cross-nvptx-newlib7-devel-7.5.0+r278197-4.30.1 >  A aBp9|BU^\vnc.[8J2".(coH2ڨz_I=88;YFP&tAMW7FcQ~DDs?^̃|+цnqք bgr^|L觔#VV߂Ra pٺ%b]=$lx=Қ,ܞH.kh$Șl.hb&ICVPTOS+,p<ثx4%`^ca9895b0e0f741930a748ec86493d69aae6db36d98131668a827c8261d252b3df33be37f0fb15c7e47e07a45b1a4dab1cc6f7632NaBp9|DSq':/VyNȾ)xT(֔D $y}7qoJD;Ÿ2莖*s*i w~E g2,͎:Y- uLWRV> ˮT]\-U`4سN @(x;ّuwl&!Ƽj"{<6Z,'ns2?x ZȲK[.j!Ꞽ8'k '`v IbN >p=(?d* 1 U  )>DLss s s s !s "Xs$$s&cs((s**++o+++(+8+b9-@b:4ibFrGrsHtsIv`sXvYv\w s]xs^|b}gc~d~f~l~u~svxzCcross-nvptx-newlib7-devel7.5.0+r2781974.30.1newlib for the nvptx offload targetNewlib development files for the nvptx offload target compiler.aBNsheep52MNSUSE Linux Enterprise 15SUSE LLC GPL-3.0-or-laterhttps://www.suse.com/Development/Languages/C and C++https://gcc.gnu.org/linuxx86_64? 9 n  Q P,p0t !m2L'w9 "B W8@64o %2`Y~O2S+ %4Y_d34)'t k8<Rk\#YZ$  YdYdAA큤A큤A큤A큤A큤A큤A큤aB]p]V]9]5@]0_@]@\9\O\@\B@\]o@\3?@\ @[v[6@[@Z3@ZZUZa@ZlZ@Z@ZH@ZZs@ZiZe@Z_:Z]@Z\ZV@ZKt@Z/Z*~Z@Y@YY˒YYW@Y@YYaYTY?Y:Y7Y-^Y;@Y Y.XXXDXXӸXƉX@X@X@X|@XXAXXwoXQ4@X<@X8'X5rguenther@suse.comlukas.lansky@suse.comgiuliano.belinassi@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comdmueller@suse.comrguenther@suse.commatz@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comguillaume.gardet@opensuse.orgrguenther@suse.comrguenther@suse.commliska@suse.czrguenther@suse.commatz@suse.comrguenther@suse.comschwab@suse.derguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.commliska@suse.czmliska@suse.czrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.commliska@suse.czrguenther@suse.comrguenther@suse.comrguenther@suse.comschwab@suse.derguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.commatz@suse.derguenther@suse.combwiedemann@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.commliska@suse.czrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.comrguenther@suse.commliska@suse.czmliska@suse.cz- Adjust some ambiguous SPDX license specifications to prevent spec-cleaner from messing up.- Add gcc7-pr55917.patch to do not handle exceptions in std::thread (jsc#CAR-1182)- - Add gcc7-pfe-0001-Backport-Add-entry-for-patchable_function_entry.patch gcc7-pfe-0002-Backport-Skip-fpatchable-function-entry-tests-for-nv.patch gcc7-pfe-0003-Backport-Error-out-on-nvptx-for-fpatchable-function-.patch gcc7-pfe-0004-Backport-Adapt-scan-assembler-times-for-alpha.patch gcc7-pfe-0005-Backport-patchable_function_entry-decl.c-Use-3-NOPs-.patch gcc7-pfe-0006-Backport-IBM-Z-Use-the-dedicated-NOP-instructions-fo.patch gcc7-pfe-0007-Backport-Add-regex-to-search-for-uppercase-NOP-instr.patch gcc7-pfe-0008-Backport-ICE-segmentation-fault-with-patchable_funct.patch gcc7-pfe-0009-Backport-patchable_function_entry-decl.c-Pass-mcpu-g.patch gcc7-pfe-0010-Backport-patchable_function_entry-decl.c-Do-not-run-.patch gcc7-pfe-0011-Backport-patchable_function_entry-decl.c-Add-fno-pie.patch gcc7-pfe-0012-Backport-PR-c-89946-ICE-in-assemble_start_function-a.patch gcc7-pfe-0013-Backport-targhooks.c-default_print_patchable_functio.patch gcc7-pfe-0014-Backport-Align-__patchable_function_entries-to-POINT.patch gcc7-pfe-0015-Backport-Fix-PR-93242-patchable-function-entry-broke.patch gcc7-pfe-0016-Backport-AArch64-PR92424-Fix-fpatchable-function-ent.patch gcc7-pfe-0017-Backport-Fix-patchable-function-entry-on-arc.patch gcc7-pfe-0018-Backport-Add-patch_area_size-and-patch_area_entry-to.patch gcc7-pfe-0019-Backport-testsuite-Adjust-patchable_function-tests-f.patch gcc7-pfe-0020-Backport-Use-the-section-flag-o-for-__patchable_func.patch gcc7-pfe-0021-Backport-varasm-Fix-up-__patchable_function_entries-.patch gcc7-pfe-0022-Backport-rs6000-Avoid-fpatchable-function-entry-regr.patch gcc7-pfe-0023-Fix-unwinding-issues-when-pfe-is-enabled.patch to add -fpatchable-function-entry feature to gcc-7.- Add gcc7-ada-MINSTKSZ.patch to fix build with glibc 2.34. - Add bits/unistd_ext.h to the list of removed fixed includes.- Add gcc7-sanitizer-cyclades.patch to remove cyclades.h use from libsanitizer fixing builds with recent kernels.- Remove include-fixed/pthread.h - Change GCC exception licenses to SPDX format- add gcc7-pr81942.patch [bsc#1181618]- Amend gcc7-aarch64-moutline-atomics.patch for glibc namespace violation with getauxval. [bsc#1167939]- Add gcc7-aarch64-sls-miti-1.patch, gcc7-aarch64-sls-miti-2.patch, gcc7-aarch64-sls-miti-3.patch to backport aarch64 Straight Line Speculation mitigation [bsc#1172798, CVE-2020-13844] - Add gcc7-fix-retrieval-of-testnames.patch to support usage in testcases added by the above.- Enable fortran for the nvptx offload compiler. - Do not specify alternate offload compiler location at configure time. - Update README.First-for.SuSE.packagers- Add gcc7-pr88522.patch to avoid assembler errors with AVX512 gather and scatter instructions when using -masm=intel. - Amend gcc7-remove-Wexpansion-to-defined-from-Wextra.patch to reflect changes in option handling in the testsuite. - Add gcc7-testsuite-fixes.patch to fix PR98001 and PR98002 which are broken testcases showing with malloc debugging enabled.- Add gcc7-aarch64-moutline-atomics.patch to backport the aarch64 - moutline-atomics feature and accumulated fixes but not its default enabling. [jsc#SLE-12209, bsc#1167939] - Order gcc7-pr92692.patch after gcc7-aarch64-moutline-atomics.patch and refresh.- Revert gcc7-pr97774.patch as it causes gdb to crash.- Fix 32bit libgnat.so link. [bsc#1178675] - Quote %{cross_arch} consistently when comparing expansion against string in RPM %if condition.- Add gcc7-pr97535.patch to fix memcpy miscompilation on aarch64. [bsc#1178624, bsc#1178577]- Add gcc7-pr97774.patch to fix debug line info for try/catch. [bsc#1178614]- Remove -mbranch-protection=standard (aarch64 flag) when gcc7 is used to build gcc7 (ie when ada is enabled)- Add gcc7-pr94148.patch to fix corruption of pass private ->aux via DF. [gcc#94148]- Add gcc7-pr93888.patch to fix debug information issue with inlined functions and passed by reference arguments. [gcc#93888]- Add gcc7-pr93965.patch in order to fix binutils release date detection issue.- Add gcc48-bsc1161913.patch to fix register allocation issue with exception handling code on s390x. [bsc#1161913]- Add gcc7-pr92692.patch: Backport PR target/92692 to fix miscompilation of some atomic code on aarch64. [bsc#1150164]- Add gcc7-pr93246.patch: Backport PR middle-end/93246- gcc7-pr92154.patch: Backport PR sanitizer/92154- Add gcc7-bsc1160086.patch to fix miscompilation in vectorized code for s390x. [bsc#1160086] [gcc#92950]- Update to GCC 7.5.0 release. - Add gcc7-pr85887.patch to fix miscompilation with thread-safe local static initialization. [gcc#85887]- Add gcc7-bsc1146475.patch to fix debug info created for array definitions that complete an earlier declaration. [bsc#1146475]- Rework shared spec file parts to allow custom Summary and Description for cross compilers. Clarify their Summary and Description. [bsc#1148517] - Reorder things in cross.spec.in so the Version define comes before the first use of %version.- Update to gcc-7-branch head (r275405). * Pulls fix for POWER9 DARN miscompilation. (bsc#1149145, CVE-2019-15847) * Includes gcc8-pr89752.patch- Remove bogus fixed include bits/statx.h from glibc 2.30. [gcc#91085]- Update to gcc-7-branch head (r273795). * Includes fix for LTO linker plugin heap overflow. (bsc#1142649, CVE-2019-14250)- Update to gcc-7-branch head (r273666). * Fixes build with -Werror=return-type.- Update to gcc-7-branch head (r273559). * Includes fix for vector shift miscompilation on s390. [bsc#1141897]- Add gcc7-flive-patching.patch patch. [bsc#1071995, fate#323487]- Strip -flto from $optflags.- Update to gcc-7-branch head (r270528). * Disables switch jump-tables when retpolines are used. [bsc#1131264, jsc#SLE-6738]- Add gcc8-pr89752.patch to fix ICE compiling tensorflow on aarch64. [bsc#1129389]- Update to gcc-7-branch head (r269676). * Pulls fix for aarch64 FMA steering pass use-after-free. [bsc#1128794] * Fixes ICE compiling tensorflow. [bsc#1129389] - Change URLs to use https.- Update to gcc-7-branch head (r268660). * Pulls fix for s390x FP load-and-test issue. [bnc#1124644] - Improve build reproducability by disabling address-space randomization during build.- Update gcc44-rename-info-files.patch to adjust gnat manual entries in the info directory. [bnc#1114592]- Update to GCC 7.4 release. - Fix AVR configuration to not use __cxa_atexit or libstdc++ headers. Point to /usr/avr/sys-root/include as system header include directory.- Update to gcc-7-branch head (r263609). * Includes fix for build with ISL 0.20. * Includes fix to no longer try linking -lieee with -mieee-fp. [bnc#1084842]- Update to gcc-7-branch head (r262243). * Pulls fix for libcpp lexing bug on ppc64le manifesting during build with gcc8. [bnc#1099119] * Pulls fix for forcing compile-time tuning even when building with -march=z13 on s390x. [bnc#1099192]- Update to gcc-7-branch head (r261272). * Fixes support for 32bit ASAN with glibc 2.27+ * Includes gcc7-bnc1087550.diff- Update gcc7-bnc1087550.diff with latest changes. [bnc#1087550]- Update gcc7-bnc1087550.diff with fix from upstream that supports both ABIs for ios_base::failure. [bnc#1087550]- Set SUSE_ASNEEDED to zero during %install so libasan keeps its NEEDED entry for libstdc++.so. [GCC#84428]- Enable --enable-fix-cortex-a53-835769 for aarch64. - Add gcc7-bnc1087550.diff to revert the ios_base::failure ABI back to compatible behavior with the default ABI. [bnc#1087550]- Update to gcc-7-branch head (r258812). * Picks fix to no longer enable -mpc-relative-literal-loads by default with --enable-fix-cortex-a53-843419. - Enable --enable-fix-cortex-a53-843419 on aarch64. [bnc#1084812] [bnc#1087930]- Update to gcc-7-branch head (r258313). * includes spectre V2 mitigation patch for s390x. [bnc#1083946]- Fix nvptx offload target compiler install so GCC can pick up required files. Split out the newlib part into cross-nvptx-newlib7-devel and avoid conflicts with GCC 8 variant via Provides/Conflicts of cross-nvptx-newlib-devel.- Update to gcc-7-branch head (r258025). * includes fix for chromium build failure. [bnc#1083290]- Update to gcc-7-branch head (r257981). - Add conflicts to non-bootstrap variant for cross packages to silence repo-checker. - Amend gcc48-remove-mpfr-2.4.0-requirement.patch to fix build on SLE11.- Use %{?_smp_mflags} everywhere. - Update _constraints to bump physicalmemory and general simplification.- Update to GCC 7.3 release.- Move misplaced %endif- Update to GCC 7.3.0 RC1 (r256792).- Update to gcc-7-branch head (r256737) * Includes gcc7-pr81481.diff * Adds backport of retpoline support via -mindirect-branch=, - mfunction-return= and friends. [bnc#1074621]- Handle new debug sources filelist variant debugsourcefiles.list. - Prune libstdc++ includes for crosses.- Do not install target parts of cross compilers into the sysroot but instead fixup manually (once required).- Update to gcc-7-branch head (r256067). - Deal with C++ being disabled for crosses. - For crosses that have a target triplet not matching that of binutils create symlinks to as and ld in the GCC private directory.- Split cross-avr into -bootstrap and non-bootstrap variant for avr-libc integration.- Add gcc7-avoid-fixinc-error.diff to avoid install-host aborting on non-existing target include directory. Remove --with-build-sysroot=/ hack from icecream cross configs, no longer prune include-fixed for them to retain a GCC provided limits.h. Remove installed install-tools.- Add gcc7-pr82248.diff to fix bogus stack probe instruction on ARM. [bnc#1068967]- Update to gcc-7-branch head (r253932). * contains fix for PR82445 which is about a RPI1 bootloader miscompile. [bnc#1061667]- Update to gcc-7-branch head (r253435). [fate#321452, fate#321496] [fate#323972] * contains fix for PR82406 which blocks chromium build. - Add gcc7-pr81481.diff to fix a register allocation issue. [bnc#1048861]- Update to gcc-7-branch head (r253221). * Includes similar fix to gcc41-ppc32-retaddr.patch, disable the patch but keep the testcase.- Add support for zero-sized VLAs and allocas with - fstack-clash-protection. [bnc #1059075] Changes gcc7-stack-probe.diff.- Update to gcc-7-branch head (r251579). * Includes GCC 7.2 release. * Includes gcc7-pr81766.diff and gcc7-go-sigrtmax.patch.- Sort tar file list to make cross-* packages build reproducibly (boo#1041090)- Add gcc7-pr81766.diff to fix grub2 build.- Update to gcc-7-branch head (r250819). * Includes GCC 7.2 RC1. * Includes fix for gcov crash. [bnc#1050487] - Add gcc7-stack-probe.diff for support of -fstack-clash-protection [bnc#1039513]. - Add gcc7-go-sigrtmax.patch to fix Go build with glibc 2.26.- Update to gcc-7-branch head (r249772). * Includes patch for PR81080. [bnc#1044016] * Includes patch for PR81204. [bnc#1045732] * Includes patch for PR81112. [bnc#1043966]- Fix cross compiler update-alternatives machinery to make rpmlint happy.- Update plugin enablement guard to use %sle_version. [bnc#1043590]- Update to gcc-7-branch head (r248970). * Includes gcc7-pr80593.patch.- Update to gcc-7-branch head (r248590). - Add #!BuildIgnore: gcc-PIE also to cross compiler builds.- Update to gcc-7-branch head (r248152) - Drop not working SLE-10 build support. - For SLE-15 make the i586 compiler generate code for architecture level of x86_64. - Add gcc7-pr80593.patch to fix ceph build. [bnc#1025891]- Update to gcc-7-branch head (r247545) * Includes GCC 7.1 release - For SLE15 change ppc64le tuning to power9. [fate#322728] - Change tarball compression to xz, BuildRequire xz.- Update to gcc-7-branch head (r247368) * Includes GCC 7.1 RC2 * Includes ARM ABI fix for PR77728, fixing ABI incompatibility with GCC 4.8.- Update to gcc-7-branch head (r247019). - Always create nvptx offloading cross spec file. - Fix libada provides/conflicts. - Package gcov.h. - Add #!BuildIgnore: gcc-PIE. - Fix update-alternatives.- Add update-alternatives for binaries produces by cross compilers. - Add nospeccleaner comment, remove legacy norootforbuild and icecream.- Update to gcc trunk head (r246609). - Add cross-binutils Requires to cross-gcc packages.- Really fix libtsan requirement on ppc. [boo#1030623] - Also fix liblsan requirement on pcc.- Update to gcc trunk head (r246414). - Package gcov-dump. - Remove gcc7-debug-dwarf2out-ice.patch. - Add gcc7-remove-Wexpansion-to-defined-from-Wextra.patch to remove useless warning from Wextra that causes build fails due to excessive log file size. - Remove libtsan Requires from the gcc7-32bit package, tsan doesn't have a 32bit multilib on any arch. [boo#1030623]- Update to gcc trunk head (r246083).- Update to gcc trunk head (r245976). - BuildRequire at least gcc-4.8 Ada. - Enable asan and ubsan for s390. - Also require gcc-c++ of the host compiler version used when that is changed due to Ada requirements.- Update to gcc trunk head (r245417). - Enable profiledbootstrap for %ix86, build with release checking. - Build stage1 with -O2 -g. - Enable Ada for s390x. - Enable asan and ubsan for s390x. - Refresh gcc44-rename-info-files.patch.- Fix up nvptx offloading so that it actually works.- Update to gcc trunk head (r245052). - Use plain avr as gcc target for AVR to match what binutils does. [bnc#1022404] - Cleanup spec file and gcc7-rpmlintrc a bit.- Update to gcc trunk head (r244934). - Add accelerator offloading cross to nvptx-none, for this also add nvptx-newlib.tar.bz2.- Update to gcc trunk head (r244867). - Bump libgo SO version to 11. - PowerPC now supports lsan and tsan. - Correct lsan/tsan packaging who are 64bits only.- Update to gcc trunk head (r244684). - Use --with-gcc-major-version-only and drop gcc-dir-version.patch. - Enable offloading for nvptx-none on the host (offload compiler still missing). Re-enable HSA offloading. - Re-add missing cross.spec.in and enable crosses.- Update to gcc trunk head (r244350). - Package avx512vpopcntdqintrin.h and sgxintrin.h on x86_64/i?86.- Update to gcc trunk head (r243648). - Package {arm,aarch64}/arm_fp16.h and arm/arm_cmse.h.- Remove broken libffi build support. - Remove more Java remanents.- Update to gcc trunk (r242874). - Add avx5124fmapsintrin.h and avx5124vnniwintrin.h header files.- New package, inherits from gcc6 * gcc-dir-version.patch, drop patchlevel from install directory names * gcc-add-defaultsspec.diff, add the ability to provide a specs file that is read by default * tls-no-direct.diff, avoid direct %fs references on x86 to not slow down Xen * gcc43-no-unwind-tables.diff, do not produce unwind tables for CRT files * gcc41-ppc32-retaddr.patch, fix expansion of __builtin_return_addr for ppc * gcc44-textdomain.patch, make translation files version specific and adjust textdomain to find them * gcc44-rename-info-files.patch, fix cross-references in info files when renaming them to be version specific * gcc48-libstdc++-api-reference.patch, fix link in the installed libstdc++ html documentation * gcc48-remove-mpfr-2.4.0-requirement.patch, make GCC work with earlier mpfr versions on old products * gcc5-no-return-gcc43-workaround.patch, make build work with host gcc 4.3 - Drops * libjava-no-multilib.diff, gcc41-java-slow_pthread_self.patch and all Java related hunks in included patches because Java is no longer included in GCC 7. * gcc6-hsa-enablement.patch as it's part of trunk * gcc6-libsanitizer-aarch64-vma48.patch as it's part of trunk * gcc6-SOURCE_DATE_EPOCH.patch as it's part of trunksheep52 1635861070  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmmopqqs7.5.0+r278197-4.30.17.5.0+r278197-4.30.17.5.0+r278197-4.30.1nvptx-noneinclude_ansi.h_syslist.halloca.har.hargz.hassert.hbitscomplex.hctype.hdirent.henvlock.henvz.herrno.hfastmath.hfcntl.hfnmatch.hgetopt.hglob.hgrp.hiconv.hieeefp.hinttypes.hlanginfo.hlibgen.hlimits.hlocale.hmachine_default_types.h_types.hansi.hendian.hfastmath.hieeefp.hmalloc.hparam.hsetjmp-dj.hsetjmp.hstdlib.htermios.htime.htypes.hmalloc.hmath.hnewlib.hpaths.hpthread.hpwd.hreent.hregdef.hregex.hrpcsched.hsearch.hsetjmp.hsignal.hspawn.hstdatomic.hstdint.hstdio.hstdio_ext.hstdlib.hstring.hstrings.hsys_default_fcntl.h_types.hcdefs.hconfig.hcustom_file.hdir.hdirent.herrno.hfcntl.hfeatures.hfile.hiconvnls.hlock.hparam.hqueue.hreent.hresource.hsched.hsignal.hstat.hstdio.hstring.hsyslimits.htime.htimeb.htimes.htypes.hunistd.hutime.hwait.htar.htermios.htgmath.htime.hunctrl.hunistd.hutime.hutmp.hwchar.hwctype.hwordexp.hliblibc.alibg.alibm.amgomplibc.alibg.alibm.a/usr//usr/nvptx-none//usr/nvptx-none/include//usr/nvptx-none/include/machine//usr/nvptx-none/include/sys//usr/nvptx-none/lib//usr/nvptx-none/lib/mgomp/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:21370/SUSE_SLE-15_Update/becc5071d002e01d5733589c1a819015-cross-nvptx-gcc7.SUSE_SLE-15_Updatecpiox86_64-suse-linuxdirectoryC source, ASCII textASCII textcurrent ar archiveT#PpPutf-82ed54a2c0aed81ce89c780abf282e80ded46bd86d5e3e8e9618555171b05e0bd?007070100000001000041ed0000000000000000000000016181423c00000000000000000000000000000000000000000000001100000000./usr/nvptx-none07070100000002000041ed0000000000000000000000016181423d00000000000000000000000000000000000000000000001900000000./usr/nvptx-none/include07070100000003000081a40000000000000000000000016181423c0000113f000000000000000000000000000000000000002100000000./usr/nvptx-none/include/_ansi.h/* Provide support for both ANSI and non-ANSI environments. */ /* Some ANSI environments are "broken" in the sense that __STDC__ cannot be relied upon to have it's intended meaning. Therefore we must use our own concoction: _HAVE_STDC. Always use _HAVE_STDC instead of __STDC__ in newlib sources! To get a strict ANSI C environment, define macro __STRICT_ANSI__. This will "comment out" the non-ANSI parts of the ANSI header files (non-ANSI header files aren't affected). */ #ifndef _ANSIDECL_H_ #define _ANSIDECL_H_ #include #include /* First try to figure out whether we really are in an ANSI C environment. */ /* FIXME: This probably needs some work. Perhaps sys/config.h can be prevailed upon to give us a clue. */ #ifdef __STDC__ #define _HAVE_STDC #endif /* ISO C++. */ #ifdef __cplusplus #if !(defined(_BEGIN_STD_C) && defined(_END_STD_C)) #ifdef _HAVE_STD_CXX #define _BEGIN_STD_C namespace std { extern "C" { #define _END_STD_C } } #else #define _BEGIN_STD_C extern "C" { #define _END_STD_C } #endif #if __GNUC_PREREQ (3, 3) #define _NOTHROW __attribute__ ((nothrow)) #else #define _NOTHROW throw() #endif #endif #else #define _BEGIN_STD_C #define _END_STD_C #define _NOTHROW #endif #ifdef _HAVE_STDC #define _PTR void * #define _AND , #define _NOARGS void #define _CONST const #define _VOLATILE volatile #define _SIGNED signed #define _DOTS , ... #define _VOID void #ifdef __CYGWIN__ #define _EXFUN_NOTHROW(name, proto) __cdecl name proto _NOTHROW #define _EXFUN(name, proto) __cdecl name proto #define _EXPARM(name, proto) (* __cdecl name) proto #define _EXFNPTR(name, proto) (__cdecl * name) proto #else #define _EXFUN_NOTHROW(name, proto) name proto _NOTHROW #define _EXFUN(name, proto) name proto #define _EXPARM(name, proto) (* name) proto #define _EXFNPTR(name, proto) (* name) proto #endif #define _DEFUN(name, arglist, args) name(args) #define _DEFUN_VOID(name) name(_NOARGS) #define _CAST_VOID (void) #ifndef _LONG_DOUBLE #define _LONG_DOUBLE long double #endif #ifndef _LONG_LONG_TYPE #define _LONG_LONG_TYPE long long #endif #ifndef _PARAMS #define _PARAMS(paramlist) paramlist #endif #else #define _PTR char * #define _AND ; #define _NOARGS #define _CONST #define _VOLATILE #define _SIGNED #define _DOTS #define _VOID void #define _EXFUN(name, proto) name() #define _EXFUN_NOTHROW(name, proto) name() #define _DEFUN(name, arglist, args) name arglist args; #define _DEFUN_VOID(name) name() #define _CAST_VOID #define _LONG_DOUBLE double #define _LONG_LONG_TYPE long #ifndef _PARAMS #define _PARAMS(paramlist) () #endif #endif /* Support gcc's __attribute__ facility. */ #ifdef __GNUC__ #define _ATTRIBUTE(attrs) __attribute__ (attrs) #else #define _ATTRIBUTE(attrs) #endif /* The traditional meaning of 'extern inline' for GCC is not to emit the function body unless the address is explicitly taken. However this behaviour is changing to match the C99 standard, which uses 'extern inline' to indicate that the function body *must* be emitted. Likewise, a function declared without either 'extern' or 'static' defaults to extern linkage (C99 6.2.2p5), and the compiler may choose whether to use the inline version or call the extern linkage version (6.7.4p6). If we are using GCC, but do not have the new behaviour, we need to use extern inline; if we are using a new GCC with the C99-compatible behaviour, or a non-GCC compiler (which we will have to hope is C99, since there is no other way to achieve the effect of omitting the function if it isn't referenced) we use 'static inline', which c99 defines to mean more-or-less the same as the Gnu C 'extern inline'. */ #if defined(__GNUC__) && !defined(__GNUC_STDC_INLINE__) /* We're using GCC, but without the new C99-compatible behaviour. */ #define _ELIDABLE_INLINE extern __inline__ _ATTRIBUTE ((__always_inline__)) #else /* We're using GCC in C99 mode, or an unknown compiler which we just have to hope obeys the C99 semantics of inline. */ #define _ELIDABLE_INLINE static __inline__ #endif #if __GNUC_PREREQ (3, 1) #define _NOINLINE __attribute__ ((__noinline__)) #define _NOINLINE_STATIC _NOINLINE static #else /* On non-GNU compilers and GCC prior to version 3.1 the compiler can't be trusted not to inline if it is static. */ #define _NOINLINE #define _NOINLINE_STATIC #endif #endif /* _ANSIDECL_H_ */ 07070100000004000081a40000000000000000000000016181423c00000492000000000000000000000000000000000000002400000000./usr/nvptx-none/include/_syslist.h/* internal use only -- mapping of "system calls" for libraries that lose and only provide C names, so that we end up in violation of ANSI */ #ifndef __SYSLIST_H #define __SYSLIST_H #ifdef MISSING_SYSCALL_NAMES #define _close close #define _execve execve #define _fcntl fcntl #define _fork fork #define _fstat fstat #define _getpid getpid #define _gettimeofday gettimeofday #define _isatty isatty #define _kill kill #define _link link #define _lseek lseek #define _mkdir mkdir #define _open open #define _read read #define _sbrk sbrk #define _stat stat #define _times times #define _unlink unlink #define _wait wait #define _write write #endif /* MISSING_SYSCALL_NAMES */ #if defined MISSING_SYSCALL_NAMES || !defined HAVE_OPENDIR /* If the system call interface is missing opendir, readdir, and closedir, there is an implementation of these functions in libc/posix that is implemented using open, getdents, and close. Note, these functions are currently not in the libc/syscalls directory. */ #define _opendir opendir #define _readdir readdir #define _closedir closedir #endif /* MISSING_SYSCALL_NAMES || !HAVE_OPENDIR */ #endif /* !__SYSLIST_H_ */ 07070100000005000081a40000000000000000000000016181423c000001a4000000000000000000000000000000000000002200000000./usr/nvptx-none/include/alloca.h/* libc/include/alloca.h - Allocate memory on stack */ /* Written 2000 by Werner Almesberger */ /* Rearranged for general inclusion by stdlib.h. 2001, Corinna Vinschen */ #ifndef _NEWLIB_ALLOCA_H #define _NEWLIB_ALLOCA_H #include "_ansi.h" #include #undef alloca #ifdef __GNUC__ #define alloca(size) __builtin_alloca(size) #else void * _EXFUN(alloca,(size_t)); #endif #endif 07070100000006000081a40000000000000000000000016181423c00000b8e000000000000000000000000000000000000001e00000000./usr/nvptx-none/include/ar.h/* $NetBSD: ar.h,v 1.4 1994/10/26 00:55:43 cgd Exp $ */ /*- * Copyright (c) 1991, 1993 * The Regents of the University of California. All rights reserved. * (c) UNIX System Laboratories, Inc. * All or some portions of this file are derived from material licensed * to the University of California by American Telephone and Telegraph * Co. or Unix System Laboratories, Inc. and are reproduced herein with * the permission of UNIX System Laboratories, Inc. * * This code is derived from software contributed to Berkeley by * Hugh Smith at The University of Guelph. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)ar.h 8.2 (Berkeley) 1/21/94 */ #ifndef _AR_H_ #define _AR_H_ /* Pre-4BSD archives had these magic numbers in them. */ #define OARMAG1 0177555 #define OARMAG2 0177545 #define ARMAG "!\n" /* ar "magic number" */ #define SARMAG 8 /* strlen(ARMAG); */ #define AR_EFMT1 "#1/" /* extended format #1 */ struct ar_hdr { char ar_name[16]; /* name */ char ar_date[12]; /* modification time */ char ar_uid[6]; /* user id */ char ar_gid[6]; /* group id */ char ar_mode[8]; /* octal file permissions */ char ar_size[10]; /* size in bytes */ #define ARFMAG "`\n" char ar_fmag[2]; /* consistency check */ }; #endif /* !_AR_H_ */ 07070100000007000081a40000000000000000000000016181423c00000539000000000000000000000000000000000000002000000000./usr/nvptx-none/include/argz.h/* Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. * * Permission to use, copy, modify, and distribute this software * is freely granted, provided that this notice is preserved. */ #ifndef _ARGZ_H_ #define _ARGZ_H_ #include #include #include "_ansi.h" _BEGIN_STD_C /* The newlib implementation of these functions assumes that sizeof(char) == 1. */ error_t argz_create (char *const argv[], char **argz, size_t *argz_len); error_t argz_create_sep (const char *string, int sep, char **argz, size_t *argz_len); size_t argz_count (const char *argz, size_t argz_len); void argz_extract (char *argz, size_t argz_len, char **argv); void argz_stringify (char *argz, size_t argz_len, int sep); error_t argz_add (char **argz, size_t *argz_len, const char *str); error_t argz_add_sep (char **argz, size_t *argz_len, const char *str, int sep); error_t argz_append (char **argz, size_t *argz_len, const char *buf, size_t buf_len); error_t argz_delete (char **argz, size_t *argz_len, char *entry); error_t argz_insert (char **argz, size_t *argz_len, char *before, const char *entry); char * argz_next (char *argz, size_t argz_len, const char *entry); error_t argz_replace (char **argz, size_t *argz_len, const char *str, const char *with, unsigned *replace_count); _END_STD_C #endif /* _ARGZ_H_ */ 07070100000008000081a40000000000000000000000016181423c000004a6000000000000000000000000000000000000002200000000./usr/nvptx-none/include/assert.h/* assert.h */ #ifdef __cplusplus extern "C" { #endif #include "_ansi.h" #undef assert #ifdef NDEBUG /* required by ANSI standard */ # define assert(__e) ((void)0) #else # define assert(__e) ((__e) ? (void)0 : __assert_func (__FILE__, __LINE__, \ __ASSERT_FUNC, #__e)) # ifndef __ASSERT_FUNC /* Use g++'s demangled names in C++. */ # if defined __cplusplus && defined __GNUC__ # define __ASSERT_FUNC __PRETTY_FUNCTION__ /* C99 requires the use of __func__. */ # elif __STDC_VERSION__ >= 199901L # define __ASSERT_FUNC __func__ /* Older versions of gcc don't have __func__ but can use __FUNCTION__. */ # elif __GNUC__ >= 2 # define __ASSERT_FUNC __FUNCTION__ /* failed to detect __func__ support. */ # else # define __ASSERT_FUNC ((char *) 0) # endif # endif /* !__ASSERT_FUNC */ #endif /* !NDEBUG */ void _EXFUN(__assert, (const char *, int, const char *) _ATTRIBUTE ((__noreturn__))); void _EXFUN(__assert_func, (const char *, int, const char *, const char *) _ATTRIBUTE ((__noreturn__))); #if __STDC_VERSION__ >= 201112L && !defined __cplusplus # define static_assert _Static_assert #endif #ifdef __cplusplus } #endif 07070100000009000041ed0000000000000000000000016181423d00000000000000000000000000000000000000000000001e00000000./usr/nvptx-none/include/bits0707010000000a000081a40000000000000000000000016181423c00000cde000000000000000000000000000000000000002300000000./usr/nvptx-none/include/complex.h/* $NetBSD: complex.h,v 1.3 2010/09/15 16:11:30 christos Exp $ */ /* * Written by Matthias Drochner. * Public domain. */ #ifndef _COMPLEX_H #define _COMPLEX_H #define complex _Complex #define _Complex_I 1.0fi #define I _Complex_I #include __BEGIN_DECLS /* 7.3.5 Trigonometric functions */ /* 7.3.5.1 The cacos functions */ double complex cacos(double complex); float complex cacosf(float complex); /* 7.3.5.2 The casin functions */ double complex casin(double complex); float complex casinf(float complex); /* 7.3.5.1 The catan functions */ double complex catan(double complex); float complex catanf(float complex); /* 7.3.5.1 The ccos functions */ double complex ccos(double complex); float complex ccosf(float complex); /* 7.3.5.1 The csin functions */ double complex csin(double complex); float complex csinf(float complex); /* 7.3.5.1 The ctan functions */ double complex ctan(double complex); float complex ctanf(float complex); /* 7.3.6 Hyperbolic functions */ /* 7.3.6.1 The cacosh functions */ double complex cacosh(double complex); float complex cacoshf(float complex); /* 7.3.6.2 The casinh functions */ double complex casinh(double complex); float complex casinhf(float complex); /* 7.3.6.3 The catanh functions */ double complex catanh(double complex); float complex catanhf(float complex); /* 7.3.6.4 The ccosh functions */ double complex ccosh(double complex); float complex ccoshf(float complex); /* 7.3.6.5 The csinh functions */ double complex csinh(double complex); float complex csinhf(float complex); /* 7.3.6.6 The ctanh functions */ double complex ctanh(double complex); float complex ctanhf(float complex); /* 7.3.7 Exponential and logarithmic functions */ /* 7.3.7.1 The cexp functions */ double complex cexp(double complex); float complex cexpf(float complex); /* 7.3.7.2 The clog functions */ double complex clog(double complex); float complex clogf(float complex); /* 7.3.8 Power and absolute-value functions */ /* 7.3.8.1 The cabs functions */ /*#ifndef __LIBM0_SOURCE__ */ /* avoid conflict with historical cabs(struct complex) */ /* double cabs(double complex) __RENAME(__c99_cabs); float cabsf(float complex) __RENAME(__c99_cabsf); #endif */ double cabs(double complex) ; float cabsf(float complex) ; /* 7.3.8.2 The cpow functions */ double complex cpow(double complex, double complex); float complex cpowf(float complex, float complex); /* 7.3.8.3 The csqrt functions */ double complex csqrt(double complex); float complex csqrtf(float complex); /* 7.3.9 Manipulation functions */ /* 7.3.9.1 The carg functions */ double carg(double complex); float cargf(float complex); /* 7.3.9.2 The cimag functions */ double cimag(double complex); float cimagf(float complex); /*long double cimagl(long double complex); */ /* 7.3.9.3 The conj functions */ double complex conj(double complex); float complex conjf(float complex); /*long double complex conjl(long double complex); */ /* 7.3.9.4 The cproj functions */ double complex cproj(double complex); float complex cprojf(float complex); /*long double complex cprojl(long double complex); */ /* 7.3.9.5 The creal functions */ double creal(double complex); float crealf(float complex); /*long double creall(long double complex); */ __END_DECLS #endif /* ! _COMPLEX_H */ 0707010000000b000081a40000000000000000000000016181423c00000eeb000000000000000000000000000000000000002100000000./usr/nvptx-none/include/ctype.h#ifndef _CTYPE_H_ #define _CTYPE_H_ #include "_ansi.h" _BEGIN_STD_C int _EXFUN(isalnum, (int __c)); int _EXFUN(isalpha, (int __c)); int _EXFUN(iscntrl, (int __c)); int _EXFUN(isdigit, (int __c)); int _EXFUN(isgraph, (int __c)); int _EXFUN(islower, (int __c)); int _EXFUN(isprint, (int __c)); int _EXFUN(ispunct, (int __c)); int _EXFUN(isspace, (int __c)); int _EXFUN(isupper, (int __c)); int _EXFUN(isxdigit,(int __c)); int _EXFUN(tolower, (int __c)); int _EXFUN(toupper, (int __c)); #if !defined(__STRICT_ANSI__) || defined(__cplusplus) || __STDC_VERSION__ >= 199901L int _EXFUN(isblank, (int __c)); #endif #ifndef __STRICT_ANSI__ int _EXFUN(isascii, (int __c)); int _EXFUN(toascii, (int __c)); #define _tolower(__c) ((unsigned char)(__c) - 'A' + 'a') #define _toupper(__c) ((unsigned char)(__c) - 'a' + 'A') #endif #define _U 01 #define _L 02 #define _N 04 #define _S 010 #define _P 020 #define _C 040 #define _X 0100 #define _B 0200 #ifndef _MB_CAPABLE _CONST #endif extern __IMPORT char *__ctype_ptr__; #ifndef __cplusplus /* These macros are intentionally written in a manner that will trigger a gcc -Wall warning if the user mistakenly passes a 'char' instead of an int containing an 'unsigned char'. Note that the sizeof will always be 1, which is what we want for mapping EOF to __ctype_ptr__[0]; the use of a raw index inside the sizeof triggers the gcc warning if __c was of type char, and sizeof masks side effects of the extra __c. Meanwhile, the real index to __ctype_ptr__+1 must be cast to int, since isalpha(0x100000001LL) must equal isalpha(1), rather than being an out-of-bounds reference on a 64-bit machine. */ #define __ctype_lookup(__c) ((__ctype_ptr__+sizeof(""[__c]))[(int)(__c)]) #define isalpha(__c) (__ctype_lookup(__c)&(_U|_L)) #define isupper(__c) ((__ctype_lookup(__c)&(_U|_L))==_U) #define islower(__c) ((__ctype_lookup(__c)&(_U|_L))==_L) #define isdigit(__c) (__ctype_lookup(__c)&_N) #define isxdigit(__c) (__ctype_lookup(__c)&(_X|_N)) #define isspace(__c) (__ctype_lookup(__c)&_S) #define ispunct(__c) (__ctype_lookup(__c)&_P) #define isalnum(__c) (__ctype_lookup(__c)&(_U|_L|_N)) #define isprint(__c) (__ctype_lookup(__c)&(_P|_U|_L|_N|_B)) #define isgraph(__c) (__ctype_lookup(__c)&(_P|_U|_L|_N)) #define iscntrl(__c) (__ctype_lookup(__c)&_C) #if defined(__GNUC__) && \ (!defined(__STRICT_ANSI__) || __STDC_VERSION__ >= 199901L) #define isblank(__c) \ __extension__ ({ __typeof__ (__c) __x = (__c); \ (__ctype_lookup(__x)&_B) || (int) (__x) == '\t';}) #endif /* Non-gcc versions will get the library versions, and will be slightly slower. These macros are not NLS-aware so they are disabled if the system supports the extended character sets. */ # if defined(__GNUC__) # if !defined (_MB_EXTENDED_CHARSETS_ISO) && !defined (_MB_EXTENDED_CHARSETS_WINDOWS) # define toupper(__c) \ __extension__ ({ __typeof__ (__c) __x = (__c); \ islower (__x) ? (int) __x - 'a' + 'A' : (int) __x;}) # define tolower(__c) \ __extension__ ({ __typeof__ (__c) __x = (__c); \ isupper (__x) ? (int) __x - 'A' + 'a' : (int) __x;}) # else /* _MB_EXTENDED_CHARSETS* */ /* Allow a gcc warning if the user passed 'char', but defer to the function. */ # define toupper(__c) \ __extension__ ({ __typeof__ (__c) __x = (__c); \ (void) __ctype_ptr__[__x]; (toupper) (__x);}) # define tolower(__c) \ __extension__ ({ __typeof__ (__c) __x = (__c); \ (void) __ctype_ptr__[__x]; (tolower) (__x);}) # endif /* _MB_EXTENDED_CHARSETS* */ # endif /* __GNUC__ */ #endif /* !__cplusplus */ #ifndef __STRICT_ANSI__ #define isascii(__c) ((unsigned)(__c)<=0177) #define toascii(__c) ((__c)&0177) #endif /* For C++ backward-compatibility only. */ extern __IMPORT _CONST char _ctype_[]; _END_STD_C #endif /* _CTYPE_H_ */ 0707010000000c000081a40000000000000000000000016181423c000000ea000000000000000000000000000000000000002200000000./usr/nvptx-none/include/dirent.h#ifndef _DIRENT_H_ #define _DIRENT_H_ #ifdef __cplusplus extern "C" { #endif #include #if !defined(MAXNAMLEN) && !defined(_POSIX_SOURCE) #define MAXNAMLEN 1024 #endif #ifdef __cplusplus } #endif #endif /*_DIRENT_H_*/ 0707010000000d000081a40000000000000000000000016181423c0000016e000000000000000000000000000000000000002300000000./usr/nvptx-none/include/envlock.h/* envlock.h -- header file for env routines. */ #ifndef _INCLUDE_ENVLOCK_H_ #define _INCLUDE_ENVLOCK_H_ #include <_ansi.h> #include #define ENV_LOCK __env_lock(reent_ptr) #define ENV_UNLOCK __env_unlock(reent_ptr) void _EXFUN(__env_lock,(struct _reent *reent)); void _EXFUN(__env_unlock,(struct _reent *reent)); #endif /* _INCLUDE_ENVLOCK_H_ */ 0707010000000e000081a40000000000000000000000016181423c0000030d000000000000000000000000000000000000002000000000./usr/nvptx-none/include/envz.h/* Copyright (C) 2002 by Red Hat, Incorporated. All rights reserved. * * Permission to use, copy, modify, and distribute this software * is freely granted, provided that this notice is preserved. */ #include #include /* The newlib implementation of these functions assumes that sizeof(char) == 1. */ char * envz_entry (const char *envz, size_t envz_len, const char *name); char * envz_get (const char *envz, size_t envz_len, const char *name); error_t envz_add (char **envz, size_t *envz_len, const char *name, const char *value); error_t envz_merge (char **envz, size_t *envz_len, const char *envz2, size_t envz2_len, int override); void envz_remove(char **envz, size_t *envz_len, const char *name); void envz_strip (char **envz, size_t *envz_len); 0707010000000f000081a40000000000000000000000016181423c000000ae000000000000000000000000000000000000002100000000./usr/nvptx-none/include/errno.h#ifndef __ERRNO_H__ #define __ERRNO_H__ #ifndef __error_t_defined typedef int error_t; #define __error_t_defined 1 #endif #include #endif /* !__ERRNO_H__ */ 07070100000010000081a40000000000000000000000016181423c000000b9000000000000000000000000000000000000002400000000./usr/nvptx-none/include/fastmath.h#ifndef _FASTMATH_H_ #ifdef __cplusplus extern "C" { #endif #define _FASTMATH_H_ #include #include #ifdef __cplusplus } #endif #endif /* _FASTMATH_H_ */ 07070100000011000081a40000000000000000000000016181423c00000017000000000000000000000000000000000000002100000000./usr/nvptx-none/include/fcntl.h#include 07070100000012000081a40000000000000000000000016181423c00000951000000000000000000000000000000000000002300000000./usr/nvptx-none/include/fnmatch.h/*- * Copyright (c) 1992, 1993 * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * $FreeBSD: src/include/fnmatch.h,v 1.10 2002/03/23 17:24:53 imp Exp $ * @(#)fnmatch.h 8.1 (Berkeley) 6/2/93 */ #ifndef _FNMATCH_H_ #define _FNMATCH_H_ #define FNM_NOMATCH 1 /* Match failed. */ #define FNM_NOESCAPE 0x01 /* Disable backslash escaping. */ #define FNM_PATHNAME 0x02 /* Slash must be matched by slash. */ #define FNM_PERIOD 0x04 /* Period must be matched by period. */ #if defined(_GNU_SOURCE) || !defined(_ANSI_SOURCE) && !defined(_POSIX_SOURCE) #define FNM_LEADING_DIR 0x08 /* Ignore / after Imatch. */ #define FNM_CASEFOLD 0x10 /* Case insensitive search. */ #define FNM_IGNORECASE FNM_CASEFOLD #define FNM_FILE_NAME FNM_PATHNAME #endif #include __BEGIN_DECLS int fnmatch(const char *, const char *, int); __END_DECLS #endif /* !_FNMATCH_H_ */ 07070100000013000081a40000000000000000000000016181423c000019e3000000000000000000000000000000000000002200000000./usr/nvptx-none/include/getopt.h/**************************************************************************** getopt.h - Read command line options AUTHOR: Gregory Pietsch CREATED Thu Jan 09 22:37:00 1997 DESCRIPTION: The getopt() function parses the command line arguments. Its arguments argc and argv are the argument count and array as passed to the main() function on program invocation. The argument optstring is a list of available option characters. If such a character is followed by a colon (`:'), the option takes an argument, which is placed in optarg. If such a character is followed by two colons, the option takes an optional argument, which is placed in optarg. If the option does not take an argument, optarg is NULL. The external variable optind is the index of the next array element of argv to be processed; it communicates from one call to the next which element to process. The getopt_long() function works like getopt() except that it also accepts long options started by two dashes `--'. If these take values, it is either in the form --arg=value or --arg value It takes the additional arguments longopts which is a pointer to the first element of an array of type GETOPT_LONG_OPTION_T, defined below. The last element of the array has to be filled with NULL for the name field. The longind pointer points to the index of the current long option relative to longopts if it is non-NULL. The getopt() function returns the option character if the option was found successfully, `:' if there was a missing parameter for one of the options, `?' for an unknown option character, and EOF for the end of the option list. The getopt_long() function's return value is described below. The function getopt_long_only() is identical to getopt_long(), except that a plus sign `+' can introduce long options as well as `--'. Describe how to deal with options that follow non-option ARGV-elements. If the caller did not specify anything, the default is REQUIRE_ORDER if the environment variable POSIXLY_CORRECT is defined, PERMUTE otherwise. REQUIRE_ORDER means don't recognize them as options; stop option processing when the first non-option is seen. This is what Unix does. This mode of operation is selected by either setting the environment variable POSIXLY_CORRECT, or using `+' as the first character of the optstring parameter. PERMUTE is the default. We permute the contents of ARGV as we scan, so that eventually all the non-options are at the end. This allows options to be given in any order, even with programs that were not written to expect this. RETURN_IN_ORDER is an option available to programs that were written to expect options and other ARGV-elements in any order and that care about the ordering of the two. We describe each non-option ARGV-element as if it were the argument of an option with character code 1. Using `-' as the first character of the optstring parameter selects this mode of operation. The special argument `--' forces an end of option-scanning regardless of the value of `ordering'. In the case of RETURN_IN_ORDER, only `--' can cause getopt() and friends to return EOF with optind != argc. COPYRIGHT NOTICE AND DISCLAIMER: Copyright (C) 1997 Gregory Pietsch This file and the accompanying getopt.c implementation file are hereby placed in the public domain without restrictions. Just give the author credit, don't claim you wrote it or prevent anyone else from using it. Gregory Pietsch's current e-mail address: gpietsch@comcast.net ****************************************************************************/ /* This is a glibc-extension header file. */ #ifndef GETOPT_H #define GETOPT_H #include <_ansi.h> /* include files needed by this include file */ #define no_argument 0 #define required_argument 1 #define optional_argument 2 #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /* types defined by this include file */ struct option { const char *name; /* the name of the long option */ int has_arg; /* one of the above macros */ int *flag; /* determines if getopt_long() returns a * value for a long option; if it is * non-NULL, 0 is returned as a function * value and the value of val is stored in * the area pointed to by flag. Otherwise, * val is returned. */ int val; /* determines the value to return if flag is * NULL. */ }; /* While getopt.h is a glibc extension, the following are newlib extensions. * They are optionally included via the __need_getopt_newlib flag. */ #ifdef __need_getopt_newlib /* macros defined by this include file */ #define NO_ARG no_argument #define REQUIRED_ARG required_argument #define OPTIONAL_ARG optional_argument /* The GETOPT_DATA_INITIALIZER macro is used to initialize a statically- allocated variable of type struct getopt_data. */ #define GETOPT_DATA_INITIALIZER {0,0,0,0,0} /* These #defines are to make accessing the reentrant functions easier. */ #define getopt_r __getopt_r #define getopt_long_r __getopt_long_r #define getopt_long_only_r __getopt_long_only_r /* The getopt_data structure is for reentrancy. Its members are similar to the externally-defined variables. */ typedef struct getopt_data { char *optarg; int optind, opterr, optopt, optwhere; } getopt_data; #endif /* __need_getopt_newlib */ /* externally-defined variables */ extern char *optarg; extern int optind; extern int opterr; extern int optopt; /* function prototypes */ int _EXFUN (getopt, (int __argc, char *const __argv[], const char *__optstring)); int _EXFUN (getopt_long, (int __argc, char *const __argv[], const char *__shortopts, const struct option * __longopts, int *__longind)); int _EXFUN (getopt_long_only, (int __argc, char *const __argv[], const char *__shortopts, const struct option * __longopts, int *__longind)); #ifdef __need_getopt_newlib int _EXFUN (__getopt_r, (int __argc, char *const __argv[], const char *__optstring, struct getopt_data * __data)); int _EXFUN (__getopt_long_r, (int __argc, char *const __argv[], const char *__shortopts, const struct option * __longopts, int *__longind, struct getopt_data * __data)); int _EXFUN (__getopt_long_only_r, (int __argc, char *const __argv[], const char *__shortopts, const struct option * __longopts, int *__longind, struct getopt_data * __data)); #endif /* __need_getopt_newlib */ #ifdef __cplusplus }; #endif /* __cplusplus */ #endif /* GETOPT_H */ /* END OF FILE getopt.h */ 07070100000014000081a40000000000000000000000016181423c00000ecb000000000000000000000000000000000000002000000000./usr/nvptx-none/include/glob.h/* * Copyright (c) 1989, 1993 * The Regents of the University of California. All rights reserved. * * This code is derived from software contributed to Berkeley by * Guido van Rossum. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)glob.h 8.1 (Berkeley) 6/2/93 * $FreeBSD: src/include/glob.h,v 1.6 2002/03/23 17:24:53 imp Exp $ */ #ifndef _GLOB_H_ #define _GLOB_H_ #include struct stat; typedef struct { int gl_pathc; /* Count of total paths so far. */ int gl_matchc; /* Count of paths matching pattern. */ int gl_offs; /* Reserved at beginning of gl_pathv. */ int gl_flags; /* Copy of flags parameter to glob. */ char **gl_pathv; /* List of paths matching pattern. */ /* Copy of errfunc parameter to glob. */ int (*gl_errfunc)(const char *, int); /* * Alternate filesystem access methods for glob; replacement * versions of closedir(3), readdir(3), opendir(3), stat(2) * and lstat(2). */ void (*gl_closedir)(void *); struct dirent *(*gl_readdir)(void *); void *(*gl_opendir)(const char *); int (*gl_lstat)(const char *, struct stat *); int (*gl_stat)(const char *, struct stat *); } glob_t; #define GLOB_APPEND 0x0001 /* Append to output from previous call. */ #define GLOB_DOOFFS 0x0002 /* Use gl_offs. */ #define GLOB_ERR 0x0004 /* Return on error. */ #define GLOB_MARK 0x0008 /* Append / to matching directories. */ #define GLOB_NOCHECK 0x0010 /* Return pattern itself if nothing matches. */ #define GLOB_NOSORT 0x0020 /* Don't sort. */ #define GLOB_ALTDIRFUNC 0x0040 /* Use alternately specified directory funcs. */ #define GLOB_BRACE 0x0080 /* Expand braces ala csh. */ #define GLOB_MAGCHAR 0x0100 /* Pattern had globbing characters. */ #define GLOB_NOMAGIC 0x0200 /* GLOB_NOCHECK without magic chars (csh). */ #define GLOB_QUOTE 0x0400 /* Quote special chars with \. */ #define GLOB_TILDE 0x0800 /* Expand tilde names from the passwd file. */ #define GLOB_LIMIT 0x1000 /* limit number of returned paths */ /* backwards compatibility, this is the old name for this option */ #define GLOB_MAXPATH GLOB_LIMIT #define GLOB_NOSPACE (-1) /* Malloc call failed. */ #define GLOB_ABEND (-2) /* Unignored error. */ __BEGIN_DECLS int glob(const char *__restrict, int, int (*)(const char *, int), glob_t *__restrict); void globfree(glob_t *); __END_DECLS #endif /* !_GLOB_H_ */ 07070100000015000081a40000000000000000000000016181423c00000d50000000000000000000000000000000000000001f00000000./usr/nvptx-none/include/grp.h/* $NetBSD: grp.h,v 1.7 1995/04/29 05:30:40 cgd Exp $ */ /*- * Copyright (c) 1989, 1993 * The Regents of the University of California. All rights reserved. * (c) UNIX System Laboratories, Inc. * All or some portions of this file are derived from material licensed * to the University of California by American Telephone and Telegraph * Co. or Unix System Laboratories, Inc. and are reproduced herein with * the permission of UNIX System Laboratories, Inc. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)grp.h 8.2 (Berkeley) 1/21/94 */ #ifndef _GRP_H_ #define _GRP_H_ #include #include #ifdef __CYGWIN__ #include #endif #if !defined(_POSIX_SOURCE) && !defined(_XOPEN_SOURCE) #define _PATH_GROUP "/etc/group" #endif struct group { char *gr_name; /* group name */ char *gr_passwd; /* group password */ gid_t gr_gid; /* group id */ char **gr_mem; /* group members */ }; #ifdef __cplusplus extern "C" { #endif #ifndef __INSIDE_CYGWIN__ struct group *getgrgid (gid_t); struct group *getgrnam (const char *); int getgrnam_r (const char *, struct group *, char *, size_t, struct group **); int getgrgid_r (gid_t, struct group *, char *, size_t, struct group **); #ifndef _POSIX_SOURCE struct group *getgrent (void); void setgrent (void); void endgrent (void); #ifndef __CYGWIN__ void setgrfile (const char *); #endif /* !__CYGWIN__ */ #ifndef _XOPEN_SOURCE #ifndef __CYGWIN__ char *group_from_gid (gid_t, int); int setgroupent (int); #endif /* !__CYGWIN__ */ int initgroups (const char *, gid_t); #endif /* !_XOPEN_SOURCE */ #endif /* !_POSIX_SOURCE */ #endif /* !__INSIDE_CYGWIN__ */ #ifdef __cplusplus } #endif #endif /* !_GRP_H_ */ 07070100000016000081a40000000000000000000000016181423c0000088a000000000000000000000000000000000000002100000000./usr/nvptx-none/include/iconv.h/* * Copyright (c) 2003-2004, Artem B. Bityuckiy, SoftMine Corporation. * Rights transferred to Franklin Electronic Publishers. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. */ #ifndef _ICONV_H_ #define _ICONV_H_ #include <_ansi.h> #include #include #include /* iconv_t: charset conversion descriptor type */ typedef _iconv_t iconv_t; _BEGIN_STD_C #ifndef _REENT_ONLY iconv_t _EXFUN(iconv_open, (_CONST char *, _CONST char *)); size_t _EXFUN(iconv, (iconv_t, char **__restrict, size_t *__restrict, char **__restrict, size_t *__restrict)); int _EXFUN(iconv_close, (iconv_t)); #endif iconv_t _EXFUN(_iconv_open_r, (struct _reent *, _CONST char *, _CONST char *)); size_t _EXFUN(_iconv_r, (struct _reent *, iconv_t, _CONST char **, size_t *, char **, size_t *)); int _EXFUN(_iconv_close_r, (struct _reent *, iconv_t)); _END_STD_C #endif /* #ifndef _ICONV_H_ */ 07070100000017000081a40000000000000000000000016181423c000014ef000000000000000000000000000000000000002200000000./usr/nvptx-none/include/ieeefp.h#ifndef _IEEE_FP_H_ #define _IEEE_FP_H_ #include "_ansi.h" #include _BEGIN_STD_C /* FIXME FIXME FIXME: Neither of __ieee_{float,double}_shape_tape seem to be used anywhere except in libm/test. If that is the case, please delete these from here. If that is not the case, please insert documentation here describing why they're needed. */ #ifdef __IEEE_BIG_ENDIAN typedef union { double value; struct { unsigned int sign : 1; unsigned int exponent: 11; unsigned int fraction0:4; unsigned int fraction1:16; unsigned int fraction2:16; unsigned int fraction3:16; } number; struct { unsigned int sign : 1; unsigned int exponent: 11; unsigned int quiet:1; unsigned int function0:3; unsigned int function1:16; unsigned int function2:16; unsigned int function3:16; } nan; struct { unsigned long msw; unsigned long lsw; } parts; long aslong[2]; } __ieee_double_shape_type; #endif #ifdef __IEEE_LITTLE_ENDIAN typedef union { double value; struct { #ifdef __SMALL_BITFIELDS unsigned int fraction3:16; unsigned int fraction2:16; unsigned int fraction1:16; unsigned int fraction0: 4; #else unsigned int fraction1:32; unsigned int fraction0:20; #endif unsigned int exponent :11; unsigned int sign : 1; } number; struct { #ifdef __SMALL_BITFIELDS unsigned int function3:16; unsigned int function2:16; unsigned int function1:16; unsigned int function0:3; #else unsigned int function1:32; unsigned int function0:19; #endif unsigned int quiet:1; unsigned int exponent: 11; unsigned int sign : 1; } nan; struct { unsigned long lsw; unsigned long msw; } parts; long aslong[2]; } __ieee_double_shape_type; #endif #ifdef __IEEE_BIG_ENDIAN typedef union { float value; struct { unsigned int sign : 1; unsigned int exponent: 8; unsigned int fraction0: 7; unsigned int fraction1: 16; } number; struct { unsigned int sign:1; unsigned int exponent:8; unsigned int quiet:1; unsigned int function0:6; unsigned int function1:16; } nan; long p1; } __ieee_float_shape_type; #endif #ifdef __IEEE_LITTLE_ENDIAN typedef union { float value; struct { unsigned int fraction0: 7; unsigned int fraction1: 16; unsigned int exponent: 8; unsigned int sign : 1; } number; struct { unsigned int function1:16; unsigned int function0:6; unsigned int quiet:1; unsigned int exponent:8; unsigned int sign:1; } nan; long p1; } __ieee_float_shape_type; #endif /* FLOATING ROUNDING */ typedef int fp_rnd; #define FP_RN 0 /* Round to nearest */ #define FP_RM 1 /* Round down */ #define FP_RP 2 /* Round up */ #define FP_RZ 3 /* Round to zero (trunate) */ fp_rnd _EXFUN(fpgetround,(void)); fp_rnd _EXFUN(fpsetround, (fp_rnd)); /* EXCEPTIONS */ typedef int fp_except; #define FP_X_INV 0x10 /* Invalid operation */ #define FP_X_DX 0x80 /* Divide by zero */ #define FP_X_OFL 0x04 /* Overflow exception */ #define FP_X_UFL 0x02 /* Underflow exception */ #define FP_X_IMP 0x01 /* imprecise exception */ fp_except _EXFUN(fpgetmask,(void)); fp_except _EXFUN(fpsetmask,(fp_except)); fp_except _EXFUN(fpgetsticky,(void)); fp_except _EXFUN(fpsetsticky, (fp_except)); /* INTEGER ROUNDING */ typedef int fp_rdi; #define FP_RDI_TOZ 0 /* Round to Zero */ #define FP_RDI_RD 1 /* Follow float mode */ fp_rdi _EXFUN(fpgetroundtoi,(void)); fp_rdi _EXFUN(fpsetroundtoi,(fp_rdi)); #undef isnan #undef isinf int _EXFUN(isnan, (double)); int _EXFUN(isinf, (double)); int _EXFUN(finite, (double)); int _EXFUN(isnanf, (float)); int _EXFUN(isinff, (float)); int _EXFUN(finitef, (float)); #define __IEEE_DBL_EXPBIAS 1023 #define __IEEE_FLT_EXPBIAS 127 #define __IEEE_DBL_EXPLEN 11 #define __IEEE_FLT_EXPLEN 8 #define __IEEE_DBL_FRACLEN (64 - (__IEEE_DBL_EXPLEN + 1)) #define __IEEE_FLT_FRACLEN (32 - (__IEEE_FLT_EXPLEN + 1)) #define __IEEE_DBL_MAXPOWTWO ((double)(1L << 32 - 2) * (1L << (32-11) - 32 + 1)) #define __IEEE_FLT_MAXPOWTWO ((float)(1L << (32-8) - 1)) #define __IEEE_DBL_NAN_EXP 0x7ff #define __IEEE_FLT_NAN_EXP 0xff #ifndef __ieeefp_isnanf #define __ieeefp_isnanf(x) (((*(long *)&(x) & 0x7f800000L)==0x7f800000L) && \ ((*(long *)&(x) & 0x007fffffL)!=0000000000L)) #endif #define isnanf(x) __ieeefp_isnanf(x) #ifndef __ieeefp_isinff #define __ieeefp_isinff(x) (((*(long *)&(x) & 0x7f800000L)==0x7f800000L) && \ ((*(long *)&(x) & 0x007fffffL)==0000000000L)) #endif #define isinff(x) __ieeefp_isinff(x) #ifndef __ieeefp_finitef #define __ieeefp_finitef(x) (((*(long *)&(x) & 0x7f800000L)!=0x7f800000L)) #endif #define finitef(x) __ieeefp_finitef(x) #ifdef _DOUBLE_IS_32BITS #undef __IEEE_DBL_EXPBIAS #define __IEEE_DBL_EXPBIAS __IEEE_FLT_EXPBIAS #undef __IEEE_DBL_EXPLEN #define __IEEE_DBL_EXPLEN __IEEE_FLT_EXPLEN #undef __IEEE_DBL_FRACLEN #define __IEEE_DBL_FRACLEN __IEEE_FLT_FRACLEN #undef __IEEE_DBL_MAXPOWTWO #define __IEEE_DBL_MAXPOWTWO __IEEE_FLT_MAXPOWTWO #undef __IEEE_DBL_NAN_EXP #define __IEEE_DBL_NAN_EXP __IEEE_FLT_NAN_EXP #undef __ieee_double_shape_type #define __ieee_double_shape_type __ieee_float_shape_type #endif /* _DOUBLE_IS_32BITS */ _END_STD_C #endif /* _IEEE_FP_H_ */ 07070100000018000081a40000000000000000000000016181423c00001b94000000000000000000000000000000000000002400000000./usr/nvptx-none/include/inttypes.h/* * Copyright (c) 2004, 2005 by * Ralf Corsepius, Ulm/Germany. All rights reserved. * * Permission to use, copy, modify, and distribute this software * is freely granted, provided that this notice is preserved. */ /** * @file inttypes.h */ #ifndef _INTTYPES_H #define _INTTYPES_H #include #include #define __need_wchar_t #include /* Don't use __STDINT_EXP test since GCC's stdint.h provides different macros than newlib's stdint.h. */ #if __GNUC_PREREQ(3, 2) #define __INTTYPES_EXP(x) __##x##__ #else #define __INTTYPES_EXP(x) x #include #endif #define __STRINGIFY(a) #a /* 8-bit types */ #define __PRI8(x) __STRINGIFY(x) #define __SCN8(x) __STRINGIFY(hh##x) #define PRId8 __PRI8(d) #define PRIi8 __PRI8(i) #define PRIo8 __PRI8(o) #define PRIu8 __PRI8(u) #define PRIx8 __PRI8(x) #define PRIX8 __PRI8(X) #define SCNd8 __SCN8(d) #define SCNi8 __SCN8(i) #define SCNo8 __SCN8(o) #define SCNu8 __SCN8(u) #define SCNx8 __SCN8(x) #define PRIdLEAST8 __PRI8(d) #define PRIiLEAST8 __PRI8(i) #define PRIoLEAST8 __PRI8(o) #define PRIuLEAST8 __PRI8(u) #define PRIxLEAST8 __PRI8(x) #define PRIXLEAST8 __PRI8(X) #define SCNdLEAST8 __SCN8(d) #define SCNiLEAST8 __SCN8(i) #define SCNoLEAST8 __SCN8(o) #define SCNuLEAST8 __SCN8(u) #define SCNxLEAST8 __SCN8(x) #define PRIdFAST8 __PRI8(d) #define PRIiFAST8 __PRI8(i) #define PRIoFAST8 __PRI8(o) #define PRIuFAST8 __PRI8(u) #define PRIxFAST8 __PRI8(x) #define PRIXFAST8 __PRI8(X) #define SCNdFAST8 __SCN8(d) #define SCNiFAST8 __SCN8(i) #define SCNoFAST8 __SCN8(o) #define SCNuFAST8 __SCN8(u) #define SCNxFAST8 __SCN8(x) /* 16-bit types */ #define __PRI16(x) __STRINGIFY(x) #define __SCN16(x) __STRINGIFY(h##x) #define PRId16 __PRI16(d) #define PRIi16 __PRI16(i) #define PRIo16 __PRI16(o) #define PRIu16 __PRI16(u) #define PRIx16 __PRI16(x) #define PRIX16 __PRI16(X) #define SCNd16 __SCN16(d) #define SCNi16 __SCN16(i) #define SCNo16 __SCN16(o) #define SCNu16 __SCN16(u) #define SCNx16 __SCN16(x) #define PRIdLEAST16 __PRI16(d) #define PRIiLEAST16 __PRI16(i) #define PRIoLEAST16 __PRI16(o) #define PRIuLEAST16 __PRI16(u) #define PRIxLEAST16 __PRI16(x) #define PRIXLEAST16 __PRI16(X) #define SCNdLEAST16 __SCN16(d) #define SCNiLEAST16 __SCN16(i) #define SCNoLEAST16 __SCN16(o) #define SCNuLEAST16 __SCN16(u) #define SCNxLEAST16 __SCN16(x) #define PRIdFAST16 __PRI16(d) #define PRIiFAST16 __PRI16(i) #define PRIoFAST16 __PRI16(o) #define PRIuFAST16 __PRI16(u) #define PRIxFAST16 __PRI16(x) #define PRIXFAST16 __PRI16(X) #define SCNdFAST16 __SCN16(d) #define SCNiFAST16 __SCN16(i) #define SCNoFAST16 __SCN16(o) #define SCNuFAST16 __SCN16(u) #define SCNxFAST16 __SCN16(x) /* 32-bit types */ #if __have_long32 #define __PRI32(x) __STRINGIFY(l##x) #define __SCN32(x) __STRINGIFY(l##x) #else #define __PRI32(x) __STRINGIFY(x) #define __SCN32(x) __STRINGIFY(x) #endif #define PRId32 __PRI32(d) #define PRIi32 __PRI32(i) #define PRIo32 __PRI32(o) #define PRIu32 __PRI32(u) #define PRIx32 __PRI32(x) #define PRIX32 __PRI32(X) #define SCNd32 __SCN32(d) #define SCNi32 __SCN32(i) #define SCNo32 __SCN32(o) #define SCNu32 __SCN32(u) #define SCNx32 __SCN32(x) #define PRIdLEAST32 __PRI32(d) #define PRIiLEAST32 __PRI32(i) #define PRIoLEAST32 __PRI32(o) #define PRIuLEAST32 __PRI32(u) #define PRIxLEAST32 __PRI32(x) #define PRIXLEAST32 __PRI32(X) #define SCNdLEAST32 __SCN32(d) #define SCNiLEAST32 __SCN32(i) #define SCNoLEAST32 __SCN32(o) #define SCNuLEAST32 __SCN32(u) #define SCNxLEAST32 __SCN32(x) #define PRIdFAST32 __PRI32(d) #define PRIiFAST32 __PRI32(i) #define PRIoFAST32 __PRI32(o) #define PRIuFAST32 __PRI32(u) #define PRIxFAST32 __PRI32(x) #define PRIXFAST32 __PRI32(X) #define SCNdFAST32 __SCN32(d) #define SCNiFAST32 __SCN32(i) #define SCNoFAST32 __SCN32(o) #define SCNuFAST32 __SCN32(u) #define SCNxFAST32 __SCN32(x) /* 64-bit types */ #if __have_long64 #define __PRI64(x) __STRINGIFY(l##x) #define __SCN64(x) __STRINGIFY(l##x) #elif __have_longlong64 #define __PRI64(x) __STRINGIFY(ll##x) #define __SCN64(x) __STRINGIFY(ll##x) #else #define __PRI64(x) __STRINGIFY(x) #define __SCN64(x) __STRINGIFY(x) #endif #define PRId64 __PRI64(d) #define PRIi64 __PRI64(i) #define PRIo64 __PRI64(o) #define PRIu64 __PRI64(u) #define PRIx64 __PRI64(x) #define PRIX64 __PRI64(X) #define SCNd64 __SCN64(d) #define SCNi64 __SCN64(i) #define SCNo64 __SCN64(o) #define SCNu64 __SCN64(u) #define SCNx64 __SCN64(x) #if __int64_t_defined #define PRIdLEAST64 __PRI64(d) #define PRIiLEAST64 __PRI64(i) #define PRIoLEAST64 __PRI64(o) #define PRIuLEAST64 __PRI64(u) #define PRIxLEAST64 __PRI64(x) #define PRIXLEAST64 __PRI64(X) #define SCNdLEAST64 __SCN64(d) #define SCNiLEAST64 __SCN64(i) #define SCNoLEAST64 __SCN64(o) #define SCNuLEAST64 __SCN64(u) #define SCNxLEAST64 __SCN64(x) #define PRIdFAST64 __PRI64(d) #define PRIiFAST64 __PRI64(i) #define PRIoFAST64 __PRI64(o) #define PRIuFAST64 __PRI64(u) #define PRIxFAST64 __PRI64(x) #define PRIXFAST64 __PRI64(X) #define SCNdFAST64 __SCN64(d) #define SCNiFAST64 __SCN64(i) #define SCNoFAST64 __SCN64(o) #define SCNuFAST64 __SCN64(u) #define SCNxFAST64 __SCN64(x) #endif /* max-bit types */ #if __have_long64 #define __PRIMAX(x) __STRINGIFY(l##x) #define __SCNMAX(x) __STRINGIFY(l##x) #elif __have_longlong64 #define __PRIMAX(x) __STRINGIFY(ll##x) #define __SCNMAX(x) __STRINGIFY(ll##x) #else #define __PRIMAX(x) __STRINGIFY(x) #define __SCNMAX(x) __STRINGIFY(x) #endif #define PRIdMAX __PRIMAX(d) #define PRIiMAX __PRIMAX(i) #define PRIoMAX __PRIMAX(o) #define PRIuMAX __PRIMAX(u) #define PRIxMAX __PRIMAX(x) #define PRIXMAX __PRIMAX(X) #define SCNdMAX __SCNMAX(d) #define SCNiMAX __SCNMAX(i) #define SCNoMAX __SCNMAX(o) #define SCNuMAX __SCNMAX(u) #define SCNxMAX __SCNMAX(x) /* ptr types */ #if PTRDIFF_MAX <= __INTTYPES_EXP(INT_MAX) # define __PRIPTR(x) __STRINGIFY(x) # define __SCNPTR(x) __STRINGIFY(x) #elif PTRDIFF_MAX <= __INTTYPES_EXP(LONG_MAX) || !defined(__have_longlong64) # define __PRIPTR(x) __STRINGIFY(l##x) # define __SCNPTR(x) __STRINGIFY(l##x) #else # define __PRIPTR(x) __STRINGIFY(ll##x) # define __SCNPTR(x) __STRINGIFY(ll##x) #endif #define PRIdPTR __PRIPTR(d) #define PRIiPTR __PRIPTR(i) #define PRIoPTR __PRIPTR(o) #define PRIuPTR __PRIPTR(u) #define PRIxPTR __PRIPTR(x) #define PRIXPTR __PRIPTR(X) #define SCNdPTR __SCNPTR(d) #define SCNiPTR __SCNPTR(i) #define SCNoPTR __SCNPTR(o) #define SCNuPTR __SCNPTR(u) #define SCNxPTR __SCNPTR(x) typedef struct { intmax_t quot; intmax_t rem; } imaxdiv_t; #ifdef __cplusplus extern "C" { #endif extern intmax_t imaxabs(intmax_t j); extern imaxdiv_t imaxdiv(intmax_t numer, intmax_t denomer); extern intmax_t strtoimax(const char *__restrict, char **__restrict, int); extern uintmax_t strtoumax(const char *__restrict, char **__restrict, int); extern intmax_t wcstoimax(const wchar_t *__restrict, wchar_t **__restrict, int); extern uintmax_t wcstoumax(const wchar_t *__restrict, wchar_t **__restrict, int); #ifdef __cplusplus } #endif #endif 07070100000019000081a40000000000000000000000016181423c00001f1e000000000000000000000000000000000000002400000000./usr/nvptx-none/include/langinfo.h/*- * Copyright (c) 2001 Alexey Zelkin * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. * * $FreeBSD: src/include/langinfo.h,v 1.5 2002/03/23 17:24:53 imp Exp $ */ #ifndef _LANGINFO_H_ #define _LANGINFO_H_ #include #include #include typedef int nl_item; enum __nl_item { /* POSIX and BSD defined items have to stick to the original values to maintain backward compatibility. */ _NL_CTYPE_CODESET_NAME = 0, /* codeset name */ #define CODESET _NL_CTYPE_CODESET_NAME D_T_FMT, /* string for formatting date and time */ #define D_T_FMT D_T_FMT D_FMT, /* date format string */ #define D_FMT D_FMT T_FMT, /* time format string */ #define T_FMT T_FMT T_FMT_AMPM, /* a.m. or p.m. time formatting string */ #define T_FMT_AMPM T_FMT_AMPM AM_STR, /* Ante Meridian affix */ #define AM_STR AM_STR PM_STR, /* Post Meridian affix */ #define PM_STR PM_STR /* week day names */ DAY_1, #define DAY_1 DAY_1 DAY_2, #define DAY_2 DAY_2 DAY_3, #define DAY_3 DAY_3 DAY_4, #define DAY_4 DAY_4 DAY_5, #define DAY_5 DAY_5 DAY_6, #define DAY_6 DAY_6 DAY_7, #define DAY_7 DAY_7 /* abbreviated week day names */ ABDAY_1, #define ABDAY_1 ABDAY_1 ABDAY_2, #define ABDAY_2 ABDAY_2 ABDAY_3, #define ABDAY_3 ABDAY_3 ABDAY_4, #define ABDAY_4 ABDAY_4 ABDAY_5, #define ABDAY_5 ABDAY_5 ABDAY_6, #define ABDAY_6 ABDAY_6 ABDAY_7, #define ABDAY_7 ABDAY_7 /* month names */ MON_1, #define MON_1 MON_1 MON_2, #define MON_2 MON_2 MON_3, #define MON_3 MON_3 MON_4, #define MON_4 MON_4 MON_5, #define MON_5 MON_5 MON_6, #define MON_6 MON_6 MON_7, #define MON_7 MON_7 MON_8, #define MON_8 MON_8 MON_9, #define MON_9 MON_9 MON_10, #define MON_10 MON_10 MON_11, #define MON_11 MON_11 MON_12, #define MON_12 MON_12 /* abbreviated month names */ ABMON_1, #define ABMON_1 ABMON_1 ABMON_2, #define ABMON_2 ABMON_2 ABMON_3, #define ABMON_3 ABMON_3 ABMON_4, #define ABMON_4 ABMON_4 ABMON_5, #define ABMON_5 ABMON_5 ABMON_6, #define ABMON_6 ABMON_6 ABMON_7, #define ABMON_7 ABMON_7 ABMON_8, #define ABMON_8 ABMON_8 ABMON_9, #define ABMON_9 ABMON_9 ABMON_10, #define ABMON_10 ABMON_10 ABMON_11, #define ABMON_11 ABMON_11 ABMON_12, #define ABMON_12 ABMON_12 ERA, /* era description segments */ #define ERA ERA ERA_D_FMT, /* era date format string */ #define ERA_D_FMT ERA_D_FMT ERA_D_T_FMT, /* era date and time format string */ #define ERA_D_T_FMT ERA_D_T_FMT ERA_T_FMT, /* era time format string */ #define ERA_T_FMT ERA_T_FMT ALT_DIGITS, /* alternative symbols for digits */ #define ALT_DIGITS ALT_DIGITS RADIXCHAR, /* radix char */ #define RADIXCHAR RADIXCHAR THOUSEP, /* separator for thousands */ #define THOUSEP THOUSEP YESEXPR, /* affirmative response expression */ #define YESEXPR YESEXPR NOEXPR, /* negative response expression */ #define NOEXPR NOEXPR YESSTR, /* affirmative response for yes/no queries */ #define YESSTR YESSTR NOSTR, /* negative response for yes/no queries */ #define NOSTR NOSTR CRNCYSTR, /* currency symbol */ #define CRNCYSTR CRNCYSTR D_MD_ORDER, /* month/day order (BSD extension) */ #define D_MD_ORDER D_MD_ORDER _NL_TIME_DATE_FMT = 84, /* date fmt used by date(1) (GNU extension) */ #define _DATE_FMT _NL_TIME_DATE_FMT #ifdef __HAVE_LOCALE_INFO__ _NL_CTYPE_MB_CUR_MAX, _NL_MESSAGES_CODESET, #ifdef __HAVE_LOCALE_INFO_EXTENDED__ /* NOTE: Always maintain the order and position of existing entries! Always append new entry to the list, prior to the definition of _NL_LOCALE_EXTENDED_LAST_ENTRY. */ _NL_LOCALE_EXTENDED_FIRST_ENTRY, _NL_CTYPE_OUTDIGITS0_MB, _NL_CTYPE_OUTDIGITS1_MB, _NL_CTYPE_OUTDIGITS2_MB, _NL_CTYPE_OUTDIGITS3_MB, _NL_CTYPE_OUTDIGITS4_MB, _NL_CTYPE_OUTDIGITS5_MB, _NL_CTYPE_OUTDIGITS6_MB, _NL_CTYPE_OUTDIGITS7_MB, _NL_CTYPE_OUTDIGITS8_MB, _NL_CTYPE_OUTDIGITS9_MB, _NL_CTYPE_OUTDIGITS0_WC, _NL_CTYPE_OUTDIGITS1_WC, _NL_CTYPE_OUTDIGITS2_WC, _NL_CTYPE_OUTDIGITS3_WC, _NL_CTYPE_OUTDIGITS4_WC, _NL_CTYPE_OUTDIGITS5_WC, _NL_CTYPE_OUTDIGITS6_WC, _NL_CTYPE_OUTDIGITS7_WC, _NL_CTYPE_OUTDIGITS8_WC, _NL_CTYPE_OUTDIGITS9_WC, _NL_TIME_CODESET, _NL_TIME_WMON_1, _NL_TIME_WMON_2, _NL_TIME_WMON_3, _NL_TIME_WMON_4, _NL_TIME_WMON_5, _NL_TIME_WMON_6, _NL_TIME_WMON_7, _NL_TIME_WMON_8, _NL_TIME_WMON_9, _NL_TIME_WMON_10, _NL_TIME_WMON_11, _NL_TIME_WMON_12, _NL_TIME_WMONTH_1, _NL_TIME_WMONTH_2, _NL_TIME_WMONTH_3, _NL_TIME_WMONTH_4, _NL_TIME_WMONTH_5, _NL_TIME_WMONTH_6, _NL_TIME_WMONTH_7, _NL_TIME_WMONTH_8, _NL_TIME_WMONTH_9, _NL_TIME_WMONTH_10, _NL_TIME_WMONTH_11, _NL_TIME_WMONTH_12, _NL_TIME_WWDAY_1, _NL_TIME_WWDAY_2, _NL_TIME_WWDAY_3, _NL_TIME_WWDAY_4, _NL_TIME_WWDAY_5, _NL_TIME_WWDAY_6, _NL_TIME_WWDAY_7, _NL_TIME_WWEEKDAY_1, _NL_TIME_WWEEKDAY_2, _NL_TIME_WWEEKDAY_3, _NL_TIME_WWEEKDAY_4, _NL_TIME_WWEEKDAY_5, _NL_TIME_WWEEKDAY_6, _NL_TIME_WWEEKDAY_7, _NL_TIME_WT_FMT, _NL_TIME_WD_FMT, _NL_TIME_WD_T_FMT, _NL_TIME_WAM_STR, _NL_TIME_WPM_STR, _NL_TIME_WDATE_FMT, _NL_TIME_WT_FMT_AMPM, _NL_TIME_WERA, _NL_TIME_WERA_D_FMT, _NL_TIME_WERA_D_T_FMT, _NL_TIME_WERA_T_FMT, _NL_TIME_WALT_DIGITS, _NL_NUMERIC_CODESET, _NL_NUMERIC_GROUPING, _NL_NUMERIC_DECIMAL_POINT_WC, _NL_NUMERIC_THOUSANDS_SEP_WC, _NL_MONETARY_INT_CURR_SYMBOL, _NL_MONETARY_CURRENCY_SYMBOL, _NL_MONETARY_MON_DECIMAL_POINT, _NL_MONETARY_MON_THOUSANDS_SEP, _NL_MONETARY_MON_GROUPING, _NL_MONETARY_POSITIVE_SIGN, _NL_MONETARY_NEGATIVE_SIGN, _NL_MONETARY_INT_FRAC_DIGITS, _NL_MONETARY_FRAC_DIGITS, _NL_MONETARY_P_CS_PRECEDES, _NL_MONETARY_P_SEP_BY_SPACE, _NL_MONETARY_N_CS_PRECEDES, _NL_MONETARY_N_SEP_BY_SPACE, _NL_MONETARY_P_SIGN_POSN, _NL_MONETARY_N_SIGN_POSN, _NL_MONETARY_INT_P_CS_PRECEDES, _NL_MONETARY_INT_P_SEP_BY_SPACE, _NL_MONETARY_INT_N_CS_PRECEDES, _NL_MONETARY_INT_N_SEP_BY_SPACE, _NL_MONETARY_INT_P_SIGN_POSN, _NL_MONETARY_INT_N_SIGN_POSN, _NL_MONETARY_CODESET, _NL_MONETARY_WINT_CURR_SYMBOL, _NL_MONETARY_WCURRENCY_SYMBOL, _NL_MONETARY_WMON_DECIMAL_POINT, _NL_MONETARY_WMON_THOUSANDS_SEP, _NL_MONETARY_WPOSITIVE_SIGN, _NL_MONETARY_WNEGATIVE_SIGN, _NL_MESSAGES_WYESEXPR, _NL_MESSAGES_WNOEXPR, _NL_MESSAGES_WYESSTR, _NL_MESSAGES_WNOSTR, _NL_COLLATE_CODESET, /* This MUST be the last entry since it's used to check for an array index in nl_langinfo(). */ _NL_LOCALE_EXTENDED_LAST_ENTRY #endif /* __HAVE_LOCALE_INFO_EXTENDED__ */ #endif /* __HAVE_LOCALE_INFO__ */ }; __BEGIN_DECLS char *nl_langinfo(nl_item); __END_DECLS #endif /* !_LANGINFO_H_ */ 0707010000001a000081a40000000000000000000000016181423c0000012c000000000000000000000000000000000000002200000000./usr/nvptx-none/include/libgen.h/* * libgen.h - defined by XPG4 */ #ifndef _LIBGEN_H_ #define _LIBGEN_H_ #include "_ansi.h" #include #ifdef __cplusplus extern "C" { #endif char *_EXFUN(basename, (char *)); char *_EXFUN(dirname, (char *)); #ifdef __cplusplus } #endif #endif /* _LIBGEN_H_ */ 0707010000001b000081a40000000000000000000000016181423c00000f9b000000000000000000000000000000000000002200000000./usr/nvptx-none/include/limits.h#ifndef _LIBC_LIMITS_H_ # define _LIBC_LIMITS_H_ 1 #include # ifdef _MB_LEN_MAX # define MB_LEN_MAX _MB_LEN_MAX # else # define MB_LEN_MAX 1 # endif /* Maximum number of positional arguments, if _WANT_IO_POS_ARGS. */ # ifndef NL_ARGMAX # define NL_ARGMAX 32 # endif /* if do not have #include_next support, then we have to define the limits here. */ # if !defined __GNUC__ || __GNUC__ < 2 # ifndef _LIMITS_H # define _LIMITS_H 1 # include /* Number of bits in a `char'. */ # undef CHAR_BIT # define CHAR_BIT 8 /* Minimum and maximum values a `signed char' can hold. */ # undef SCHAR_MIN # define SCHAR_MIN (-128) # undef SCHAR_MAX # define SCHAR_MAX 127 /* Maximum value an `unsigned char' can hold. (Minimum is 0). */ # undef UCHAR_MAX # define UCHAR_MAX 255 /* Minimum and maximum values a `char' can hold. */ # ifdef __CHAR_UNSIGNED__ # undef CHAR_MIN # define CHAR_MIN 0 # undef CHAR_MAX # define CHAR_MAX 255 # else # undef CHAR_MIN # define CHAR_MIN (-128) # undef CHAR_MAX # define CHAR_MAX 127 # endif /* Minimum and maximum values a `signed short int' can hold. */ # undef SHRT_MIN /* For the sake of 16 bit hosts, we may not use -32768 */ # define SHRT_MIN (-32767-1) # undef SHRT_MAX # define SHRT_MAX 32767 /* Maximum value an `unsigned short int' can hold. (Minimum is 0). */ # undef USHRT_MAX # define USHRT_MAX 65535 /* Minimum and maximum values a `signed int' can hold. */ # ifndef __INT_MAX__ # define __INT_MAX__ 2147483647 # endif # undef INT_MIN # define INT_MIN (-INT_MAX-1) # undef INT_MAX # define INT_MAX __INT_MAX__ /* Maximum value an `unsigned int' can hold. (Minimum is 0). */ # undef UINT_MAX # define UINT_MAX (INT_MAX * 2U + 1) /* Minimum and maximum values a `signed long int' can hold. (Same as `int'). */ # ifndef __LONG_MAX__ # if defined (__alpha__) || (defined (__sparc__) && defined(__arch64__)) || defined (__sparcv9) # define __LONG_MAX__ 9223372036854775807L # else # define __LONG_MAX__ 2147483647L # endif /* __alpha__ || sparc64 */ # endif # undef LONG_MIN # define LONG_MIN (-LONG_MAX-1) # undef LONG_MAX # define LONG_MAX __LONG_MAX__ /* Maximum value an `unsigned long int' can hold. (Minimum is 0). */ # undef ULONG_MAX # define ULONG_MAX (LONG_MAX * 2UL + 1) # ifndef __LONG_LONG_MAX__ # define __LONG_LONG_MAX__ 9223372036854775807LL # endif # if (defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) || \ (defined(__cplusplus) && __cplusplus >= 201103L) /* Minimum and maximum values a `signed long long int' can hold. */ # undef LLONG_MIN # define LLONG_MIN (-LLONG_MAX-1) # undef LLONG_MAX # define LLONG_MAX __LONG_LONG_MAX__ /* Maximum value an `unsigned long long int' can hold. (Minimum is 0). */ # undef ULLONG_MAX # define ULLONG_MAX (LLONG_MAX * 2ULL + 1) # endif # if defined (__GNU_LIBRARY__) ? defined (__USE_GNU) : !defined (__STRICT_ANSI__) /* Minimum and maximum values a `signed long long int' can hold. */ # undef LONG_LONG_MIN # define LONG_LONG_MIN (-LONG_LONG_MAX-1) # undef LONG_LONG_MAX # define LONG_LONG_MAX __LONG_LONG_MAX__ /* Maximum value an `unsigned long long int' can hold. (Minimum is 0). */ # undef ULONG_LONG_MAX # define ULONG_LONG_MAX (LONG_LONG_MAX * 2ULL + 1) # endif # endif /* _LIMITS_H */ # endif /* GCC 2. */ #endif /* !_LIBC_LIMITS_H_ */ #if defined __GNUC__ && !defined _GCC_LIMITS_H_ /* `_GCC_LIMITS_H_' is what GCC's file defines. */ # include_next #endif /* __GNUC__ && !_GCC_LIMITS_H_ */ #ifndef _POSIX2_RE_DUP_MAX /* The maximum number of repeated occurrences of a regular expression * permitted when using the interval notation `\{M,N\}'. */ #define _POSIX2_RE_DUP_MAX 255 #endif /* _POSIX2_RE_DUP_MAX */ #ifndef ARG_MAX #define ARG_MAX 4096 #endif #ifndef PATH_MAX #define PATH_MAX 4096 #endif 0707010000001c000081a40000000000000000000000016181423c000004f3000000000000000000000000000000000000002200000000./usr/nvptx-none/include/locale.h/* locale.h Values appropriate for the formatting of monetary and other numberic quantities. */ #ifndef _LOCALE_H_ #define _LOCALE_H_ #include "_ansi.h" #define __need_NULL #include #define LC_ALL 0 #define LC_COLLATE 1 #define LC_CTYPE 2 #define LC_MONETARY 3 #define LC_NUMERIC 4 #define LC_TIME 5 #define LC_MESSAGES 6 _BEGIN_STD_C struct lconv { char *decimal_point; char *thousands_sep; char *grouping; char *int_curr_symbol; char *currency_symbol; char *mon_decimal_point; char *mon_thousands_sep; char *mon_grouping; char *positive_sign; char *negative_sign; char int_frac_digits; char frac_digits; char p_cs_precedes; char p_sep_by_space; char n_cs_precedes; char n_sep_by_space; char p_sign_posn; char n_sign_posn; char int_n_cs_precedes; char int_n_sep_by_space; char int_n_sign_posn; char int_p_cs_precedes; char int_p_sep_by_space; char int_p_sign_posn; }; #ifndef _REENT_ONLY char *_EXFUN(setlocale,(int category, const char *locale)); struct lconv *_EXFUN(localeconv,(void)); #endif struct _reent; char *_EXFUN(_setlocale_r,(struct _reent *, int category, const char *locale)); struct lconv *_EXFUN(_localeconv_r,(struct _reent *)); _END_STD_C #endif /* _LOCALE_H_ */ 0707010000001d000041ed0000000000000000000000016181423c00000000000000000000000000000000000000000000002100000000./usr/nvptx-none/include/machine0707010000001e000081a40000000000000000000000016181423c000016c9000000000000000000000000000000000000003200000000./usr/nvptx-none/include/machine/_default_types.h/* * $Id$ */ #ifndef _MACHINE__DEFAULT_TYPES_H #define _MACHINE__DEFAULT_TYPES_H #include /* * Guess on types by examining *_MIN / *_MAX defines. */ #if __GNUC_PREREQ (3, 3) /* GCC >= 3.3.0 has ____ implicitly defined. */ #define __EXP(x) __##x##__ #else /* Fall back to POSIX versions from */ #define __EXP(x) x #include #endif #ifdef __cplusplus extern "C" { #endif #ifdef __INT8_TYPE__ typedef __INT8_TYPE__ __int8_t; #ifdef __UINT8_TYPE__ typedef __UINT8_TYPE__ __uint8_t; #else typedef unsigned __INT8_TYPE__ __uint8_t; #endif #define ___int8_t_defined 1 #elif __EXP(SCHAR_MAX) == 0x7f typedef signed char __int8_t ; typedef unsigned char __uint8_t ; #define ___int8_t_defined 1 #endif #ifdef __INT16_TYPE__ typedef __INT16_TYPE__ __int16_t; #ifdef __UINT16_TYPE__ typedef __UINT16_TYPE__ __uint16_t; #else typedef unsigned __INT16_TYPE__ __uint16_t; #endif #define ___int16_t_defined 1 #elif __EXP(INT_MAX) == 0x7fff typedef signed int __int16_t; typedef unsigned int __uint16_t; #define ___int16_t_defined 1 #elif __EXP(SHRT_MAX) == 0x7fff typedef signed short __int16_t; typedef unsigned short __uint16_t; #define ___int16_t_defined 1 #elif __EXP(SCHAR_MAX) == 0x7fff typedef signed char __int16_t; typedef unsigned char __uint16_t; #define ___int16_t_defined 1 #endif #ifdef __INT32_TYPE__ typedef __INT32_TYPE__ __int32_t; #ifdef __UINT32_TYPE__ typedef __UINT32_TYPE__ __uint32_t; #else typedef unsigned __INT32_TYPE__ __uint32_t; #endif #define ___int32_t_defined 1 #elif __EXP(INT_MAX) == 0x7fffffffL typedef signed int __int32_t; typedef unsigned int __uint32_t; #define ___int32_t_defined 1 #elif __EXP(LONG_MAX) == 0x7fffffffL typedef signed long __int32_t; typedef unsigned long __uint32_t; #define ___int32_t_defined 1 #elif __EXP(SHRT_MAX) == 0x7fffffffL typedef signed short __int32_t; typedef unsigned short __uint32_t; #define ___int32_t_defined 1 #elif __EXP(SCHAR_MAX) == 0x7fffffffL typedef signed char __int32_t; typedef unsigned char __uint32_t; #define ___int32_t_defined 1 #endif #ifdef __INT64_TYPE__ typedef __INT64_TYPE__ __int64_t; #ifdef __UINT64_TYPE__ typedef __UINT64_TYPE__ __uint64_t; #else typedef unsigned __INT64_TYPE__ __uint64_t; #endif #define ___int64_t_defined 1 #elif __EXP(LONG_MAX) > 0x7fffffff typedef signed long __int64_t; typedef unsigned long __uint64_t; #define ___int64_t_defined 1 /* GCC has __LONG_LONG_MAX__ */ #elif defined(__LONG_LONG_MAX__) && (__LONG_LONG_MAX__ > 0x7fffffff) typedef signed long long __int64_t; typedef unsigned long long __uint64_t; #define ___int64_t_defined 1 /* POSIX mandates LLONG_MAX in */ #elif defined(LLONG_MAX) && (LLONG_MAX > 0x7fffffff) typedef signed long long __int64_t; typedef unsigned long long __uint64_t; #define ___int64_t_defined 1 #elif __EXP(INT_MAX) > 0x7fffffff typedef signed int __int64_t; typedef unsigned int __uint64_t; #define ___int64_t_defined 1 #endif #ifdef __INT_LEAST8_TYPE__ typedef __INT_LEAST8_TYPE__ __int_least8_t; #ifdef __UINT_LEAST8_TYPE__ typedef __UINT_LEAST8_TYPE__ __uint_least8_t; #else typedef unsigned __INT_LEAST8_TYPE__ __uint_least8_t; #endif #define ___int_least8_t_defined 1 #elif defined(___int8_t_defined) typedef __int8_t __int_least8_t; typedef __uint8_t __uint_least8_t; #define ___int_least8_t_defined 1 #elif defined(___int16_t_defined) typedef __int16_t __int_least8_t; typedef __uint16_t __uint_least8_t; #define ___int_least8_t_defined 1 #elif defined(___int32_t_defined) typedef __int32_t __int_least8_t; typedef __uint32_t __uint_least8_t; #define ___int_least8_t_defined 1 #elif defined(___int64_t_defined) typedef __int64_t __int_least8_t; typedef __uint64_t __uint_least8_t; #define ___int_least8_t_defined 1 #endif #ifdef __INT_LEAST16_TYPE__ typedef __INT_LEAST16_TYPE__ __int_least16_t; #ifdef __UINT_LEAST16_TYPE__ typedef __UINT_LEAST16_TYPE__ __uint_least16_t; #else typedef unsigned __INT_LEAST16_TYPE__ __uint_least16_t; #endif #define ___int_least16_t_defined 1 #elif defined(___int16_t_defined) typedef __int16_t __int_least16_t; typedef __uint16_t __uint_least16_t; #define ___int_least16_t_defined 1 #elif defined(___int32_t_defined) typedef __int32_t __int_least16_t; typedef __uint32_t __uint_least16_t; #define ___int_least16_t_defined 1 #elif defined(___int64_t_defined) typedef __int64_t __int_least16_t; typedef __uint64_t __uint_least16_t; #define ___int_least16_t_defined 1 #endif #ifdef __INT_LEAST32_TYPE__ typedef __INT_LEAST32_TYPE__ __int_least32_t; #ifdef __UINT_LEAST32_TYPE__ typedef __UINT_LEAST32_TYPE__ __uint_least32_t; #else typedef unsigned __INT_LEAST32_TYPE__ __uint_least32_t; #endif #define ___int_least32_t_defined 1 #elif defined(___int32_t_defined) typedef __int32_t __int_least32_t; typedef __uint32_t __uint_least32_t; #define ___int_least32_t_defined 1 #elif defined(___int64_t_defined) typedef __int64_t __int_least32_t; typedef __uint64_t __uint_least32_t; #define ___int_least32_t_defined 1 #endif #ifdef __INT_LEAST64_TYPE__ typedef __INT_LEAST64_TYPE__ __int_least64_t; #ifdef __UINT_LEAST64_TYPE__ typedef __UINT_LEAST64_TYPE__ __uint_least64_t; #else typedef unsigned __INT_LEAST64_TYPE__ __uint_least64_t; #endif #define ___int_least64_t_defined 1 #elif defined(___int64_t_defined) typedef __int64_t __int_least64_t; typedef __uint64_t __uint_least64_t; #define ___int_least64_t_defined 1 #endif #ifdef __INTPTR_TYPE__ typedef __INTPTR_TYPE__ __intptr_t; #ifdef __UINTPTR_TYPE__ typedef __UINTPTR_TYPE__ __uintptr_t; #else typedef unsigned __INTPTR_TYPE__ __uintptr_t; #endif #elif defined(__PTRDIFF_TYPE__) typedef __PTRDIFF_TYPE__ __intptr_t; typedef unsigned __PTRDIFF_TYPE__ __uintptr_t; #else typedef long __intptr_t; typedef unsigned long __uintptr_t; #endif #undef __EXP #ifdef __cplusplus } #endif #endif /* _MACHINE__DEFAULT_TYPES_H */ 0707010000001f000081a40000000000000000000000016181423c00000070000000000000000000000000000000000000002a00000000./usr/nvptx-none/include/machine/_types.h/* * $Id$ */ #ifndef _MACHINE__TYPES_H #define _MACHINE__TYPES_H #include #endif 07070100000020000081a40000000000000000000000016181423c00000030000000000000000000000000000000000000002800000000./usr/nvptx-none/include/machine/ansi.h/* dummy header file to support BSD compiler */ 07070100000021000081a40000000000000000000000016181423c00000174000000000000000000000000000000000000002a00000000./usr/nvptx-none/include/machine/endian.h#ifndef __MACHINE_ENDIAN_H__ #include #ifndef BIG_ENDIAN #define BIG_ENDIAN 4321 #endif #ifndef LITTLE_ENDIAN #define LITTLE_ENDIAN 1234 #endif #ifndef BYTE_ORDER #if defined(__IEEE_LITTLE_ENDIAN) || defined(__IEEE_BYTES_LITTLE_ENDIAN) #define BYTE_ORDER LITTLE_ENDIAN #else #define BYTE_ORDER BIG_ENDIAN #endif #endif #endif /* __MACHINE_ENDIAN_H__ */ 07070100000022000081a40000000000000000000000016181423c00000b0d000000000000000000000000000000000000002c00000000./usr/nvptx-none/include/machine/fastmath.h#ifdef __sysvnecv70_target double EXFUN(fast_sin,(double)); double EXFUN(fast_cos,(double)); double EXFUN(fast_tan,(double)); double EXFUN(fast_asin,(double)); double EXFUN(fast_acos,(double)); double EXFUN(fast_atan,(double)); double EXFUN(fast_sinh,(double)); double EXFUN(fast_cosh,(double)); double EXFUN(fast_tanh,(double)); double EXFUN(fast_asinh,(double)); double EXFUN(fast_acosh,(double)); double EXFUN(fast_atanh,(double)); double EXFUN(fast_abs,(double)); double EXFUN(fast_sqrt,(double)); double EXFUN(fast_exp2,(double)); double EXFUN(fast_exp10,(double)); double EXFUN(fast_expe,(double)); double EXFUN(fast_log10,(double)); double EXFUN(fast_log2,(double)); double EXFUN(fast_loge,(double)); #define sin(x) fast_sin(x) #define cos(x) fast_cos(x) #define tan(x) fast_tan(x) #define asin(x) fast_asin(x) #define acos(x) fast_acos(x) #define atan(x) fast_atan(x) #define sinh(x) fast_sinh(x) #define cosh(x) fast_cosh(x) #define tanh(x) fast_tanh(x) #define asinh(x) fast_asinh(x) #define acosh(x) fast_acosh(x) #define atanh(x) fast_atanh(x) #define abs(x) fast_abs(x) #define sqrt(x) fast_sqrt(x) #define exp2(x) fast_exp2(x) #define exp10(x) fast_exp10(x) #define expe(x) fast_expe(x) #define log10(x) fast_log10(x) #define log2(x) fast_log2(x) #define loge(x) fast_loge(x) #ifdef _HAVE_STDC /* These functions are in assembler, they really do take floats. This can only be used with a real ANSI compiler */ float EXFUN(fast_sinf,(float)); float EXFUN(fast_cosf,(float)); float EXFUN(fast_tanf,(float)); float EXFUN(fast_asinf,(float)); float EXFUN(fast_acosf,(float)); float EXFUN(fast_atanf,(float)); float EXFUN(fast_sinhf,(float)); float EXFUN(fast_coshf,(float)); float EXFUN(fast_tanhf,(float)); float EXFUN(fast_asinhf,(float)); float EXFUN(fast_acoshf,(float)); float EXFUN(fast_atanhf,(float)); float EXFUN(fast_absf,(float)); float EXFUN(fast_sqrtf,(float)); float EXFUN(fast_exp2f,(float)); float EXFUN(fast_exp10f,(float)); float EXFUN(fast_expef,(float)); float EXFUN(fast_log10f,(float)); float EXFUN(fast_log2f,(float)); float EXFUN(fast_logef,(float)); #define sinf(x) fast_sinf(x) #define cosf(x) fast_cosf(x) #define tanf(x) fast_tanf(x) #define asinf(x) fast_asinf(x) #define acosf(x) fast_acosf(x) #define atanf(x) fast_atanf(x) #define sinhf(x) fast_sinhf(x) #define coshf(x) fast_coshf(x) #define tanhf(x) fast_tanhf(x) #define asinhf(x) fast_asinhf(x) #define acoshf(x) fast_acoshf(x) #define atanhf(x) fast_atanhf(x) #define absf(x) fast_absf(x) #define sqrtf(x) fast_sqrtf(x) #define exp2f(x) fast_exp2f(x) #define exp10f(x) fast_exp10f(x) #define expef(x) fast_expef(x) #define log10f(x) fast_log10f(x) #define log2f(x) fast_log2f(x) #define logef(x) fast_logef(x) #endif /* Override the functions defined in math.h */ #endif /* __sysvnecv70_target */ 07070100000023000081a40000000000000000000000016181423c0000216d000000000000000000000000000000000000002a00000000./usr/nvptx-none/include/machine/ieeefp.h#ifndef __IEEE_BIG_ENDIAN #ifndef __IEEE_LITTLE_ENDIAN /* This file can define macros to choose variations of the IEEE float format: _FLT_LARGEST_EXPONENT_IS_NORMAL Defined if the float format uses the largest exponent for finite numbers rather than NaN and infinity representations. Such a format cannot represent NaNs or infinities at all, but it's FLT_MAX is twice the IEEE value. _FLT_NO_DENORMALS Defined if the float format does not support IEEE denormals. Every float with a zero exponent is taken to be a zero representation. ??? At the moment, there are no equivalent macros above for doubles and the macros are not fully supported by --enable-newlib-hw-fp. __IEEE_BIG_ENDIAN Defined if the float format is big endian. This is mutually exclusive with __IEEE_LITTLE_ENDIAN. __IEEE_LITTLE_ENDIAN Defined if the float format is little endian. This is mutually exclusive with __IEEE_BIG_ENDIAN. Note that one of __IEEE_BIG_ENDIAN or __IEEE_LITTLE_ENDIAN must be specified for a platform or error will occur. __IEEE_BYTES_LITTLE_ENDIAN This flag is used in conjunction with __IEEE_BIG_ENDIAN to describe a situation whereby multiple words of an IEEE floating point are in big endian order, but the words themselves are little endian with respect to the bytes. _DOUBLE_IS_32BITS This is used on platforms that support double by using the 32-bit IEEE float type. _FLOAT_ARG This represents what type a float arg is passed as. It is used when the type is not promoted to double. */ #if (defined(__arm__) || defined(__thumb__)) && !defined(__MAVERICK__) /* ARM traditionally used big-endian words; and within those words the byte ordering was big or little endian depending upon the target. Modern floating-point formats are naturally ordered; in this case __VFP_FP__ will be defined, even if soft-float. */ #ifdef __VFP_FP__ # ifdef __ARMEL__ # define __IEEE_LITTLE_ENDIAN # else # define __IEEE_BIG_ENDIAN # endif #else # define __IEEE_BIG_ENDIAN # ifdef __ARMEL__ # define __IEEE_BYTES_LITTLE_ENDIAN # endif #endif #endif #if defined (__aarch64__) #if defined (__AARCH64EL__) #define __IEEE_LITTLE_ENDIAN #else #define __IEEE_BIG_ENDIAN #endif #endif #ifdef __epiphany__ #define __IEEE_LITTLE_ENDIAN #define Sudden_Underflow 1 #endif #ifdef __hppa__ #define __IEEE_BIG_ENDIAN #endif #ifdef __nds32__ #ifdef __big_endian__ #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #endif #ifdef __SPU__ #define __IEEE_BIG_ENDIAN #define isfinite(__y) \ (__extension__ ({int __cy; \ (sizeof (__y) == sizeof (float)) ? (1) : \ (__cy = fpclassify(__y)) != FP_INFINITE && __cy != FP_NAN;})) #define isinf(__x) ((sizeof (__x) == sizeof (float)) ? (0) : __isinfd(__x)) #define isnan(__x) ((sizeof (__x) == sizeof (float)) ? (0) : __isnand(__x)) /* * Macros for use in ieeefp.h. We can't just define the real ones here * (like those above) as we have name space issues when this is *not* * included via generic the ieeefp.h. */ #define __ieeefp_isnanf(x) 0 #define __ieeefp_isinff(x) 0 #define __ieeefp_finitef(x) 1 #endif #ifdef __sparc__ #ifdef __LITTLE_ENDIAN_DATA__ #define __IEEE_LITTLE_ENDIAN #else #define __IEEE_BIG_ENDIAN #endif #endif #if defined(__m68k__) || defined(__mc68000__) #define __IEEE_BIG_ENDIAN #endif #if defined(__mc68hc11__) || defined(__mc68hc12__) || defined(__mc68hc1x__) #define __IEEE_BIG_ENDIAN #ifdef __HAVE_SHORT_DOUBLE__ # define _DOUBLE_IS_32BITS #endif #endif #if defined (__H8300__) || defined (__H8300H__) || defined (__H8300S__) || defined (__H8500__) || defined (__H8300SX__) #define __IEEE_BIG_ENDIAN #define _FLOAT_ARG float #define _DOUBLE_IS_32BITS #endif #if defined (__xc16x__) || defined (__xc16xL__) || defined (__xc16xS__) #define __IEEE_LITTLE_ENDIAN #define _FLOAT_ARG float #define _DOUBLE_IS_32BITS #endif #ifdef __sh__ #ifdef __LITTLE_ENDIAN__ #define __IEEE_LITTLE_ENDIAN #else #define __IEEE_BIG_ENDIAN #endif #if defined(__SH2E__) || defined(__SH3E__) || defined(__SH4_SINGLE_ONLY__) || defined(__SH2A_SINGLE_ONLY__) #define _DOUBLE_IS_32BITS #endif #endif #ifdef _AM29K #define __IEEE_BIG_ENDIAN #endif #ifdef _WIN32 #define __IEEE_LITTLE_ENDIAN #endif #ifdef __i386__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __i960__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __lm32__ #define __IEEE_BIG_ENDIAN #endif #ifdef __M32R__ #define __IEEE_BIG_ENDIAN #endif #ifdef __nvptx__ #define __IEEE_LITTLE_ENDIAN #endif #if defined(_C4x) || defined(_C3x) #define __IEEE_BIG_ENDIAN #define _DOUBLE_IS_32BITS #endif #ifdef __TMS320C6X__ #ifdef _BIG_ENDIAN #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #endif #ifdef __TIC80__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __MIPSEL__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __MIPSEB__ #define __IEEE_BIG_ENDIAN #endif #ifdef __MMIX__ #define __IEEE_BIG_ENDIAN #endif #ifdef __D30V__ #define __IEEE_BIG_ENDIAN #endif /* necv70 was __IEEE_LITTLE_ENDIAN. */ #ifdef __W65__ #define __IEEE_LITTLE_ENDIAN #define _DOUBLE_IS_32BITS #endif #if defined(__Z8001__) || defined(__Z8002__) #define __IEEE_BIG_ENDIAN #endif #ifdef __m88k__ #define __IEEE_BIG_ENDIAN #endif #ifdef __mn10300__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __mn10200__ #define __IEEE_LITTLE_ENDIAN #define _DOUBLE_IS_32BITS #endif #ifdef __v800 #define __IEEE_LITTLE_ENDIAN #endif #ifdef __v850 #define __IEEE_LITTLE_ENDIAN #endif #ifdef __D10V__ #define __IEEE_BIG_ENDIAN #if __DOUBLE__ == 32 #define _DOUBLE_IS_32BITS #endif #endif #ifdef __PPC__ #if (defined(_BIG_ENDIAN) && _BIG_ENDIAN) || (defined(_AIX) && _AIX) #define __IEEE_BIG_ENDIAN #else #if (defined(_LITTLE_ENDIAN) && _LITTLE_ENDIAN) || (defined(__sun__) && __sun__) || (defined(_WIN32) && _WIN32) #define __IEEE_LITTLE_ENDIAN #endif #endif #endif #ifdef __xstormy16__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __arc__ #ifdef __big_endian__ #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #endif #ifdef __CRX__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __fr30__ #define __IEEE_BIG_ENDIAN #endif #ifdef __mcore__ #define __IEEE_BIG_ENDIAN #endif #ifdef __mt__ #define __IEEE_BIG_ENDIAN #endif #ifdef __frv__ #define __IEEE_BIG_ENDIAN #endif #ifdef __moxie__ #ifdef __MOXIE_BIG_ENDIAN__ #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #endif #ifdef __ia64__ #ifdef __BIG_ENDIAN__ #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #endif #ifdef __AVR__ #define __IEEE_LITTLE_ENDIAN #define _DOUBLE_IS_32BITS #endif #if defined(__or32__) || defined(__or1k__) || defined(__or16__) #define __IEEE_BIG_ENDIAN #endif #ifdef __IP2K__ #define __IEEE_BIG_ENDIAN #define __SMALL_BITFIELDS #define _DOUBLE_IS_32BITS #endif #ifdef __iq2000__ #define __IEEE_BIG_ENDIAN #endif #ifdef __MAVERICK__ #ifdef __ARMEL__ # define __IEEE_LITTLE_ENDIAN #else /* must be __ARMEB__ */ # define __IEEE_BIG_ENDIAN #endif /* __ARMEL__ */ #endif /* __MAVERICK__ */ #ifdef __m32c__ #define __IEEE_LITTLE_ENDIAN #define __SMALL_BITFIELDS #endif #ifdef __CRIS__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __BFIN__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __x86_64__ #define __IEEE_LITTLE_ENDIAN #endif #ifdef __mep__ #ifdef __LITTLE_ENDIAN__ #define __IEEE_LITTLE_ENDIAN #else #define __IEEE_BIG_ENDIAN #endif #endif #ifdef __MICROBLAZE__ #ifndef __MICROBLAZEEL__ #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #endif #ifdef __MSP430__ #define __IEEE_LITTLE_ENDIAN #define __SMALL_BITFIELDS /* 16 Bit INT */ #endif #ifdef __RL78__ #define __IEEE_LITTLE_ENDIAN #define __SMALL_BITFIELDS /* 16 Bit INT */ #ifndef __RL78_64BIT_DOUBLES__ #define _DOUBLE_IS_32BITS #endif #endif #ifdef __RX__ #ifdef __RX_BIG_ENDIAN__ #define __IEEE_BIG_ENDIAN #else #define __IEEE_LITTLE_ENDIAN #endif #ifndef __RX_64BIT_DOUBLES__ #define _DOUBLE_IS_32BITS #endif #ifdef __RX_16BIT_INTS__ #define __SMALL_BITFIELDS #endif #endif #if (defined(__CR16__) || defined(__CR16C__) ||defined(__CR16CP__)) #define __IEEE_LITTLE_ENDIAN #define __SMALL_BITFIELDS /* 16 Bit INT */ #endif #ifdef __NIOS2__ # ifdef __nios2_big_endian__ # define __IEEE_BIG_ENDIAN # else # define __IEEE_LITTLE_ENDIAN # endif #endif #ifndef __IEEE_BIG_ENDIAN #ifndef __IEEE_LITTLE_ENDIAN #error Endianess not declared!! #endif /* not __IEEE_LITTLE_ENDIAN */ #endif /* not __IEEE_BIG_ENDIAN */ #endif /* not __IEEE_LITTLE_ENDIAN */ #endif /* not __IEEE_BIG_ENDIAN */ 07070100000024000081a40000000000000000000000016181423c0000008a000000000000000000000000000000000000002a00000000./usr/nvptx-none/include/machine/malloc.h#ifndef _MACHMALLOC_H_ #define _MACHMALLOC_H_ /* place holder so platforms may add malloc.h extensions */ #endif /* _MACHMALLOC_H_ */ 07070100000025000081a40000000000000000000000016181423c00000032000000000000000000000000000000000000002900000000./usr/nvptx-none/include/machine/param.h/* Place holder for machine-specific param.h. */ 07070100000026000081a40000000000000000000000016181423c000003b3000000000000000000000000000000000000002d00000000./usr/nvptx-none/include/machine/setjmp-dj.h/* * Copyright (C) 1991 DJ Delorie * All rights reserved. * * Redistribution, modification, and use in source and binary forms is permitted * provided that the above copyright notice and following paragraph are * duplicated in all such forms. * * This file is distributed WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. */ /* Modified to use SETJMP_DJ_H rather than SETJMP_H to avoid conflicting with setjmp.h. Ian Taylor, Cygnus support, April, 1993. */ #ifndef _SETJMP_DJ_H_ #define _SETJMP_DJ_H_ #ifdef __cplusplus extern "C" { #endif typedef struct { unsigned long eax; unsigned long ebx; unsigned long ecx; unsigned long edx; unsigned long esi; unsigned long edi; unsigned long ebp; unsigned long esp; unsigned long eip; } jmp_buf[1]; extern int setjmp(jmp_buf); extern void longjmp(jmp_buf, int); #ifdef __cplusplus } #endif #endif 07070100000027000081a40000000000000000000000016181423c00001f7f000000000000000000000000000000000000002a00000000./usr/nvptx-none/include/machine/setjmp.h _BEGIN_STD_C #if defined(__arm__) || defined(__thumb__) /* * All callee preserved registers: * v1 - v7, fp, ip, sp, lr, f4, f5, f6, f7 */ #define _JBLEN 23 #endif #if defined(__aarch64__) #define _JBLEN 22 #define _JBTYPE long long #endif #if defined(__AVR__) #define _JBLEN 24 #endif #ifdef __sparc__ /* * onsstack,sigmask,sp,pc,npc,psr,g1,o0,wbcnt (sigcontext). * All else recovered by under/over(flow) handling. */ #define _JBLEN 13 #endif #ifdef __BFIN__ #define _JBLEN 40 #endif #ifdef __epiphany__ /* All callee preserved registers: r4-r10,fp, sp, lr,r15, r32-r39 */ #define _JBTYPE long long #define _JBLEN 10 #endif /* necv70 was 9 as well. */ #if defined(__m68k__) || defined(__mc68000__) /* * onsstack,sigmask,sp,pc,psl,d2-d7,a2-a6, * fp2-fp7 for 68881. * All else recovered by under/over(flow) handling. */ #define _JBLEN 34 #endif #if defined(__mc68hc11__) || defined(__mc68hc12__) || defined(__mc68hc1x__) /* * D, X, Y are not saved. * Only take into account the pseudo soft registers (max 32). */ #define _JBLEN 32 #endif #ifdef __nds32__ /* Only 17 words are currently needed. Preserve one word slot if we need to expand. Check newlib/libc/machine/nds32/setjmp.S for more information. */ #define _JBLEN 18 #endif #if defined(__Z8001__) || defined(__Z8002__) /* 16 regs + pc */ #define _JBLEN 20 #endif #ifdef _AM29K /* * onsstack,sigmask,sp,pc,npc,psr,g1,o0,wbcnt (sigcontext). * All else recovered by under/over(flow) handling. */ #define _JBLEN 9 #endif #ifdef __i386__ # if defined(__CYGWIN__) && !defined (_JBLEN) # define _JBLEN (13 * 4) # elif defined(__unix__) || defined(__rtems__) # define _JBLEN 9 # else # include "setjmp-dj.h" # endif #endif #ifdef __x86_64__ # ifdef __CYGWIN__ # define _JBTYPE long # define _JBLEN 32 # else # define _JBTYPE long long # define _JBLEN 8 # endif #endif #ifdef __i960__ #define _JBLEN 35 #endif #ifdef __M32R__ /* Only 8 words are currently needed. 10 gives us some slop if we need to expand. */ #define _JBLEN 10 #endif #ifdef __mips__ # if defined(__mips64) || (__mips_fpr == 64) # define _JBTYPE long long # endif # ifdef __mips_soft_float # define _JBLEN 11 # else # define _JBLEN 23 # endif #endif #ifdef __m88000__ #define _JBLEN 21 #endif #ifdef __H8300__ #define _JBLEN 5 #define _JBTYPE int #endif #ifdef __H8300H__ /* same as H8/300 but registers are twice as big */ #define _JBLEN 5 #define _JBTYPE long #endif #if defined (__H8300S__) || defined (__H8300SX__) /* same as H8/300 but registers are twice as big */ #define _JBLEN 5 #define _JBTYPE long #endif #ifdef __H8500__ #define _JBLEN 4 #endif #ifdef __sh__ #if __SH5__ #define _JBLEN 50 #define _JBTYPE long long #else #define _JBLEN 20 #endif /* __SH5__ */ #endif #ifdef __v800 #define _JBLEN 28 #endif #ifdef __PPC__ #ifdef __ALTIVEC__ #define _JBLEN 64 #else #define _JBLEN 32 #endif #define _JBTYPE double #endif #ifdef __MICROBLAZE__ #define _JBLEN 20 #define _JBTYPE unsigned int #endif #ifdef __hppa__ /* %r30, %r2-%r18, %r27, pad, %fr12-%fr15. Note space exists for the FP registers, but they are not saved. */ #define _JBLEN 28 #endif #if defined(__mn10300__) || defined(__mn10200__) #ifdef __AM33_2__ #define _JBLEN 26 #else /* A guess */ #define _JBLEN 10 #endif #endif #ifdef __v850 /* I think our setjmp is saving 15 regs at the moment. Gives us one word slop if we need to expand. */ #define _JBLEN 16 #endif #if defined(_C4x) #define _JBLEN 10 #endif #if defined(_C3x) #define _JBLEN 9 #endif #ifdef __TMS320C6X__ #define _JBLEN 13 #endif #ifdef __TIC80__ #define _JBLEN 13 #endif #ifdef __D10V__ #define _JBLEN 8 #endif #ifdef __D30V__ #define _JBLEN ((64 /* GPR */ + (2*2) /* ACs */ + 18 /* CRs */) / 2) #define _JBTYPE double #endif #ifdef __frv__ #define _JBLEN (68/2) /* room for 68 32-bit regs */ #define _JBTYPE double #endif #ifdef __moxie__ #define _JBLEN 16 #endif #ifdef __CRX__ #define _JBLEN 9 #endif #if (defined(__CR16__) || defined(__CR16C__) ||defined(__CR16CP__)) /* r6, r7, r8, r9, r10, r11, r12 (r12L, r12H), * r13 (r13L, r13H), ra(raL, raH), sp(spL, spH) */ #define _JBLEN 14 #define _JBTYPE unsigned short #endif #ifdef __fr30__ #define _JBLEN 10 #endif #ifdef __iq2000__ #define _JBLEN 32 #endif #ifdef __mcore__ #define _JBLEN 16 #endif #ifdef __MMIX__ /* Using a layout compatible with GCC's built-in. */ #define _JBLEN 5 #define _JBTYPE unsigned long #endif #ifdef __mt__ #define _JBLEN 16 #endif #ifdef __SPU__ #define _JBLEN 50 #define _JBTYPE __vector signed int #endif #ifdef __xstormy16__ /* 4 GPRs plus SP plus PC. */ #define _JBLEN 8 #endif #ifdef __mep__ /* 16 GPRs, pc, hi, lo */ #define _JBLEN 19 #endif #ifdef __CRIS__ #define _JBLEN 18 #endif #ifdef __lm32__ #define _JBLEN 19 #endif #ifdef __m32c__ #if defined(__r8c_cpu__) || defined(__m16c_cpu__) #define _JBLEN (22/2) #else #define _JBLEN (34/2) #endif #define _JBTYPE unsigned short #endif /* __m32c__ */ #ifdef __MSP430__ #define _JBLEN 9 #ifdef __MSP430X_LARGE__ #define _JBTYPE unsigned long #else #define _JBTYPE unsigned short #endif #endif #ifdef __RL78__ /* Three banks of registers, SP, CS, ES, PC */ #define _JBLEN (8*3+8) #define _JBTYPE unsigned char #endif /* * There are two versions of setjmp()/longjmp(): * 1) Compiler (gcc) built-in versions. * 2) Function-call versions. * * The built-in versions are used most of the time. When used, gcc replaces * calls to setjmp()/longjmp() with inline assembly code. The built-in * versions save/restore a variable number of registers. * _JBLEN is set to 40 to be ultra-safe with the built-in versions. * It only needs to be 12 for the function-call versions * but this data structure is used by both versions. */ #ifdef __NIOS2__ #define _JBLEN 40 #define _JBTYPE unsigned long #endif #ifdef __RX__ #define _JBLEN 0x44 #endif #ifdef _JBLEN #ifdef _JBTYPE typedef _JBTYPE jmp_buf[_JBLEN]; #else typedef int jmp_buf[_JBLEN]; #endif #endif _END_STD_C #if defined(__CYGWIN__) || defined(__rtems__) #include #ifdef __cplusplus extern "C" { #endif /* POSIX sigsetjmp/siglongjmp macros */ #ifdef _JBTYPE typedef _JBTYPE sigjmp_buf[_JBLEN+1+((sizeof (_JBTYPE) + sizeof (sigset_t) - 1) /sizeof (_JBTYPE))]; #else typedef int sigjmp_buf[_JBLEN+1+(sizeof (sigset_t)/sizeof (int))]; #endif #define _SAVEMASK _JBLEN #define _SIGMASK (_JBLEN+1) #ifdef __CYGWIN__ # define _CYGWIN_WORKING_SIGSETJMP #endif #ifdef _POSIX_THREADS #define __SIGMASK_FUNC pthread_sigmask #else #define __SIGMASK_FUNC sigprocmask #endif #if defined(__GNUC__) #define sigsetjmp(env, savemask) \ __extension__ \ ({ \ sigjmp_buf *_sjbuf = &(env); \ ((*_sjbuf)[_SAVEMASK] = savemask,\ __SIGMASK_FUNC (SIG_SETMASK, 0, (sigset_t *)((*_sjbuf) + _SIGMASK)),\ setjmp (*_sjbuf)); \ }) #define siglongjmp(env, val) \ __extension__ \ ({ \ sigjmp_buf *_sjbuf = &(env); \ ((((*_sjbuf)[_SAVEMASK]) ? \ __SIGMASK_FUNC (SIG_SETMASK, (sigset_t *)((*_sjbuf) + _SIGMASK), 0)\ : 0), \ longjmp (*_sjbuf, val)); \ }) #else /* !__GNUC__ */ #define sigsetjmp(env, savemask) ((env)[_SAVEMASK] = savemask,\ __SIGMASK_FUNC (SIG_SETMASK, 0, (sigset_t *) ((env) + _SIGMASK)),\ setjmp (env)) #define siglongjmp(env, val) ((((env)[_SAVEMASK])?\ __SIGMASK_FUNC (SIG_SETMASK, (sigset_t *) ((env) + _SIGMASK), 0):0),\ longjmp (env, val)) #endif /* POSIX _setjmp/_longjmp, maintained for XSI compatibility. These are equivalent to sigsetjmp/siglongjmp when not saving the signal mask. New applications should use sigsetjmp/siglongjmp instead. */ #ifdef __CYGWIN__ extern void _longjmp(jmp_buf, int); extern int _setjmp(jmp_buf); #else #define _setjmp(env) sigsetjmp ((env), 0) #define _longjmp(env, val) siglongjmp ((env), (val)) #endif #ifdef __cplusplus } #endif #endif /* __CYGWIN__ or __rtems__ */ 07070100000028000081a40000000000000000000000016181423c0000008a000000000000000000000000000000000000002a00000000./usr/nvptx-none/include/machine/stdlib.h#ifndef _MACHSTDLIB_H_ #define _MACHSTDLIB_H_ /* place holder so platforms may add stdlib.h extensions */ #endif /* _MACHSTDLIB_H_ */ 07070100000029000081a40000000000000000000000016181423c0000001d000000000000000000000000000000000000002b00000000./usr/nvptx-none/include/machine/termios.h#define __MAX_BAUD B4000000 0707010000002a000081a40000000000000000000000016181423c0000018f000000000000000000000000000000000000002800000000./usr/nvptx-none/include/machine/time.h#ifndef _MACHTIME_H_ #define _MACHTIME_H_ #if defined(__rtems__) #define _CLOCKS_PER_SEC_ sysconf(_SC_CLK_TCK) #else /* !__rtems__ */ #if defined(__aarch64__) || defined(__arm__) || defined(__thumb__) #define _CLOCKS_PER_SEC_ 100 #endif #endif /* !__rtems__ */ #ifdef __SPU__ #include int nanosleep (const struct timespec *, struct timespec *); #endif #endif /* _MACHTIME_H_ */ 0707010000002b000081a40000000000000000000000016181423c0000029b000000000000000000000000000000000000002900000000./usr/nvptx-none/include/machine/types.h#ifndef _MACHTYPES_H_ #define _MACHTYPES_H_ /* * The following section is RTEMS specific and is needed to more * closely match the types defined in the BSD machine/types.h. * This is needed to let the RTEMS/BSD TCP/IP stack compile. */ #if defined(__rtems__) #include #endif #define _CLOCK_T_ unsigned long /* clock() */ #define _TIME_T_ long /* time() */ #define _CLOCKID_T_ unsigned long #define _TIMER_T_ unsigned long #ifndef _HAVE_SYSTYPES typedef long int __off_t; typedef int __pid_t; #ifdef __GNUC__ __extension__ typedef long long int __loff_t; #else typedef long int __loff_t; #endif #endif #endif /* _MACHTYPES_H_ */ 0707010000002c000081a40000000000000000000000016181423c000010e2000000000000000000000000000000000000002200000000./usr/nvptx-none/include/malloc.h/* malloc.h -- header file for memory routines. */ #ifndef _INCLUDE_MALLOC_H_ #define _INCLUDE_MALLOC_H_ #include <_ansi.h> #include #define __need_size_t #include /* include any machine-specific extensions */ #include #ifdef __cplusplus extern "C" { #endif /* This version of struct mallinfo must match the one in libc/stdlib/mallocr.c. */ struct mallinfo { size_t arena; /* total space allocated from system */ size_t ordblks; /* number of non-inuse chunks */ size_t smblks; /* unused -- always zero */ size_t hblks; /* number of mmapped regions */ size_t hblkhd; /* total space in mmapped regions */ size_t usmblks; /* unused -- always zero */ size_t fsmblks; /* unused -- always zero */ size_t uordblks; /* total allocated space */ size_t fordblks; /* total non-inuse space */ size_t keepcost; /* top-most, releasable (via malloc_trim) space */ }; /* The routines. */ extern _PTR malloc _PARAMS ((size_t)); #ifdef __CYGWIN__ #undef _malloc_r #define _malloc_r(r, s) malloc (s) #else extern _PTR _malloc_r _PARAMS ((struct _reent *, size_t)); #endif extern _VOID free _PARAMS ((_PTR)); #ifdef __CYGWIN__ #undef _free_r #define _free_r(r, p) free (p) #else extern _VOID _free_r _PARAMS ((struct _reent *, _PTR)); #endif extern _PTR realloc _PARAMS ((_PTR, size_t)); #ifdef __CYGWIN__ #undef _realloc_r #define _realloc_r(r, p, s) realloc (p, s) #else extern _PTR _realloc_r _PARAMS ((struct _reent *, _PTR, size_t)); #endif extern _PTR calloc _PARAMS ((size_t, size_t)); #ifdef __CYGWIN__ #undef _calloc_r #define _calloc_r(r, s1, s2) calloc (s1, s2); #else extern _PTR _calloc_r _PARAMS ((struct _reent *, size_t, size_t)); #endif extern _PTR memalign _PARAMS ((size_t, size_t)); #ifdef __CYGWIN__ #undef _memalign_r #define _memalign_r(r, s1, s2) memalign (s1, s2); #else extern _PTR _memalign_r _PARAMS ((struct _reent *, size_t, size_t)); #endif extern struct mallinfo mallinfo _PARAMS ((void)); #ifdef __CYGWIN__ #undef _mallinfo_r #define _mallinfo_r(r) mallinfo () #else extern struct mallinfo _mallinfo_r _PARAMS ((struct _reent *)); #endif extern void malloc_stats _PARAMS ((void)); #ifdef __CYGWIN__ #undef _malloc_stats_r #define _malloc_stats_r(r) malloc_stats () #else extern void _malloc_stats_r _PARAMS ((struct _reent *)); #endif extern int mallopt _PARAMS ((int, int)); #ifdef __CYGWIN__ #undef _mallopt_r #define _mallopt_r(i1, i2) mallopt (i1, i2) #else extern int _mallopt_r _PARAMS ((struct _reent *, int, int)); #endif extern size_t malloc_usable_size _PARAMS ((_PTR)); #ifdef __CYGWIN__ #undef _malloc_usable_size_r #define _malloc_usable_size_r(r, p) malloc_usable_size (p) #else extern size_t _malloc_usable_size_r _PARAMS ((struct _reent *, _PTR)); #endif /* These aren't too useful on an embedded system, but we define them anyhow. */ extern _PTR valloc _PARAMS ((size_t)); #ifdef __CYGWIN__ #undef _valloc_r #define _valloc_r(r, s) valloc (s) #else extern _PTR _valloc_r _PARAMS ((struct _reent *, size_t)); #endif extern _PTR pvalloc _PARAMS ((size_t)); #ifdef __CYGWIN__ #undef _pvalloc_r #define _pvalloc_r(r, s) pvalloc (s) #else extern _PTR _pvalloc_r _PARAMS ((struct _reent *, size_t)); #endif extern int malloc_trim _PARAMS ((size_t)); #ifdef __CYGWIN__ #undef _malloc_trim_r #define _malloc_trim_r(r, s) malloc_trim (s) #else extern int _malloc_trim_r _PARAMS ((struct _reent *, size_t)); #endif /* A compatibility routine for an earlier version of the allocator. */ extern _VOID mstats _PARAMS ((char *)); #ifdef __CYGWIN__ #undef _mstats_r #define _mstats_r(r, p) mstats (p) #else extern _VOID _mstats_r _PARAMS ((struct _reent *, char *)); #endif /* SVID2/XPG mallopt options */ #define M_MXFAST 1 /* UNUSED in this malloc */ #define M_NLBLKS 2 /* UNUSED in this malloc */ #define M_GRAIN 3 /* UNUSED in this malloc */ #define M_KEEP 4 /* UNUSED in this malloc */ /* mallopt options that actually do something */ #define M_TRIM_THRESHOLD -1 #define M_TOP_PAD -2 #define M_MMAP_THRESHOLD -3 #define M_MMAP_MAX -4 #ifndef __CYGWIN__ /* Some systems provide this, so do too for compatibility. */ extern void cfree _PARAMS ((_PTR)); #endif /* __CYGWIN__ */ #ifdef __cplusplus } #endif #endif /* _INCLUDE_MALLOC_H_ */ 0707010000002d000081a40000000000000000000000016181423c00004c27000000000000000000000000000000000000002000000000./usr/nvptx-none/include/math.h#ifndef _MATH_H_ #define _MATH_H_ #include #include #include "_ansi.h" _BEGIN_STD_C /* __dmath, __fmath, and __ldmath are only here for backwards compatibility * in case any code used them. They are no longer used by Newlib, itself, * other than legacy. */ union __dmath { double d; __ULong i[2]; }; union __fmath { float f; __ULong i[1]; }; #if defined(_HAVE_LONG_DOUBLE) union __ldmath { long double ld; __ULong i[4]; }; #endif /* Natural log of 2 */ #define _M_LN2 0.693147180559945309417 #if __GNUC_PREREQ (3, 3) /* gcc >= 3.3 implicitly defines builtins for HUGE_VALx values. */ # ifndef HUGE_VAL # define HUGE_VAL (__builtin_huge_val()) # endif # ifndef HUGE_VALF # define HUGE_VALF (__builtin_huge_valf()) # endif # ifndef HUGE_VALL # define HUGE_VALL (__builtin_huge_vall()) # endif # ifndef INFINITY # define INFINITY (__builtin_inff()) # endif # ifndef NAN # define NAN (__builtin_nanf("")) # endif #else /* !gcc >= 3.3 */ /* No builtins. Use fixed defines instead. (All 3 HUGE plus the INFINITY * and NAN macros are required to be constant expressions. Using a variable-- * even a static const--does not meet this requirement, as it cannot be * evaluated at translation time.) * The infinities are done using numbers that are far in excess of * something that would be expected to be encountered in a floating-point * implementation. (A more certain way uses values from float.h, but that is * avoided because system includes are not supposed to include each other.) * This method might produce warnings from some compilers. (It does in * newer GCCs, but not for ones that would hit this #else.) If this happens, * please report details to the Newlib mailing list. */ #ifndef HUGE_VAL #define HUGE_VAL (1.0e999999999) #endif #ifndef HUGE_VALF #define HUGE_VALF (1.0e999999999F) #endif #if !defined(HUGE_VALL) && defined(_HAVE_LONG_DOUBLE) #define HUGE_VALL (1.0e999999999L) #endif #if !defined(INFINITY) #define INFINITY (HUGE_VALF) #endif #if !defined(NAN) #if defined(__GNUC__) && defined(__cplusplus) /* Exception: older g++ versions warn about the divide by 0 used in the * normal case (even though older gccs do not). This trick suppresses the * warning, but causes errors for plain gcc, so is only used in the one * special case. */ static const union { __ULong __i[1]; float __d; } __Nanf = {0x7FC00000}; #define NAN (__Nanf.__d) #else #define NAN (0.0F/0.0F) #endif #endif #endif /* !gcc >= 3.3 */ /* Reentrant ANSI C functions. */ #ifndef __math_68881 extern double atan _PARAMS((double)); extern double cos _PARAMS((double)); extern double sin _PARAMS((double)); extern double tan _PARAMS((double)); extern double tanh _PARAMS((double)); extern double frexp _PARAMS((double, int *)); extern double modf _PARAMS((double, double *)); extern double ceil _PARAMS((double)); extern double fabs _PARAMS((double)); extern double floor _PARAMS((double)); #endif /* ! defined (__math_68881) */ /* Non reentrant ANSI C functions. */ #ifndef _REENT_ONLY #ifndef __math_68881 extern double acos _PARAMS((double)); extern double asin _PARAMS((double)); extern double atan2 _PARAMS((double, double)); extern double cosh _PARAMS((double)); extern double sinh _PARAMS((double)); extern double exp _PARAMS((double)); extern double ldexp _PARAMS((double, int)); extern double log _PARAMS((double)); extern double log10 _PARAMS((double)); extern double pow _PARAMS((double, double)); extern double sqrt _PARAMS((double)); extern double fmod _PARAMS((double, double)); #endif /* ! defined (__math_68881) */ #endif /* ! defined (_REENT_ONLY) */ #if !defined(__STRICT_ANSI__) || defined(__cplusplus) || __STDC_VERSION__ >= 199901L /* ISO C99 types and macros. */ /* FIXME: FLT_EVAL_METHOD should somehow be gotten from float.h (which is hard, * considering that the standard says the includes it defines should not * include other includes that it defines) and that value used. (This can be * solved, but autoconf has a bug which makes the solution more difficult, so * it has been skipped for now.) */ #if !defined(FLT_EVAL_METHOD) && defined(__FLT_EVAL_METHOD__) #define FLT_EVAL_METHOD __FLT_EVAL_METHOD__ #define __TMP_FLT_EVAL_METHOD #endif /* FLT_EVAL_METHOD */ #if defined FLT_EVAL_METHOD #if FLT_EVAL_METHOD == 0 typedef float float_t; typedef double double_t; #elif FLT_EVAL_METHOD == 1 typedef double float_t; typedef double double_t; #elif FLT_EVAL_METHOD == 2 typedef long double float_t; typedef long double double_t; #else /* Implementation-defined. Assume float_t and double_t have been * defined previously for this configuration (e.g. config.h). */ #endif #else /* Assume basic definitions. */ typedef float float_t; typedef double double_t; #endif #if defined(__TMP_FLT_EVAL_METHOD) #undef FLT_EVAL_METHOD #endif #define FP_NAN 0 #define FP_INFINITE 1 #define FP_ZERO 2 #define FP_SUBNORMAL 3 #define FP_NORMAL 4 #ifndef FP_ILOGB0 # define FP_ILOGB0 (-INT_MAX) #endif #ifndef FP_ILOGBNAN # define FP_ILOGBNAN INT_MAX #endif #ifndef MATH_ERRNO # define MATH_ERRNO 1 #endif #ifndef MATH_ERREXCEPT # define MATH_ERREXCEPT 2 #endif #ifndef math_errhandling # define math_errhandling MATH_ERRNO #endif extern int __isinff (float x); extern int __isinfd (double x); extern int __isnanf (float x); extern int __isnand (double x); extern int __fpclassifyf (float x); extern int __fpclassifyd (double x); extern int __signbitf (float x); extern int __signbitd (double x); #define fpclassify(__x) \ ((sizeof(__x) == sizeof(float)) ? __fpclassifyf(__x) : \ __fpclassifyd(__x)) #ifndef isfinite #define isfinite(__y) \ (__extension__ ({int __cy = fpclassify(__y); \ __cy != FP_INFINITE && __cy != FP_NAN;})) #endif /* Note: isinf and isnan were once functions in newlib that took double * arguments. C99 specifies that these names are reserved for macros * supporting multiple floating point types. Thus, they are * now defined as macros. Implementations of the old functions * taking double arguments still exist for compatibility purposes * (prototypes for them are in ). */ #ifndef isinf #define isinf(y) (fpclassify(y) == FP_INFINITE) #endif #ifndef isnan #define isnan(y) (fpclassify(y) == FP_NAN) #endif #define isnormal(y) (fpclassify(y) == FP_NORMAL) #define signbit(__x) \ ((sizeof(__x) == sizeof(float)) ? __signbitf(__x) : \ __signbitd(__x)) #define isgreater(x,y) \ (__extension__ ({__typeof__(x) __x = (x); __typeof__(y) __y = (y); \ !isunordered(__x,__y) && (__x > __y);})) #define isgreaterequal(x,y) \ (__extension__ ({__typeof__(x) __x = (x); __typeof__(y) __y = (y); \ !isunordered(__x,__y) && (__x >= __y);})) #define isless(x,y) \ (__extension__ ({__typeof__(x) __x = (x); __typeof__(y) __y = (y); \ !isunordered(__x,__y) && (__x < __y);})) #define islessequal(x,y) \ (__extension__ ({__typeof__(x) __x = (x); __typeof__(y) __y = (y); \ !isunordered(__x,__y) && (__x <= __y);})) #define islessgreater(x,y) \ (__extension__ ({__typeof__(x) __x = (x); __typeof__(y) __y = (y); \ !isunordered(__x,__y) && (__x < __y || __x > __y);})) #define isunordered(a,b) \ (__extension__ ({__typeof__(a) __a = (a); __typeof__(b) __b = (b); \ fpclassify(__a) == FP_NAN || fpclassify(__b) == FP_NAN;})) /* Non ANSI double precision functions. */ extern double infinity _PARAMS((void)); extern double nan _PARAMS((const char *)); extern int finite _PARAMS((double)); extern double copysign _PARAMS((double, double)); extern double logb _PARAMS((double)); extern int ilogb _PARAMS((double)); extern double asinh _PARAMS((double)); extern double cbrt _PARAMS((double)); extern double nextafter _PARAMS((double, double)); extern double rint _PARAMS((double)); extern double scalbn _PARAMS((double, int)); extern double exp2 _PARAMS((double)); extern double scalbln _PARAMS((double, long int)); extern double tgamma _PARAMS((double)); extern double nearbyint _PARAMS((double)); extern long int lrint _PARAMS((double)); extern _LONG_LONG_TYPE int llrint _PARAMS((double)); extern double round _PARAMS((double)); extern long int lround _PARAMS((double)); extern long long int llround _PARAMS((double)); extern double trunc _PARAMS((double)); extern double remquo _PARAMS((double, double, int *)); extern double fdim _PARAMS((double, double)); extern double fmax _PARAMS((double, double)); extern double fmin _PARAMS((double, double)); extern double fma _PARAMS((double, double, double)); #ifndef __math_68881 extern double log1p _PARAMS((double)); extern double expm1 _PARAMS((double)); #endif /* ! defined (__math_68881) */ #ifndef _REENT_ONLY extern double acosh _PARAMS((double)); extern double atanh _PARAMS((double)); extern double remainder _PARAMS((double, double)); extern double gamma _PARAMS((double)); extern double lgamma _PARAMS((double)); extern double erf _PARAMS((double)); extern double erfc _PARAMS((double)); extern double log2 _PARAMS((double)); #if !defined(__cplusplus) #define log2(x) (log (x) / _M_LN2) #endif #ifndef __math_68881 extern double hypot _PARAMS((double, double)); #endif #endif /* ! defined (_REENT_ONLY) */ /* Single precision versions of ANSI functions. */ extern float atanf _PARAMS((float)); extern float cosf _PARAMS((float)); extern float sinf _PARAMS((float)); extern float tanf _PARAMS((float)); extern float tanhf _PARAMS((float)); extern float frexpf _PARAMS((float, int *)); extern float modff _PARAMS((float, float *)); extern float ceilf _PARAMS((float)); extern float fabsf _PARAMS((float)); extern float floorf _PARAMS((float)); #ifndef _REENT_ONLY extern float acosf _PARAMS((float)); extern float asinf _PARAMS((float)); extern float atan2f _PARAMS((float, float)); extern float coshf _PARAMS((float)); extern float sinhf _PARAMS((float)); extern float expf _PARAMS((float)); extern float ldexpf _PARAMS((float, int)); extern float logf _PARAMS((float)); extern float log10f _PARAMS((float)); extern float powf _PARAMS((float, float)); extern float sqrtf _PARAMS((float)); extern float fmodf _PARAMS((float, float)); #endif /* ! defined (_REENT_ONLY) */ /* Other single precision functions. */ extern float exp2f _PARAMS((float)); extern float scalblnf _PARAMS((float, long int)); extern float tgammaf _PARAMS((float)); extern float nearbyintf _PARAMS((float)); extern long int lrintf _PARAMS((float)); extern _LONG_LONG_TYPE llrintf _PARAMS((float)); extern float roundf _PARAMS((float)); extern long int lroundf _PARAMS((float)); extern long long int llroundf _PARAMS((float)); extern float truncf _PARAMS((float)); extern float remquof _PARAMS((float, float, int *)); extern float fdimf _PARAMS((float, float)); extern float fmaxf _PARAMS((float, float)); extern float fminf _PARAMS((float, float)); extern float fmaf _PARAMS((float, float, float)); extern float infinityf _PARAMS((void)); extern float nanf _PARAMS((const char *)); extern int finitef _PARAMS((float)); extern float copysignf _PARAMS((float, float)); extern float logbf _PARAMS((float)); extern int ilogbf _PARAMS((float)); extern float asinhf _PARAMS((float)); extern float cbrtf _PARAMS((float)); extern float nextafterf _PARAMS((float, float)); extern float rintf _PARAMS((float)); extern float scalbnf _PARAMS((float, int)); extern float log1pf _PARAMS((float)); extern float expm1f _PARAMS((float)); #ifndef _REENT_ONLY extern float acoshf _PARAMS((float)); extern float atanhf _PARAMS((float)); extern float remainderf _PARAMS((float, float)); extern float gammaf _PARAMS((float)); extern float lgammaf _PARAMS((float)); extern float erff _PARAMS((float)); extern float erfcf _PARAMS((float)); extern float log2f _PARAMS((float)); extern float hypotf _PARAMS((float, float)); #endif /* ! defined (_REENT_ONLY) */ /* On platforms where long double equals double. */ #ifdef _LDBL_EQ_DBL /* Reentrant ANSI C functions. */ #ifndef __math_68881 extern long double atanl _PARAMS((long double)); extern long double cosl _PARAMS((long double)); extern long double sinl _PARAMS((long double)); extern long double tanl _PARAMS((long double)); extern long double tanhl _PARAMS((long double)); extern long double frexpl _PARAMS((long double value, int *)); extern long double modfl _PARAMS((long double, long double *)); extern long double ceill _PARAMS((long double)); extern long double fabsl _PARAMS((long double)); extern long double floorl _PARAMS((long double)); extern long double log1pl _PARAMS((long double)); extern long double expm1l _PARAMS((long double)); #endif /* ! defined (__math_68881) */ /* Non reentrant ANSI C functions. */ #ifndef _REENT_ONLY #ifndef __math_68881 extern long double acosl _PARAMS((long double)); extern long double asinl _PARAMS((long double)); extern long double atan2l _PARAMS((long double, long double)); extern long double coshl _PARAMS((long double)); extern long double sinhl _PARAMS((long double)); extern long double expl _PARAMS((long double)); extern long double ldexpl _PARAMS((long double, int)); extern long double logl _PARAMS((long double)); extern long double log10l _PARAMS((long double)); extern long double powl _PARAMS((long double, long double)); extern long double sqrtl _PARAMS((long double)); extern long double fmodl _PARAMS((long double, long double)); extern long double hypotl _PARAMS((long double, long double)); #endif /* ! defined (__math_68881) */ #endif /* ! defined (_REENT_ONLY) */ extern long double copysignl _PARAMS((long double, long double)); extern long double nanl _PARAMS((const char *)); extern int ilogbl _PARAMS((long double)); extern long double asinhl _PARAMS((long double)); extern long double cbrtl _PARAMS((long double)); extern long double nextafterl _PARAMS((long double, long double)); extern long double rintl _PARAMS((long double)); extern long double scalbnl _PARAMS((long double, int)); extern long double exp2l _PARAMS((long double)); extern long double scalblnl _PARAMS((long double, long)); extern long double tgammal _PARAMS((long double)); extern long double nearbyintl _PARAMS((long double)); extern long int lrintl _PARAMS((long double)); extern long long int llrintl _PARAMS((long double)); extern long double roundl _PARAMS((long double)); extern long lroundl _PARAMS((long double)); extern _LONG_LONG_TYPE int llroundl _PARAMS((long double)); extern long double truncl _PARAMS((long double)); extern long double remquol _PARAMS((long double, long double, int *)); extern long double fdiml _PARAMS((long double, long double)); extern long double fmaxl _PARAMS((long double, long double)); extern long double fminl _PARAMS((long double, long double)); extern long double fmal _PARAMS((long double, long double, long double)); #ifndef _REENT_ONLY extern long double acoshl _PARAMS((long double)); extern long double atanhl _PARAMS((long double)); extern long double remainderl _PARAMS((long double, long double)); extern long double lgammal _PARAMS((long double)); extern long double erfl _PARAMS((long double)); extern long double erfcl _PARAMS((long double)); #endif /* ! defined (_REENT_ONLY) */ #else /* !_LDBL_EQ_DBL */ #ifdef __i386__ /* Other long double precision functions. */ extern _LONG_DOUBLE rintl _PARAMS((_LONG_DOUBLE)); extern long int lrintl _PARAMS((_LONG_DOUBLE)); extern _LONG_LONG_TYPE llrintl _PARAMS((_LONG_DOUBLE)); #endif /* __i386__ */ #endif /* !_LDBL_EQ_DBL */ #endif /* !defined (__STRICT_ANSI__) || defined(__cplusplus) || __STDC_VERSION__ >= 199901L */ #if !defined (__STRICT_ANSI__) || defined(__cplusplus) extern double drem _PARAMS((double, double)); extern void sincos _PARAMS((double, double *, double *)); extern double gamma_r _PARAMS((double, int *)); extern double lgamma_r _PARAMS((double, int *)); extern double y0 _PARAMS((double)); extern double y1 _PARAMS((double)); extern double yn _PARAMS((int, double)); extern double j0 _PARAMS((double)); extern double j1 _PARAMS((double)); extern double jn _PARAMS((int, double)); extern float dremf _PARAMS((float, float)); extern void sincosf _PARAMS((float, float *, float *)); extern float gammaf_r _PARAMS((float, int *)); extern float lgammaf_r _PARAMS((float, int *)); extern float y0f _PARAMS((float)); extern float y1f _PARAMS((float)); extern float ynf _PARAMS((int, float)); extern float j0f _PARAMS((float)); extern float j1f _PARAMS((float)); extern float jnf _PARAMS((int, float)); /* GNU extensions */ # ifndef exp10 extern double exp10 _PARAMS((double)); # endif # ifndef pow10 extern double pow10 _PARAMS((double)); # endif # ifndef exp10f extern float exp10f _PARAMS((float)); # endif # ifndef pow10f extern float pow10f _PARAMS((float)); # endif #endif /* !defined (__STRICT_ANSI__) || defined(__cplusplus) */ #ifndef __STRICT_ANSI__ /* The gamma functions use a global variable, signgam. */ #ifndef _REENT_ONLY #define signgam (*__signgam()) extern int *__signgam _PARAMS((void)); #endif /* ! defined (_REENT_ONLY) */ #define __signgam_r(ptr) _REENT_SIGNGAM(ptr) /* The exception structure passed to the matherr routine. */ /* We have a problem when using C++ since `exception' is a reserved name in C++. */ #ifdef __cplusplus struct __exception #else struct exception #endif { int type; char *name; double arg1; double arg2; double retval; int err; }; #ifdef __cplusplus extern int matherr _PARAMS((struct __exception *e)); #else extern int matherr _PARAMS((struct exception *e)); #endif /* Values for the type field of struct exception. */ #define DOMAIN 1 #define SING 2 #define OVERFLOW 3 #define UNDERFLOW 4 #define TLOSS 5 #define PLOSS 6 /* Useful constants. */ #define MAXFLOAT 3.40282347e+38F #define M_E 2.7182818284590452354 #define M_LOG2E 1.4426950408889634074 #define M_LOG10E 0.43429448190325182765 #define M_LN2 _M_LN2 #define M_LN10 2.30258509299404568402 #define M_PI 3.14159265358979323846 #define M_TWOPI (M_PI * 2.0) #define M_PI_2 1.57079632679489661923 #define M_PI_4 0.78539816339744830962 #define M_3PI_4 2.3561944901923448370E0 #define M_SQRTPI 1.77245385090551602792981 #define M_1_PI 0.31830988618379067154 #define M_2_PI 0.63661977236758134308 #define M_2_SQRTPI 1.12837916709551257390 #define M_SQRT2 1.41421356237309504880 #define M_SQRT1_2 0.70710678118654752440 #define M_LN2LO 1.9082149292705877000E-10 #define M_LN2HI 6.9314718036912381649E-1 #define M_SQRT3 1.73205080756887719000 #define M_IVLN10 0.43429448190325182765 /* 1 / log(10) */ #define M_LOG2_E _M_LN2 #define M_INVLN2 1.4426950408889633870E0 /* 1 / log(2) */ /* Global control over fdlibm error handling. */ enum __fdlibm_version { __fdlibm_ieee = -1, __fdlibm_svid, __fdlibm_xopen, __fdlibm_posix }; #define _LIB_VERSION_TYPE enum __fdlibm_version #define _LIB_VERSION __fdlib_version extern __IMPORT _LIB_VERSION_TYPE _LIB_VERSION; #define _IEEE_ __fdlibm_ieee #define _SVID_ __fdlibm_svid #define _XOPEN_ __fdlibm_xopen #define _POSIX_ __fdlibm_posix #endif /* ! defined (__STRICT_ANSI__) */ _END_STD_C #ifdef __FAST_MATH__ #include #endif #endif /* _MATH_H_ */ 0707010000002e000081a40000000000000000000000016181423c00001a77000000000000000000000000000000000000002200000000./usr/nvptx-none/include/newlib.h/* newlib.h. Generated from newlib.hin by configure. */ /* newlib.hin. Manually edited from the output of autoheader to remove all PACKAGE_ macros which will collide with any user package using newlib header files and having its own package name, version, etc... */ #ifndef __NEWLIB_H__ #define __NEWLIB_H__ 1 /* EL/IX level */ /* #undef _ELIX_LEVEL */ /* Newlib version */ #define _NEWLIB_VERSION "2.1.0" /* C99 formats support (such as %a, %zu, ...) in IO functions like * printf/scanf enabled */ /* #undef _WANT_IO_C99_FORMATS */ /* long long type support in IO functions like printf/scanf enabled */ #define _WANT_IO_LONG_LONG 1 /* Register application finalization function using atexit. */ /* #undef _WANT_REGISTER_FINI */ /* long double type support in IO functions like printf/scanf enabled */ /* #undef _WANT_IO_LONG_DOUBLE */ /* Positional argument support in printf functions enabled. */ /* #undef _WANT_IO_POS_ARGS */ /* Optional reentrant struct support. Used mostly on platforms with very restricted storage. */ /* #undef _WANT_REENT_SMALL */ /* Multibyte supported */ /* #undef _MB_CAPABLE */ /* MB_LEN_MAX */ #define _MB_LEN_MAX 1 /* ICONV enabled */ /* #undef _ICONV_ENABLED */ /* Enable ICONV external CCS files loading capabilities */ /* #undef _ICONV_ENABLE_EXTERNAL_CCS */ /* Define if the linker supports .preinit_array/.init_array/.fini_array * sections. */ /* #undef HAVE_INITFINI_ARRAY */ /* True if atexit() may dynamically allocate space for cleanup functions. */ #define _ATEXIT_DYNAMIC_ALLOC 1 /* True if long double supported. */ #define _HAVE_LONG_DOUBLE 1 /* Define if compiler supports -fno-tree-loop-distribute-patterns. */ #define _HAVE_CC_INHIBIT_LOOP_TO_LIBCALL 1 /* True if long double supported and it is equal to double. */ #define _LDBL_EQ_DBL 1 /* Define if ivo supported in streamio. */ #define _FVWRITE_IN_STREAMIO 1 /* Define if fseek functions support seek optimization. */ #define _FSEEK_OPTIMIZATION 1 /* Define if wide char orientation is supported. */ #define _WIDE_ORIENT 1 /* Define if unbuffered stream file optimization is supported. */ #define _UNBUF_STREAM_OPT 1 /* Define if lite version of exit supported. */ /* #undef _LITE_EXIT */ /* Define if declare atexit data as global. */ /* #undef _REENT_GLOBAL_ATEXIT */ /* Define if small footprint nano-formatted-IO implementation used. */ /* #undef _NANO_FORMATTED_IO */ /* * Iconv encodings enabled ("to" direction) */ /* #undef _ICONV_TO_ENCODING_BIG5 */ /* #undef _ICONV_TO_ENCODING_CP775 */ /* #undef _ICONV_TO_ENCODING_CP850 */ /* #undef _ICONV_TO_ENCODING_CP852 */ /* #undef _ICONV_TO_ENCODING_CP855 */ /* #undef _ICONV_TO_ENCODING_CP866 */ /* #undef _ICONV_TO_ENCODING_EUC_JP */ /* #undef _ICONV_TO_ENCODING_EUC_TW */ /* #undef _ICONV_TO_ENCODING_EUC_KR */ /* #undef _ICONV_TO_ENCODING_ISO_8859_1 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_10 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_11 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_13 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_14 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_15 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_2 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_3 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_4 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_5 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_6 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_7 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_8 */ /* #undef _ICONV_TO_ENCODING_ISO_8859_9 */ /* #undef _ICONV_TO_ENCODING_ISO_IR_111 */ /* #undef _ICONV_TO_ENCODING_KOI8_R */ /* #undef _ICONV_TO_ENCODING_KOI8_RU */ /* #undef _ICONV_TO_ENCODING_KOI8_U */ /* #undef _ICONV_TO_ENCODING_KOI8_UNI */ /* #undef _ICONV_TO_ENCODING_UCS_2 */ /* #undef _ICONV_TO_ENCODING_UCS_2_INTERNAL */ /* #undef _ICONV_TO_ENCODING_UCS_2BE */ /* #undef _ICONV_TO_ENCODING_UCS_2LE */ /* #undef _ICONV_TO_ENCODING_UCS_4 */ /* #undef _ICONV_TO_ENCODING_UCS_4_INTERNAL */ /* #undef _ICONV_TO_ENCODING_UCS_4BE */ /* #undef _ICONV_TO_ENCODING_UCS_4LE */ /* #undef _ICONV_TO_ENCODING_US_ASCII */ /* #undef _ICONV_TO_ENCODING_UTF_16 */ /* #undef _ICONV_TO_ENCODING_UTF_16BE */ /* #undef _ICONV_TO_ENCODING_UTF_16LE */ /* #undef _ICONV_TO_ENCODING_UTF_8 */ /* #undef _ICONV_TO_ENCODING_WIN_1250 */ /* #undef _ICONV_TO_ENCODING_WIN_1251 */ /* #undef _ICONV_TO_ENCODING_WIN_1252 */ /* #undef _ICONV_TO_ENCODING_WIN_1253 */ /* #undef _ICONV_TO_ENCODING_WIN_1254 */ /* #undef _ICONV_TO_ENCODING_WIN_1255 */ /* #undef _ICONV_TO_ENCODING_WIN_1256 */ /* #undef _ICONV_TO_ENCODING_WIN_1257 */ /* #undef _ICONV_TO_ENCODING_WIN_1258 */ /* * Iconv encodings enabled ("from" direction) */ /* #undef _ICONV_FROM_ENCODING_BIG5 */ /* #undef _ICONV_FROM_ENCODING_CP775 */ /* #undef _ICONV_FROM_ENCODING_CP850 */ /* #undef _ICONV_FROM_ENCODING_CP852 */ /* #undef _ICONV_FROM_ENCODING_CP855 */ /* #undef _ICONV_FROM_ENCODING_CP866 */ /* #undef _ICONV_FROM_ENCODING_EUC_JP */ /* #undef _ICONV_FROM_ENCODING_EUC_TW */ /* #undef _ICONV_FROM_ENCODING_EUC_KR */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_1 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_10 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_11 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_13 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_14 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_15 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_2 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_3 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_4 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_5 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_6 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_7 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_8 */ /* #undef _ICONV_FROM_ENCODING_ISO_8859_9 */ /* #undef _ICONV_FROM_ENCODING_ISO_IR_111 */ /* #undef _ICONV_FROM_ENCODING_KOI8_R */ /* #undef _ICONV_FROM_ENCODING_KOI8_RU */ /* #undef _ICONV_FROM_ENCODING_KOI8_U */ /* #undef _ICONV_FROM_ENCODING_KOI8_UNI */ /* #undef _ICONV_FROM_ENCODING_UCS_2 */ /* #undef _ICONV_FROM_ENCODING_UCS_2_INTERNAL */ /* #undef _ICONV_FROM_ENCODING_UCS_2BE */ /* #undef _ICONV_FROM_ENCODING_UCS_2LE */ /* #undef _ICONV_FROM_ENCODING_UCS_4 */ /* #undef _ICONV_FROM_ENCODING_UCS_4_INTERNAL */ /* #undef _ICONV_FROM_ENCODING_UCS_4BE */ /* #undef _ICONV_FROM_ENCODING_UCS_4LE */ /* #undef _ICONV_FROM_ENCODING_US_ASCII */ /* #undef _ICONV_FROM_ENCODING_UTF_16 */ /* #undef _ICONV_FROM_ENCODING_UTF_16BE */ /* #undef _ICONV_FROM_ENCODING_UTF_16LE */ /* #undef _ICONV_FROM_ENCODING_UTF_8 */ /* #undef _ICONV_FROM_ENCODING_WIN_1250 */ /* #undef _ICONV_FROM_ENCODING_WIN_1251 */ /* #undef _ICONV_FROM_ENCODING_WIN_1252 */ /* #undef _ICONV_FROM_ENCODING_WIN_1253 */ /* #undef _ICONV_FROM_ENCODING_WIN_1254 */ /* #undef _ICONV_FROM_ENCODING_WIN_1255 */ /* #undef _ICONV_FROM_ENCODING_WIN_1256 */ /* #undef _ICONV_FROM_ENCODING_WIN_1257 */ /* #undef _ICONV_FROM_ENCODING_WIN_1258 */ #endif /* !__NEWLIB_H__ */ 0707010000002f000081a40000000000000000000000016181423c000000c1000000000000000000000000000000000000002100000000./usr/nvptx-none/include/paths.h#ifndef _PATHS_H_ #define _PATHS_H_ #define _PATH_DEV "/dev/" #define _PATH_DEVNULL "/dev/null" #define _PATH_DEVZERO "/dev/zero" #define _PATH_BSHELL "/bin/sh" #endif /* _PATHS_H_ */ 07070100000030000081a40000000000000000000000016181423c00003900000000000000000000000000000000000000002300000000./usr/nvptx-none/include/pthread.h/* pthread.h * * Written by Joel Sherrill . * * COPYRIGHT (c) 1989-2013. * On-Line Applications Research Corporation (OAR). * * Permission to use, copy, modify, and distribute this software for any * purpose without fee is hereby granted, provided that this entire notice * is included in all copies of any software which is or includes a copy * or modification of this software. * * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED * WARRANTY. IN PARTICULAR, THE AUTHOR MAKES NO REPRESENTATION * OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY OF THIS * SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE. * * $Id$ */ #ifndef __PTHREAD_h #define __PTHREAD_h #ifdef __cplusplus extern "C" { #endif #include #if defined(_POSIX_THREADS) #include #include #include #include struct _pthread_cleanup_context { void (*_routine)(void *); void *_arg; int _canceltype; struct _pthread_cleanup_context *_previous; }; /* Register Fork Handlers */ int _EXFUN(pthread_atfork,(void (*prepare)(void), void (*parent)(void), void (*child)(void))); /* Mutex Initialization Attributes, P1003.1c/Draft 10, p. 81 */ int _EXFUN(pthread_mutexattr_init, (pthread_mutexattr_t *__attr)); int _EXFUN(pthread_mutexattr_destroy, (pthread_mutexattr_t *__attr)); int _EXFUN(pthread_mutexattr_getpshared, (_CONST pthread_mutexattr_t *__attr, int *__pshared)); int _EXFUN(pthread_mutexattr_setpshared, (pthread_mutexattr_t *__attr, int __pshared)); #if defined(_UNIX98_THREAD_MUTEX_ATTRIBUTES) /* Single UNIX Specification 2 Mutex Attributes types */ int _EXFUN(pthread_mutexattr_gettype, (_CONST pthread_mutexattr_t *__attr, int *__kind)); int _EXFUN(pthread_mutexattr_settype, (pthread_mutexattr_t *__attr, int __kind)); #endif /* Initializing and Destroying a Mutex, P1003.1c/Draft 10, p. 87 */ int _EXFUN(pthread_mutex_init, (pthread_mutex_t *__mutex, _CONST pthread_mutexattr_t *__attr)); int _EXFUN(pthread_mutex_destroy, (pthread_mutex_t *__mutex)); /* This is used to statically initialize a pthread_mutex_t. Example: pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; */ #define PTHREAD_MUTEX_INITIALIZER ((pthread_mutex_t) 0xFFFFFFFF) /* Locking and Unlocking a Mutex, P1003.1c/Draft 10, p. 93 NOTE: P1003.4b/D8 adds pthread_mutex_timedlock(), p. 29 */ int _EXFUN(pthread_mutex_lock, (pthread_mutex_t *__mutex)); int _EXFUN(pthread_mutex_trylock, (pthread_mutex_t *__mutex)); int _EXFUN(pthread_mutex_unlock, (pthread_mutex_t *__mutex)); #if defined(_POSIX_TIMEOUTS) int _EXFUN(pthread_mutex_timedlock, (pthread_mutex_t *__mutex, _CONST struct timespec *__timeout)); #endif /* _POSIX_TIMEOUTS */ /* Condition Variable Initialization Attributes, P1003.1c/Draft 10, p. 96 */ int _EXFUN(pthread_condattr_init, (pthread_condattr_t *__attr)); int _EXFUN(pthread_condattr_destroy, (pthread_condattr_t *__attr)); int _EXFUN(pthread_condattr_getpshared, (_CONST pthread_condattr_t *__attr, int *__pshared)); int _EXFUN(pthread_condattr_setpshared, (pthread_condattr_t *__attr, int __pshared)); /* Initializing and Destroying a Condition Variable, P1003.1c/Draft 10, p. 87 */ int _EXFUN(pthread_cond_init, (pthread_cond_t *__cond, _CONST pthread_condattr_t *__attr)); int _EXFUN(pthread_cond_destroy, (pthread_cond_t *__mutex)); /* This is used to statically initialize a pthread_cond_t. Example: pthread_cond_t cond = PTHREAD_COND_INITIALIZER; */ #define PTHREAD_COND_INITIALIZER ((pthread_cond_t) 0xFFFFFFFF) /* Broadcasting and Signaling a Condition, P1003.1c/Draft 10, p. 101 */ int _EXFUN(pthread_cond_signal, (pthread_cond_t *__cond)); int _EXFUN(pthread_cond_broadcast, (pthread_cond_t *__cond)); /* Waiting on a Condition, P1003.1c/Draft 10, p. 105 */ int _EXFUN(pthread_cond_wait, (pthread_cond_t *__cond, pthread_mutex_t *__mutex)); int _EXFUN(pthread_cond_timedwait, (pthread_cond_t *__cond, pthread_mutex_t *__mutex, _CONST struct timespec *__abstime)); #if defined(_POSIX_THREAD_PRIORITY_SCHEDULING) /* Thread Creation Scheduling Attributes, P1003.1c/Draft 10, p. 120 */ int _EXFUN(pthread_attr_setscope, (pthread_attr_t *__attr, int __contentionscope)); int _EXFUN(pthread_attr_getscope, (_CONST pthread_attr_t *__attr, int *__contentionscope)); int _EXFUN(pthread_attr_setinheritsched, (pthread_attr_t *__attr, int __inheritsched)); int _EXFUN(pthread_attr_getinheritsched, (_CONST pthread_attr_t *__attr, int *__inheritsched)); int _EXFUN(pthread_attr_setschedpolicy, (pthread_attr_t *__attr, int __policy)); int _EXFUN(pthread_attr_getschedpolicy, (_CONST pthread_attr_t *__attr, int *__policy)); #endif /* defined(_POSIX_THREAD_PRIORITY_SCHEDULING) */ int _EXFUN(pthread_attr_setschedparam, (pthread_attr_t *__attr, _CONST struct sched_param *__param)); int _EXFUN(pthread_attr_getschedparam, (_CONST pthread_attr_t *__attr, struct sched_param *__param)); #if defined(_POSIX_THREAD_PRIORITY_SCHEDULING) /* Dynamic Thread Scheduling Parameters Access, P1003.1c/Draft 10, p. 124 */ int _EXFUN(pthread_getschedparam, (pthread_t __pthread, int *__policy, struct sched_param *__param)); int _EXFUN(pthread_setschedparam, (pthread_t __pthread, int __policy, struct sched_param *__param)); #endif /* defined(_POSIX_THREAD_PRIORITY_SCHEDULING) */ #if defined(_POSIX_THREAD_PRIO_INHERIT) || defined(_POSIX_THREAD_PRIO_PROTECT) /* Mutex Initialization Scheduling Attributes, P1003.1c/Draft 10, p. 128 */ int _EXFUN(pthread_mutexattr_setprotocol, (pthread_mutexattr_t *__attr, int __protocol)); int _EXFUN(pthread_mutexattr_getprotocol, (_CONST pthread_mutexattr_t *__attr, int *__protocol)); int _EXFUN(pthread_mutexattr_setprioceiling, (pthread_mutexattr_t *__attr, int __prioceiling)); int _EXFUN(pthread_mutexattr_getprioceiling, (_CONST pthread_mutexattr_t *__attr, int *__prioceiling)); #endif /* _POSIX_THREAD_PRIO_INHERIT || _POSIX_THREAD_PRIO_PROTECT */ #if defined(_POSIX_THREAD_PRIO_PROTECT) /* Change the Priority Ceiling of a Mutex, P1003.1c/Draft 10, p. 131 */ int _EXFUN(pthread_mutex_setprioceiling, (pthread_mutex_t *__mutex, int __prioceiling, int *__old_ceiling)); int _EXFUN(pthread_mutex_getprioceiling, (pthread_mutex_t *__mutex, int *__prioceiling)); #endif /* _POSIX_THREAD_PRIO_PROTECT */ /* Thread Creation Attributes, P1003.1c/Draft 10, p, 140 */ int _EXFUN(pthread_attr_init, (pthread_attr_t *__attr)); int _EXFUN(pthread_attr_destroy, (pthread_attr_t *__attr)); int _EXFUN(pthread_attr_setstack, (pthread_attr_t *attr, void *__stackaddr, size_t __stacksize)); int _EXFUN(pthread_attr_getstack, (_CONST pthread_attr_t *attr, void **__stackaddr, size_t *__stacksize)); int _EXFUN(pthread_attr_getstacksize, (_CONST pthread_attr_t *__attr, size_t *__stacksize)); int _EXFUN(pthread_attr_setstacksize, (pthread_attr_t *__attr, size_t __stacksize)); int _EXFUN(pthread_attr_getstackaddr, (_CONST pthread_attr_t *__attr, void **__stackaddr)); int _EXFUN(pthread_attr_setstackaddr, (pthread_attr_t *__attr, void *__stackaddr)); int _EXFUN(pthread_attr_getdetachstate, (_CONST pthread_attr_t *__attr, int *__detachstate)); int _EXFUN(pthread_attr_setdetachstate, (pthread_attr_t *__attr, int __detachstate)); int _EXFUN(pthread_attr_getguardsize, (_CONST pthread_attr_t *__attr, size_t *__guardsize)); int _EXFUN(pthread_attr_setguardsize, (pthread_attr_t *__attr, size_t __guardsize)); /* POSIX thread APIs beyond the POSIX standard but provided * in GNU/Linux. They may be provided by other OSes for * compatibility. */ #if defined(__GNU_VISIBLE) #if defined(__rtems__) int _EXFUN(pthread_attr_setaffinity_np, (pthread_attr_t *__attr, size_t __cpusetsize, const cpu_set_t *__cpuset)); int _EXFUN(pthread_attr_getaffinity_np, (const pthread_attr_t *__attr, size_t __cpusetsize, cpu_set_t *__cpuset)); int _EXFUN(pthread_setaffinity_np, (pthread_t __id, size_t __cpusetsize, const cpu_set_t *__cpuset)); int _EXFUN(pthread_getaffinity_np, (const pthread_t __id, size_t __cpusetsize, cpu_set_t *__cpuset)); int _EXFUN(pthread_getattr_np, (pthread_t __id, pthread_attr_t *__attr)); #endif /* defined(__rtems__) */ #endif /* defined(__GNU_VISIBLE) */ /* Thread Creation, P1003.1c/Draft 10, p. 144 */ int _EXFUN(pthread_create, (pthread_t *__pthread, _CONST pthread_attr_t *__attr, void *(*__start_routine)( void * ), void *__arg)); /* Wait for Thread Termination, P1003.1c/Draft 10, p. 147 */ int _EXFUN(pthread_join, (pthread_t __pthread, void **__value_ptr)); /* Detaching a Thread, P1003.1c/Draft 10, p. 149 */ int _EXFUN(pthread_detach, (pthread_t __pthread)); /* Thread Termination, p1003.1c/Draft 10, p. 150 */ void _EXFUN(pthread_exit, (void *__value_ptr)); /* Get Calling Thread's ID, p1003.1c/Draft 10, p. XXX */ pthread_t _EXFUN(pthread_self, (void)); /* Compare Thread IDs, p1003.1c/Draft 10, p. 153 */ int _EXFUN(pthread_equal, (pthread_t __t1, pthread_t __t2)); /* Dynamic Package Initialization */ /* This is used to statically initialize a pthread_once_t. Example: pthread_once_t once = PTHREAD_ONCE_INIT; NOTE: This is named inconsistently -- it should be INITIALIZER. */ #define PTHREAD_ONCE_INIT { 1, 0 } /* is initialized and not run */ int _EXFUN(pthread_once, (pthread_once_t *__once_control, void (*__init_routine)(void))); /* Thread-Specific Data Key Create, P1003.1c/Draft 10, p. 163 */ int _EXFUN(pthread_key_create, (pthread_key_t *__key, void (*__destructor)( void * ))); /* Thread-Specific Data Management, P1003.1c/Draft 10, p. 165 */ int _EXFUN(pthread_setspecific, (pthread_key_t __key, _CONST void *__value)); void * _EXFUN(pthread_getspecific, (pthread_key_t __key)); /* Thread-Specific Data Key Deletion, P1003.1c/Draft 10, p. 167 */ int _EXFUN(pthread_key_delete, (pthread_key_t __key)); /* Execution of a Thread, P1003.1c/Draft 10, p. 181 */ #define PTHREAD_CANCEL_ENABLE 0 #define PTHREAD_CANCEL_DISABLE 1 #define PTHREAD_CANCEL_DEFERRED 0 #define PTHREAD_CANCEL_ASYNCHRONOUS 1 #define PTHREAD_CANCELED ((void *) -1) int _EXFUN(pthread_cancel, (pthread_t __pthread)); /* Setting Cancelability State, P1003.1c/Draft 10, p. 183 */ int _EXFUN(pthread_setcancelstate, (int __state, int *__oldstate)); int _EXFUN(pthread_setcanceltype, (int __type, int *__oldtype)); void _EXFUN(pthread_testcancel, (void)); /* Establishing Cancellation Handlers, P1003.1c/Draft 10, p. 184 */ void _EXFUN(_pthread_cleanup_push, (struct _pthread_cleanup_context *_context, void (*_routine)(void *), void *_arg)); void _EXFUN(_pthread_cleanup_pop, (struct _pthread_cleanup_context *_context, int _execute)); /* It is intentional to open and close the scope in two different macros */ #define pthread_cleanup_push(_routine, _arg) \ do { \ struct _pthread_cleanup_context _pthread_clup_ctx; \ _pthread_cleanup_push(&_pthread_clup_ctx, (_routine), (_arg)) #define pthread_cleanup_pop(_execute) \ _pthread_cleanup_pop(&_pthread_clup_ctx, (_execute)); \ } while (0) #if defined(_GNU_SOURCE) void _EXFUN(_pthread_cleanup_push_defer, (struct _pthread_cleanup_context *_context, void (*_routine)(void *), void *_arg)); void _EXFUN(_pthread_cleanup_pop_restore, (struct _pthread_cleanup_context *_context, int _execute)); /* It is intentional to open and close the scope in two different macros */ #define pthread_cleanup_push_defer_np(_routine, _arg) \ do { \ struct _pthread_cleanup_context _pthread_clup_ctx; \ _pthread_cleanup_push_defer(&_pthread_clup_ctx, (_routine), (_arg)) #define pthread_cleanup_pop_restore_np(_execute) \ _pthread_cleanup_pop_restore(&_pthread_clup_ctx, (_execute)); \ } while (0) #endif /* defined(_GNU_SOURCE) */ #if defined(_POSIX_THREAD_CPUTIME) /* Accessing a Thread CPU-time Clock, P1003.4b/D8, p. 58 */ int _EXFUN(pthread_getcpuclockid, (pthread_t __pthread_id, clockid_t *__clock_id)); #endif /* defined(_POSIX_THREAD_CPUTIME) */ #endif /* defined(_POSIX_THREADS) */ #if defined(_POSIX_BARRIERS) int _EXFUN(pthread_barrierattr_init, (pthread_barrierattr_t *__attr)); int _EXFUN(pthread_barrierattr_destroy, (pthread_barrierattr_t *__attr)); int _EXFUN(pthread_barrierattr_getpshared, (_CONST pthread_barrierattr_t *__attr, int *__pshared)); int _EXFUN(pthread_barrierattr_setpshared, (pthread_barrierattr_t *__attr, int __pshared)); #define PTHREAD_BARRIER_SERIAL_THREAD -1 int _EXFUN(pthread_barrier_init, (pthread_barrier_t *__barrier, _CONST pthread_barrierattr_t *__attr, unsigned __count)); int _EXFUN(pthread_barrier_destroy, (pthread_barrier_t *__barrier)); int _EXFUN(pthread_barrier_wait,(pthread_barrier_t *__barrier)); #endif /* defined(_POSIX_BARRIERS) */ #if defined(_POSIX_SPIN_LOCKS) int _EXFUN(pthread_spin_init, (pthread_spinlock_t *__spinlock, int __pshared)); int _EXFUN(pthread_spin_destroy, (pthread_spinlock_t *__spinlock)); int _EXFUN(pthread_spin_lock, (pthread_spinlock_t *__spinlock)); int _EXFUN(pthread_spin_trylock, (pthread_spinlock_t *__spinlock)); int _EXFUN(pthread_spin_unlock, (pthread_spinlock_t *__spinlock)); #endif /* defined(_POSIX_SPIN_LOCKS) */ #if defined(_POSIX_READER_WRITER_LOCKS) /* This is used to statically initialize a pthread_rwlock_t. Example: pthread_mutex_t mutex = PTHREAD_RWLOCK_INITIALIZER; */ #define PTHREAD_RWLOCK_INITIALIZER ((pthread_rwlock_t) 0xFFFFFFFF) int _EXFUN(pthread_rwlockattr_init, (pthread_rwlockattr_t *__attr)); int _EXFUN(pthread_rwlockattr_destroy, (pthread_rwlockattr_t *__attr)); int _EXFUN(pthread_rwlockattr_getpshared, (_CONST pthread_rwlockattr_t *__attr, int *__pshared)); int _EXFUN(pthread_rwlockattr_setpshared, (pthread_rwlockattr_t *__attr, int __pshared)); int _EXFUN(pthread_rwlock_init, (pthread_rwlock_t *__rwlock, _CONST pthread_rwlockattr_t *__attr)); int _EXFUN(pthread_rwlock_destroy, (pthread_rwlock_t *__rwlock)); int _EXFUN(pthread_rwlock_rdlock,(pthread_rwlock_t *__rwlock)); int _EXFUN(pthread_rwlock_tryrdlock,(pthread_rwlock_t *__rwlock)); int _EXFUN(pthread_rwlock_timedrdlock, (pthread_rwlock_t *__rwlock, _CONST struct timespec *__abstime)); int _EXFUN(pthread_rwlock_unlock,(pthread_rwlock_t *__rwlock)); int _EXFUN(pthread_rwlock_wrlock,(pthread_rwlock_t *__rwlock)); int _EXFUN(pthread_rwlock_trywrlock,(pthread_rwlock_t *__rwlock)); int _EXFUN(pthread_rwlock_timedwrlock, (pthread_rwlock_t *__rwlock, _CONST struct timespec *__abstime)); #endif /* defined(_POSIX_READER_WRITER_LOCKS) */ #ifdef __cplusplus } #endif #endif /* end of include file */ 07070100000031000081a40000000000000000000000016181423c00000bb7000000000000000000000000000000000000001f00000000./usr/nvptx-none/include/pwd.h/*- * Copyright (c) 1989 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)pwd.h 5.13 (Berkeley) 5/28/91 */ #ifndef _PWD_H_ #ifdef __cplusplus extern "C" { #endif #define _PWD_H_ #include #include #if __BSD_VISIBLE #define _PATH_PASSWD "/etc/passwd" #define _PASSWORD_LEN 128 /* max length, not counting NULL */ #endif struct passwd { char *pw_name; /* user name */ char *pw_passwd; /* encrypted password */ uid_t pw_uid; /* user uid */ gid_t pw_gid; /* user gid */ char *pw_comment; /* comment */ char *pw_gecos; /* Honeywell login info */ char *pw_dir; /* home directory */ char *pw_shell; /* default shell */ }; #ifndef __INSIDE_CYGWIN__ struct passwd *getpwuid (uid_t); struct passwd *getpwnam (const char *); #if __POSIX_VISIBLE >= 200112 || __XSI_VISIBLE >= 500 int getpwnam_r (const char *, struct passwd *, char *, size_t , struct passwd **); int getpwuid_r (uid_t, struct passwd *, char *, size_t, struct passwd **); #endif #if __XSI_VISIBLE >= 500 struct passwd *getpwent (void); void setpwent (void); void endpwent (void); #endif #if __BSD_VISIBLE int setpassent (int); #endif #endif /*!__INSIDE_CYGWIN__*/ #ifdef __cplusplus } #endif #endif /* _PWD_H_ */ 07070100000032000081a40000000000000000000000016181423c00002242000000000000000000000000000000000000002100000000./usr/nvptx-none/include/reent.h/* This header file provides the reentrancy. */ /* The reentrant system calls here serve two purposes: 1) Provide reentrant versions of the system calls the ANSI C library requires. 2) Provide these system calls in a namespace clean way. It is intended that *all* system calls that the ANSI C library needs be declared here. It documents them all in one place. All library access to the system is via some form of these functions. The target may provide the needed syscalls by any of the following: 1) Define the reentrant versions of the syscalls directly. (eg: _open_r, _close_r, etc.). Please keep the namespace clean. When you do this, set "syscall_dir" to "syscalls" and add -DREENTRANT_SYSCALLS_PROVIDED to newlib_cflags in configure.host. 2) Define namespace clean versions of the system calls by prefixing them with '_' (eg: _open, _close, etc.). Technically, there won't be true reentrancy at the syscall level, but the library will be namespace clean. When you do this, set "syscall_dir" to "syscalls" in configure.host. 3) Define or otherwise provide the regular versions of the syscalls (eg: open, close, etc.). The library won't be reentrant nor namespace clean, but at least it will work. When you do this, add -DMISSING_SYSCALL_NAMES to newlib_cflags in configure.host. 4) Define or otherwise provide the regular versions of the syscalls, and do not supply functional interfaces for any of the reentrant calls. With this method, the reentrant syscalls are redefined to directly call the regular system call without the reentrancy argument. When you do this, specify both -DREENTRANT_SYSCALLS_PROVIDED and -DMISSING_SYSCALL_NAMES via newlib_cflags in configure.host and do not specify "syscall_dir". Stubs of the reentrant versions of the syscalls exist in the libc/reent source directory and are provided if REENTRANT_SYSCALLS_PROVIDED isn't defined. These stubs call the native system calls: _open, _close, etc. if MISSING_SYSCALL_NAMES is *not* defined, otherwise they call the non-underscored versions: open, close, etc. when MISSING_SYSCALL_NAMES *is* defined. By default, newlib functions call the reentrant syscalls internally, passing a reentrancy structure as an argument. This reentrancy structure contains data that is thread-specific. For example, the errno value is kept in the reentrancy structure. If multiple threads exist, each will keep a separate errno value which is intuitive since the application flow cannot check for failure reliably otherwise. The reentrant syscalls are either provided by the platform, by the libc/reent stubs, or in the case of both MISSING_SYSCALL_NAMES and REENTRANT_SYSCALLS_PROVIDED being defined, the calls are redefined to simply call the regular syscalls with no reentrancy struct argument. A single-threaded application does not need to worry about the reentrancy structure. It is used internally. A multi-threaded application needs either to manually manage reentrancy structures or use dynamic reentrancy. Manually managing reentrancy structures entails calling special reentrant versions of newlib functions that have an additional reentrancy argument. For example, _printf_r. By convention, the first argument is the reentrancy structure. By default, the normal version of the function uses the default reentrancy structure: _REENT. The reentrancy structure is passed internally, eventually to the reentrant syscalls themselves. How the structures are stored and accessed in this model is up to the application. Dynamic reentrancy is specified by the __DYNAMIC_REENT__ flag. This flag denotes setting up a macro to replace _REENT with a function call to __getreent(). This function needs to be implemented by the platform and it is meant to return the reentrancy structure for the current thread. When the regular C functions (e.g. printf) go to call internal routines with the default _REENT structure, they end up calling with the reentrancy structure for the thread. Thus, application code does not need to call the _r routines nor worry about reentrancy structures. */ /* WARNING: All identifiers here must begin with an underscore. This file is included by stdio.h and others and we therefore must only use identifiers in the namespace allotted to us. */ #ifndef _REENT_H_ #ifdef __cplusplus extern "C" { #endif #define _REENT_H_ #include #include #include #define __need_size_t #define __need_ptrdiff_t #include /* FIXME: not namespace clean */ struct stat; struct tms; struct timeval; struct timezone; #if defined(REENTRANT_SYSCALLS_PROVIDED) && defined(MISSING_SYSCALL_NAMES) #define _close_r(__reent, __fd) close(__fd) #define _execve_r(__reent, __f, __arg, __env) execve(__f, __arg, __env) #define _fcntl_r(__reent, __fd, __cmd, __arg) fcntl(__fd, __cmd, __arg) #define _fork_r(__reent) fork() #define _fstat_r(__reent, __fdes, __stat) fstat(__fdes, __stat) #define _getpid_r(__reent) getpid() #define _isatty_r(__reent, __desc) isatty(__desc) #define _kill_r(__reent, __pid, __signal) kill(__pid, __signal) #define _link_r(__reent, __oldpath, __newpath) link(__oldpath, __newpath) #define _lseek_r(__reent, __fdes, __off, __w) lseek(__fdes, __off, __w) #define _mkdir_r(__reent, __path, __m) mkdir(__path, __m) #define _open_r(__reent, __path, __flag, __m) open(__path, __flag, __m) #define _read_r(__reent, __fd, __buff, __cnt) read(__fd, __buff, __cnt) #define _rename_r(__reent, __old, __new) rename(__old, __new) #define _sbrk_r(__reent, __incr) sbrk(__incr) #define _stat_r(__reent, __path, __buff) stat(__path, __buff) #define _times_r(__reent, __time) times(__time) #define _unlink_r(__reent, __path) unlink(__path) #define _wait_r(__reent, __status) wait(__status) #define _write_r(__reent, __fd, __buff, __cnt) write(__fd, __buff, __cnt) #define _gettimeofday_r(__reent, __tp, __tzp) gettimeofday(__tp, __tzp) #ifdef __LARGE64_FILES #define _lseek64_r(__reent, __fd, __off, __w) lseek64(__fd, __off, __w) #define _fstat64_r(__reent, __fd, __buff) fstat64(__fd, __buff) #define _open64_r(__reent, __path, __flag, __m) open64(__path, __flag, __m) #endif #else /* Reentrant versions of system calls. */ extern int _close_r _PARAMS ((struct _reent *, int)); extern int _execve_r _PARAMS ((struct _reent *, const char *, char *const *, char *const *)); extern int _fcntl_r _PARAMS ((struct _reent *, int, int, int)); extern int _fork_r _PARAMS ((struct _reent *)); extern int _fstat_r _PARAMS ((struct _reent *, int, struct stat *)); extern int _getpid_r _PARAMS ((struct _reent *)); extern int _isatty_r _PARAMS ((struct _reent *, int)); extern int _kill_r _PARAMS ((struct _reent *, int, int)); extern int _link_r _PARAMS ((struct _reent *, const char *, const char *)); extern _off_t _lseek_r _PARAMS ((struct _reent *, int, _off_t, int)); extern int _mkdir_r _PARAMS ((struct _reent *, const char *, int)); extern int _open_r _PARAMS ((struct _reent *, const char *, int, int)); extern _ssize_t _read_r _PARAMS ((struct _reent *, int, void *, size_t)); extern int _rename_r _PARAMS ((struct _reent *, const char *, const char *)); extern void *_sbrk_r _PARAMS ((struct _reent *, ptrdiff_t)); extern int _stat_r _PARAMS ((struct _reent *, const char *, struct stat *)); extern _CLOCK_T_ _times_r _PARAMS ((struct _reent *, struct tms *)); extern int _unlink_r _PARAMS ((struct _reent *, const char *)); extern int _wait_r _PARAMS ((struct _reent *, int *)); extern _ssize_t _write_r _PARAMS ((struct _reent *, int, const void *, size_t)); /* This one is not guaranteed to be available on all targets. */ extern int _gettimeofday_r _PARAMS ((struct _reent *, struct timeval *__tp, void *__tzp)); #ifdef __LARGE64_FILES #if defined(__CYGWIN__) #define stat64 stat #endif struct stat64; extern _off64_t _lseek64_r _PARAMS ((struct _reent *, int, _off64_t, int)); extern int _fstat64_r _PARAMS ((struct _reent *, int, struct stat64 *)); extern int _open64_r _PARAMS ((struct _reent *, const char *, int, int)); extern int _stat64_r _PARAMS ((struct _reent *, const char *, struct stat64 *)); /* Don't pollute namespace if not building newlib. */ #if defined (__CYGWIN__) && !defined (_COMPILING_NEWLIB) #undef stat64 #endif #endif #endif #ifdef __cplusplus } #endif #endif /* _REENT_H_ */ 07070100000033000081a40000000000000000000000016181423c000000dc000000000000000000000000000000000000002200000000./usr/nvptx-none/include/regdef.h/* regdef.h -- define register names. */ /* This is a standard include file for MIPS targets. Other target probably don't define it, and attempts to include this file will fail. */ #include 07070100000034000081a40000000000000000000000016181423c00000dea000000000000000000000000000000000000002100000000./usr/nvptx-none/include/regex.h/*- * Copyright (c) 1992 Henry Spencer. * Copyright (c) 1992, 1993 * The Regents of the University of California. All rights reserved. * * This code is derived from software contributed to Berkeley by * Henry Spencer of the University of Toronto. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)regex.h 8.2 (Berkeley) 1/3/94 * $FreeBSD: src/include/regex.h,v 1.4 2002/03/23 17:24:53 imp Exp $ */ #ifndef _REGEX_H_ #define _REGEX_H_ #include /* types */ typedef off_t regoff_t; typedef struct { int re_magic; size_t re_nsub; /* number of parenthesized subexpressions */ __const char *re_endp; /* end pointer for REG_PEND */ struct re_guts *re_g; /* none of your business :-) */ } regex_t; typedef struct { regoff_t rm_so; /* start of match */ regoff_t rm_eo; /* end of match */ } regmatch_t; /* regcomp() flags */ #define REG_BASIC 0000 #define REG_EXTENDED 0001 #define REG_ICASE 0002 #define REG_NOSUB 0004 #define REG_NEWLINE 0010 #define REG_NOSPEC 0020 #define REG_PEND 0040 #define REG_DUMP 0200 /* regerror() flags */ #define REG_NOMATCH 1 #define REG_BADPAT 2 #define REG_ECOLLATE 3 #define REG_ECTYPE 4 #define REG_EESCAPE 5 #define REG_ESUBREG 6 #define REG_EBRACK 7 #define REG_EPAREN 8 #define REG_EBRACE 9 #define REG_BADBR 10 #define REG_ERANGE 11 #define REG_ESPACE 12 #define REG_BADRPT 13 #define REG_EMPTY 14 #define REG_ASSERT 15 #define REG_INVARG 16 #define REG_ATOI 255 /* convert name to number (!) */ #define REG_ITOA 0400 /* convert number to name (!) */ /* regexec() flags */ #define REG_NOTBOL 00001 #define REG_NOTEOL 00002 #define REG_STARTEND 00004 #define REG_TRACE 00400 /* tracing of execution */ #define REG_LARGE 01000 /* force large representation */ #define REG_BACKR 02000 /* force use of backref code */ __BEGIN_DECLS int regcomp(regex_t *__restrict, const char *__restrict, int); size_t regerror(int, const regex_t *__restrict, char *__restrict, size_t); int regexec(const regex_t *__restrict, const char *__restrict, size_t, regmatch_t [__restrict], int); void regfree(regex_t *); __END_DECLS #endif /* !_REGEX_H_ */ 07070100000035000041ed0000000000000000000000016181423d00000000000000000000000000000000000000000000001d00000000./usr/nvptx-none/include/rpc07070100000036000081a40000000000000000000000016181423c0000088e000000000000000000000000000000000000002100000000./usr/nvptx-none/include/sched.h/* * Written by Joel Sherrill . * * COPYRIGHT (c) 1989-2010. * On-Line Applications Research Corporation (OAR). * * Permission to use, copy, modify, and distribute this software for any * purpose without fee is hereby granted, provided that this entire notice * is included in all copies of any software which is or includes a copy * or modification of this software. * * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED * WARRANTY. IN PARTICULAR, THE AUTHOR MAKES NO REPRESENTATION * OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY OF THIS * SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE. * * $Id$ */ #ifndef _SCHED_H_ #define _SCHED_H_ #include #include #ifdef __cplusplus extern "C" { #endif #if defined(_POSIX_PRIORITY_SCHEDULING) /* * XBD 13 - Set Scheduling Parameters, P1003.1b-2008, p. 1803 */ int sched_setparam( pid_t __pid, const struct sched_param *__param ); /* * XBD 13 - Set Scheduling Parameters, P1003.1b-2008, p. 1800 */ int sched_getparam( pid_t __pid, struct sched_param *__param ); /* * XBD 13 - Set Scheduling Policy and Scheduling Parameters, * P1003.1b-2008, p. 1805 */ int sched_setscheduler( pid_t __pid, int __policy, const struct sched_param *__param ); /* * XBD 13 - Get Scheduling Policy, P1003.1b-2008, p. 1801 */ int sched_getscheduler( pid_t __pid ); /* * XBD 13 - Get Scheduling Parameter Limits, P1003.1b-2008, p. 1799 */ int sched_get_priority_max( int __policy ); int sched_get_priority_min( int __policy ); /* * XBD 13 - Get Scheduling Parameter Limits, P1003.1b-2008, p. 1802 */ int sched_rr_get_interval( pid_t __pid, struct timespec *__interval ); #endif /* _POSIX_PRIORITY_SCHEDULING */ #if defined(_POSIX_THREADS) || defined(_POSIX_PRIORITY_SCHEDULING) /* * XBD 13 - Yield Processor, P1003.1b-2008, p. 1807 */ int sched_yield( void ); #endif /* _POSIX_THREADS or _POSIX_PRIORITY_SCHEDULING */ #ifdef __cplusplus } #endif #endif /* _SCHED_H_ */ 07070100000037000081a40000000000000000000000016181423c00000557000000000000000000000000000000000000002200000000./usr/nvptx-none/include/search.h/* $NetBSD: search.h,v 1.12 1999/02/22 10:34:28 christos Exp $ */ /* $FreeBSD: src/include/search.h,v 1.4 2002/03/23 17:24:53 imp Exp $ */ /* * Written by J.T. Conklin * Public domain. */ #ifndef _SEARCH_H_ #define _SEARCH_H_ #include #include #include typedef struct entry { char *key; void *data; } ENTRY; typedef enum { FIND, ENTER } ACTION; typedef enum { preorder, postorder, endorder, leaf } VISIT; #ifdef _SEARCH_PRIVATE typedef struct node { char *key; struct node *llink, *rlink; } node_t; #endif struct hsearch_data { struct internal_head *htable; size_t htablesize; }; #ifndef __compar_fn_t_defined #define __compar_fn_t_defined typedef int (*__compar_fn_t) (const void *, const void *); #endif __BEGIN_DECLS int hcreate(size_t); void hdestroy(void); ENTRY *hsearch(ENTRY, ACTION); int hcreate_r(size_t, struct hsearch_data *); void hdestroy_r(struct hsearch_data *); int hsearch_r(ENTRY, ACTION, ENTRY **, struct hsearch_data *); void *tdelete(const void *__restrict, void **__restrict, __compar_fn_t); void tdestroy (void *, void (*)(void *)); void *tfind(const void *, void **, __compar_fn_t); void *tsearch(const void *, void **, __compar_fn_t); void twalk(const void *, void (*)(const void *, VISIT, int)); __END_DECLS #endif /* !_SEARCH_H_ */ 07070100000038000081a40000000000000000000000016181423c00000181000000000000000000000000000000000000002200000000./usr/nvptx-none/include/setjmp.h/* setjmp.h stubs for future use. */ #ifndef _SETJMP_H_ #define _SETJMP_H_ #include "_ansi.h" #include _BEGIN_STD_C #ifdef __GNUC__ void _EXFUN(longjmp,(jmp_buf __jmpb, int __retval)) __attribute__ ((__noreturn__)); #else void _EXFUN(longjmp,(jmp_buf __jmpb, int __retval)); #endif int _EXFUN(setjmp,(jmp_buf __jmpb)); _END_STD_C #endif /* _SETJMP_H_ */ 07070100000039000081a40000000000000000000000016181423c0000031c000000000000000000000000000000000000002200000000./usr/nvptx-none/include/signal.h#ifndef _SIGNAL_H_ #define _SIGNAL_H_ #include "_ansi.h" #include _BEGIN_STD_C typedef int sig_atomic_t; /* Atomic entity type (ANSI) */ #ifndef _POSIX_SOURCE typedef _sig_func_ptr sig_t; /* BSD naming */ typedef _sig_func_ptr sighandler_t; /* glibc naming */ #endif /* !_POSIX_SOURCE */ #define SIG_DFL ((_sig_func_ptr)0) /* Default action */ #define SIG_IGN ((_sig_func_ptr)1) /* Ignore action */ #define SIG_ERR ((_sig_func_ptr)-1) /* Error return */ struct _reent; _sig_func_ptr _EXFUN(_signal_r, (struct _reent *, int, _sig_func_ptr)); int _EXFUN(_raise_r, (struct _reent *, int)); #ifndef _REENT_ONLY _sig_func_ptr _EXFUN(signal, (int, _sig_func_ptr)); int _EXFUN(raise, (int)); void _EXFUN(psignal, (int, const char *)); #endif _END_STD_C #endif /* _SIGNAL_H_ */ 0707010000003a000081a40000000000000000000000016181423c000010b7000000000000000000000000000000000000002100000000./usr/nvptx-none/include/spawn.h/*- * Copyright (c) 2008 Ed Schouten * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. */ #ifndef _SPAWN_H_ #define _SPAWN_H_ #include <_ansi.h> #include #include #include #define __need_sigset_t #include struct sched_param; typedef struct __posix_spawnattr *posix_spawnattr_t; typedef struct __posix_spawn_file_actions *posix_spawn_file_actions_t; #define POSIX_SPAWN_RESETIDS 0x01 #define POSIX_SPAWN_SETPGROUP 0x02 #define POSIX_SPAWN_SETSCHEDPARAM 0x04 #define POSIX_SPAWN_SETSCHEDULER 0x08 #define POSIX_SPAWN_SETSIGDEF 0x10 #define POSIX_SPAWN_SETSIGMASK 0x20 _BEGIN_STD_C /* * Spawn routines * * XXX both arrays should be __restrict, but this does not work when GCC * is invoked with -std=c99. */ int _EXFUN(posix_spawn, (pid_t * __restrict, const char * __restrict, const posix_spawn_file_actions_t *, const posix_spawnattr_t * __restrict, char * const [], char * const []) ); int _EXFUN(posix_spawnp, (pid_t * __restrict, const char * __restrict, const posix_spawn_file_actions_t *, const posix_spawnattr_t * __restrict, char * const [], char * const []) ); /* * File descriptor actions */ int _EXFUN(posix_spawn_file_actions_init, (posix_spawn_file_actions_t *)); int _EXFUN(posix_spawn_file_actions_destroy, (posix_spawn_file_actions_t *)); int _EXFUN(posix_spawn_file_actions_addopen, (posix_spawn_file_actions_t * __restrict, int, const char * __restrict, int, mode_t) ); int _EXFUN(posix_spawn_file_actions_adddup2, (posix_spawn_file_actions_t *, int, int) ); int _EXFUN(posix_spawn_file_actions_addclose, (posix_spawn_file_actions_t *, int) ); /* * Spawn attributes */ int _EXFUN(posix_spawnattr_init, (posix_spawnattr_t *)); int _EXFUN(posix_spawnattr_destroy, (posix_spawnattr_t *)); int _EXFUN(posix_spawnattr_getflags, (const posix_spawnattr_t * __restrict, short * __restrict) ); int _EXFUN(posix_spawnattr_getpgroup, (const posix_spawnattr_t * __restrict, pid_t * __restrict)); int _EXFUN(posix_spawnattr_getschedparam, (const posix_spawnattr_t * __restrict, struct sched_param * __restrict) ); int _EXFUN(posix_spawnattr_getschedpolicy, (const posix_spawnattr_t * __restrict, int * __restrict) ); int _EXFUN(posix_spawnattr_getsigdefault, (const posix_spawnattr_t * __restrict, sigset_t * __restrict) ); int _EXFUN(posix_spawnattr_getsigmask, (const posix_spawnattr_t * __restrict, sigset_t * __restrict) ); int _EXFUN(posix_spawnattr_setflags, (posix_spawnattr_t *, short)); int _EXFUN(posix_spawnattr_setpgroup, (posix_spawnattr_t *, pid_t)); int _EXFUN(posix_spawnattr_setschedparam, (posix_spawnattr_t * __restrict, const struct sched_param * __restrict) ); int _EXFUN(posix_spawnattr_setschedpolicy, (posix_spawnattr_t *, int)); int _EXFUN(posix_spawnattr_setsigdefault, (posix_spawnattr_t * __restrict, const sigset_t * __restrict) ); int _EXFUN(posix_spawnattr_setsigmask, (posix_spawnattr_t * __restrict, const sigset_t * __restrict) ); _END_STD_C #endif /* !_SPAWN_H_ */ 0707010000003b000081a40000000000000000000000016181423c00003840000000000000000000000000000000000000002500000000./usr/nvptx-none/include/stdatomic.h/*- * Copyright (c) 2011 Ed Schouten * David Chisnall * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. * * $FreeBSD$ */ #ifndef _STDATOMIC_H_ #define _STDATOMIC_H_ #include #include #if __has_extension(c_atomic) || __has_extension(cxx_atomic) #define __CLANG_ATOMICS #elif __GNUC_PREREQ__(4, 7) #define __GNUC_ATOMICS #elif defined(__GNUC__) #define __SYNC_ATOMICS #else #error "stdatomic.h does not support your compiler" #endif /* * 7.17.1 Atomic lock-free macros. */ #ifdef __GCC_ATOMIC_BOOL_LOCK_FREE #define ATOMIC_BOOL_LOCK_FREE __GCC_ATOMIC_BOOL_LOCK_FREE #endif #ifdef __GCC_ATOMIC_CHAR_LOCK_FREE #define ATOMIC_CHAR_LOCK_FREE __GCC_ATOMIC_CHAR_LOCK_FREE #endif #ifdef __GCC_ATOMIC_CHAR16_T_LOCK_FREE #define ATOMIC_CHAR16_T_LOCK_FREE __GCC_ATOMIC_CHAR16_T_LOCK_FREE #endif #ifdef __GCC_ATOMIC_CHAR32_T_LOCK_FREE #define ATOMIC_CHAR32_T_LOCK_FREE __GCC_ATOMIC_CHAR32_T_LOCK_FREE #endif #ifdef __GCC_ATOMIC_WCHAR_T_LOCK_FREE #define ATOMIC_WCHAR_T_LOCK_FREE __GCC_ATOMIC_WCHAR_T_LOCK_FREE #endif #ifdef __GCC_ATOMIC_SHORT_LOCK_FREE #define ATOMIC_SHORT_LOCK_FREE __GCC_ATOMIC_SHORT_LOCK_FREE #endif #ifdef __GCC_ATOMIC_INT_LOCK_FREE #define ATOMIC_INT_LOCK_FREE __GCC_ATOMIC_INT_LOCK_FREE #endif #ifdef __GCC_ATOMIC_LONG_LOCK_FREE #define ATOMIC_LONG_LOCK_FREE __GCC_ATOMIC_LONG_LOCK_FREE #endif #ifdef __GCC_ATOMIC_LLONG_LOCK_FREE #define ATOMIC_LLONG_LOCK_FREE __GCC_ATOMIC_LLONG_LOCK_FREE #endif #ifdef __GCC_ATOMIC_POINTER_LOCK_FREE #define ATOMIC_POINTER_LOCK_FREE __GCC_ATOMIC_POINTER_LOCK_FREE #endif /* * 7.17.2 Initialization. */ #if defined(__CLANG_ATOMICS) #define ATOMIC_VAR_INIT(value) (value) #define atomic_init(obj, value) __c11_atomic_init(obj, value) #else #define ATOMIC_VAR_INIT(value) { .__val = (value) } #define atomic_init(obj, value) ((void)((obj)->__val = (value))) #endif /* * Clang and recent GCC both provide predefined macros for the memory * orderings. If we are using a compiler that doesn't define them, use the * clang values - these will be ignored in the fallback path. */ #ifndef __ATOMIC_RELAXED #define __ATOMIC_RELAXED 0 #endif #ifndef __ATOMIC_CONSUME #define __ATOMIC_CONSUME 1 #endif #ifndef __ATOMIC_ACQUIRE #define __ATOMIC_ACQUIRE 2 #endif #ifndef __ATOMIC_RELEASE #define __ATOMIC_RELEASE 3 #endif #ifndef __ATOMIC_ACQ_REL #define __ATOMIC_ACQ_REL 4 #endif #ifndef __ATOMIC_SEQ_CST #define __ATOMIC_SEQ_CST 5 #endif /* * 7.17.3 Order and consistency. * * The memory_order_* constants that denote the barrier behaviour of the * atomic operations. */ typedef enum { memory_order_relaxed = __ATOMIC_RELAXED, memory_order_consume = __ATOMIC_CONSUME, memory_order_acquire = __ATOMIC_ACQUIRE, memory_order_release = __ATOMIC_RELEASE, memory_order_acq_rel = __ATOMIC_ACQ_REL, memory_order_seq_cst = __ATOMIC_SEQ_CST } memory_order; /* * 7.17.4 Fences. */ static __inline void atomic_thread_fence(memory_order __order __unused) { #ifdef __CLANG_ATOMICS __c11_atomic_thread_fence(__order); #elif defined(__GNUC_ATOMICS) __atomic_thread_fence(__order); #else __sync_synchronize(); #endif } static __inline void atomic_signal_fence(memory_order __order __unused) { #ifdef __CLANG_ATOMICS __c11_atomic_signal_fence(__order); #elif defined(__GNUC_ATOMICS) __atomic_signal_fence(__order); #else __asm volatile ("" ::: "memory"); #endif } /* * 7.17.5 Lock-free property. */ #if defined(_KERNEL) /* Atomics in kernelspace are always lock-free. */ #define atomic_is_lock_free(obj) \ ((void)(obj), (_Bool)1) #elif defined(__CLANG_ATOMICS) #define atomic_is_lock_free(obj) \ __atomic_is_lock_free(sizeof(*(obj)), obj) #elif defined(__GNUC_ATOMICS) #define atomic_is_lock_free(obj) \ __atomic_is_lock_free(sizeof((obj)->__val), &(obj)->__val) #else #define atomic_is_lock_free(obj) \ ((void)(obj), sizeof((obj)->__val) <= sizeof(void *)) #endif /* * 7.17.6 Atomic integer types. */ typedef _Atomic(_Bool) atomic_bool; typedef _Atomic(char) atomic_char; typedef _Atomic(signed char) atomic_schar; typedef _Atomic(unsigned char) atomic_uchar; typedef _Atomic(short) atomic_short; typedef _Atomic(unsigned short) atomic_ushort; typedef _Atomic(int) atomic_int; typedef _Atomic(unsigned int) atomic_uint; typedef _Atomic(long) atomic_long; typedef _Atomic(unsigned long) atomic_ulong; typedef _Atomic(long long) atomic_llong; typedef _Atomic(unsigned long long) atomic_ullong; #if 0 typedef _Atomic(__char16_t) atomic_char16_t; typedef _Atomic(__char32_t) atomic_char32_t; #endif typedef _Atomic(wchar_t) atomic_wchar_t; typedef _Atomic(int_least8_t) atomic_int_least8_t; typedef _Atomic(uint_least8_t) atomic_uint_least8_t; typedef _Atomic(int_least16_t) atomic_int_least16_t; typedef _Atomic(uint_least16_t) atomic_uint_least16_t; typedef _Atomic(int_least32_t) atomic_int_least32_t; typedef _Atomic(uint_least32_t) atomic_uint_least32_t; typedef _Atomic(int_least64_t) atomic_int_least64_t; typedef _Atomic(uint_least64_t) atomic_uint_least64_t; typedef _Atomic(int_fast8_t) atomic_int_fast8_t; typedef _Atomic(uint_fast8_t) atomic_uint_fast8_t; typedef _Atomic(int_fast16_t) atomic_int_fast16_t; typedef _Atomic(uint_fast16_t) atomic_uint_fast16_t; typedef _Atomic(int_fast32_t) atomic_int_fast32_t; typedef _Atomic(uint_fast32_t) atomic_uint_fast32_t; typedef _Atomic(int_fast64_t) atomic_int_fast64_t; typedef _Atomic(uint_fast64_t) atomic_uint_fast64_t; typedef _Atomic(intptr_t) atomic_intptr_t; typedef _Atomic(uintptr_t) atomic_uintptr_t; typedef _Atomic(size_t) atomic_size_t; typedef _Atomic(ptrdiff_t) atomic_ptrdiff_t; typedef _Atomic(intmax_t) atomic_intmax_t; typedef _Atomic(uintmax_t) atomic_uintmax_t; /* * 7.17.7 Operations on atomic types. */ /* * Compiler-specific operations. */ #if defined(__CLANG_ATOMICS) #define atomic_compare_exchange_strong_explicit(object, expected, \ desired, success, failure) \ __c11_atomic_compare_exchange_strong(object, expected, desired, \ success, failure) #define atomic_compare_exchange_weak_explicit(object, expected, \ desired, success, failure) \ __c11_atomic_compare_exchange_weak(object, expected, desired, \ success, failure) #define atomic_exchange_explicit(object, desired, order) \ __c11_atomic_exchange(object, desired, order) #define atomic_fetch_add_explicit(object, operand, order) \ __c11_atomic_fetch_add(object, operand, order) #define atomic_fetch_and_explicit(object, operand, order) \ __c11_atomic_fetch_and(object, operand, order) #define atomic_fetch_or_explicit(object, operand, order) \ __c11_atomic_fetch_or(object, operand, order) #define atomic_fetch_sub_explicit(object, operand, order) \ __c11_atomic_fetch_sub(object, operand, order) #define atomic_fetch_xor_explicit(object, operand, order) \ __c11_atomic_fetch_xor(object, operand, order) #define atomic_load_explicit(object, order) \ __c11_atomic_load(object, order) #define atomic_store_explicit(object, desired, order) \ __c11_atomic_store(object, desired, order) #elif defined(__GNUC_ATOMICS) #define atomic_compare_exchange_strong_explicit(object, expected, \ desired, success, failure) \ __atomic_compare_exchange_n(&(object)->__val, expected, \ desired, 0, success, failure) #define atomic_compare_exchange_weak_explicit(object, expected, \ desired, success, failure) \ __atomic_compare_exchange_n(&(object)->__val, expected, \ desired, 1, success, failure) #define atomic_exchange_explicit(object, desired, order) \ __atomic_exchange_n(&(object)->__val, desired, order) #define atomic_fetch_add_explicit(object, operand, order) \ __atomic_fetch_add(&(object)->__val, operand, order) #define atomic_fetch_and_explicit(object, operand, order) \ __atomic_fetch_and(&(object)->__val, operand, order) #define atomic_fetch_or_explicit(object, operand, order) \ __atomic_fetch_or(&(object)->__val, operand, order) #define atomic_fetch_sub_explicit(object, operand, order) \ __atomic_fetch_sub(&(object)->__val, operand, order) #define atomic_fetch_xor_explicit(object, operand, order) \ __atomic_fetch_xor(&(object)->__val, operand, order) #define atomic_load_explicit(object, order) \ __atomic_load_n(&(object)->__val, order) #define atomic_store_explicit(object, desired, order) \ __atomic_store_n(&(object)->__val, desired, order) #else #define __atomic_apply_stride(object, operand) \ (((__typeof__((object)->__val))0) + (operand)) #define atomic_compare_exchange_strong_explicit(object, expected, \ desired, success, failure) __extension__ ({ \ __typeof__(expected) __ep = (expected); \ __typeof__(*__ep) __e = *__ep; \ (void)(success); (void)(failure); \ (_Bool)((*__ep = __sync_val_compare_and_swap(&(object)->__val, \ __e, desired)) == __e); \ }) #define atomic_compare_exchange_weak_explicit(object, expected, \ desired, success, failure) \ atomic_compare_exchange_strong_explicit(object, expected, \ desired, success, failure) #if __has_builtin(__sync_swap) /* Clang provides a full-barrier atomic exchange - use it if available. */ #define atomic_exchange_explicit(object, desired, order) \ ((void)(order), __sync_swap(&(object)->__val, desired)) #else /* * __sync_lock_test_and_set() is only an acquire barrier in theory (although in * practice it is usually a full barrier) so we need an explicit barrier before * it. */ #define atomic_exchange_explicit(object, desired, order) \ __extension__ ({ \ __typeof__(object) __o = (object); \ __typeof__(desired) __d = (desired); \ (void)(order); \ __sync_synchronize(); \ __sync_lock_test_and_set(&(__o)->__val, __d); \ }) #endif #define atomic_fetch_add_explicit(object, operand, order) \ ((void)(order), __sync_fetch_and_add(&(object)->__val, \ __atomic_apply_stride(object, operand))) #define atomic_fetch_and_explicit(object, operand, order) \ ((void)(order), __sync_fetch_and_and(&(object)->__val, operand)) #define atomic_fetch_or_explicit(object, operand, order) \ ((void)(order), __sync_fetch_and_or(&(object)->__val, operand)) #define atomic_fetch_sub_explicit(object, operand, order) \ ((void)(order), __sync_fetch_and_sub(&(object)->__val, \ __atomic_apply_stride(object, operand))) #define atomic_fetch_xor_explicit(object, operand, order) \ ((void)(order), __sync_fetch_and_xor(&(object)->__val, operand)) #define atomic_load_explicit(object, order) \ ((void)(order), __sync_fetch_and_add(&(object)->__val, 0)) #define atomic_store_explicit(object, desired, order) \ ((void)atomic_exchange_explicit(object, desired, order)) #endif /* * Convenience functions. * * Don't provide these in kernel space. In kernel space, we should be * disciplined enough to always provide explicit barriers. */ #ifndef _KERNEL #define atomic_compare_exchange_strong(object, expected, desired) \ atomic_compare_exchange_strong_explicit(object, expected, \ desired, memory_order_seq_cst, memory_order_seq_cst) #define atomic_compare_exchange_weak(object, expected, desired) \ atomic_compare_exchange_weak_explicit(object, expected, \ desired, memory_order_seq_cst, memory_order_seq_cst) #define atomic_exchange(object, desired) \ atomic_exchange_explicit(object, desired, memory_order_seq_cst) #define atomic_fetch_add(object, operand) \ atomic_fetch_add_explicit(object, operand, memory_order_seq_cst) #define atomic_fetch_and(object, operand) \ atomic_fetch_and_explicit(object, operand, memory_order_seq_cst) #define atomic_fetch_or(object, operand) \ atomic_fetch_or_explicit(object, operand, memory_order_seq_cst) #define atomic_fetch_sub(object, operand) \ atomic_fetch_sub_explicit(object, operand, memory_order_seq_cst) #define atomic_fetch_xor(object, operand) \ atomic_fetch_xor_explicit(object, operand, memory_order_seq_cst) #define atomic_load(object) \ atomic_load_explicit(object, memory_order_seq_cst) #define atomic_store(object, desired) \ atomic_store_explicit(object, desired, memory_order_seq_cst) #endif /* !_KERNEL */ /* * 7.17.8 Atomic flag type and operations. * * XXX: Assume atomic_bool can be used as an atomic_flag. Is there some * kind of compiler built-in type we could use? */ typedef struct { atomic_bool __flag; } atomic_flag; #define ATOMIC_FLAG_INIT { ATOMIC_VAR_INIT(0) } static __inline _Bool atomic_flag_test_and_set_explicit(volatile atomic_flag *__object, memory_order __order) { return (atomic_exchange_explicit(&__object->__flag, 1, __order)); } static __inline void atomic_flag_clear_explicit(volatile atomic_flag *__object, memory_order __order) { atomic_store_explicit(&__object->__flag, 0, __order); } #ifndef _KERNEL static __inline _Bool atomic_flag_test_and_set(volatile atomic_flag *__object) { return (atomic_flag_test_and_set_explicit(__object, memory_order_seq_cst)); } static __inline void atomic_flag_clear(volatile atomic_flag *__object) { atomic_flag_clear_explicit(__object, memory_order_seq_cst); } #endif /* !_KERNEL */ #endif /* !_STDATOMIC_H_ */ 0707010000003c000081a40000000000000000000000016181423c00003634000000000000000000000000000000000000002200000000./usr/nvptx-none/include/stdint.h/* * Copyright (c) 2004, 2005 by * Ralf Corsepius, Ulm/Germany. All rights reserved. * * Permission to use, copy, modify, and distribute this software * is freely granted, provided that this notice is preserved. */ #ifndef _STDINT_H #define _STDINT_H #include #ifdef __cplusplus extern "C" { #endif #if __GNUC_PREREQ (3, 2) /* gcc > 3.2 implicitly defines the values we are interested */ #define __STDINT_EXP(x) __##x##__ #else #define __STDINT_EXP(x) x #include #endif /* Check if "long long" is 64bit wide */ /* Modern GCCs provide __LONG_LONG_MAX__, SUSv3 wants LLONG_MAX */ #if ( defined(__LONG_LONG_MAX__) && (__LONG_LONG_MAX__ > 0x7fffffff) ) \ || ( defined(LLONG_MAX) && (LLONG_MAX > 0x7fffffff) ) #define __have_longlong64 1 #endif /* Check if "long" is 64bit or 32bit wide */ #if __STDINT_EXP(LONG_MAX) > 0x7fffffff #define __have_long64 1 #elif __STDINT_EXP(LONG_MAX) == 0x7fffffff && !defined(__SPU__) #define __have_long32 1 #endif #ifdef ___int8_t_defined typedef __int8_t int8_t ; typedef __uint8_t uint8_t ; #define __int8_t_defined 1 #endif #ifdef ___int_least8_t_defined typedef __int_least8_t int_least8_t; typedef __uint_least8_t uint_least8_t; #define __int_least8_t_defined 1 #endif #ifdef ___int16_t_defined typedef __int16_t int16_t ; typedef __uint16_t uint16_t ; #define __int16_t_defined 1 #endif #ifdef ___int_least16_t_defined typedef __int_least16_t int_least16_t; typedef __uint_least16_t uint_least16_t; #define __int_least16_t_defined 1 #endif #ifdef ___int32_t_defined typedef __int32_t int32_t ; typedef __uint32_t uint32_t ; #define __int32_t_defined 1 #endif #ifdef ___int_least32_t_defined typedef __int_least32_t int_least32_t; typedef __uint_least32_t uint_least32_t; #define __int_least32_t_defined 1 #endif #ifdef ___int64_t_defined typedef __int64_t int64_t ; typedef __uint64_t uint64_t ; #define __int64_t_defined 1 #endif #ifdef ___int_least64_t_defined typedef __int_least64_t int_least64_t; typedef __uint_least64_t uint_least64_t; #define __int_least64_t_defined 1 #endif /* * Fastest minimum-width integer types * * Assume int to be the fastest type for all types with a width * less than __INT_MAX__ rsp. INT_MAX */ #ifdef __INT_FAST8_TYPE__ typedef __INT_FAST8_TYPE__ int_fast8_t; typedef __UINT_FAST8_TYPE__ uint_fast8_t; #define __int_fast8_t_defined 1 #elif __STDINT_EXP(INT_MAX) >= 0x7f typedef signed int int_fast8_t; typedef unsigned int uint_fast8_t; #define __int_fast8_t_defined 1 #endif #ifdef __INT_FAST16_TYPE__ typedef __INT_FAST16_TYPE__ int_fast16_t; typedef __UINT_FAST16_TYPE__ uint_fast16_t; #define __int_fast16_t_defined 1 #elif __STDINT_EXP(INT_MAX) >= 0x7fff typedef signed int int_fast16_t; typedef unsigned int uint_fast16_t; #define __int_fast16_t_defined 1 #endif #ifdef __INT_FAST32_TYPE__ typedef __INT_FAST32_TYPE__ int_fast32_t; typedef __UINT_FAST32_TYPE__ uint_fast32_t; #define __int_fast32_t_defined 1 #elif __STDINT_EXP(INT_MAX) >= 0x7fffffff typedef signed int int_fast32_t; typedef unsigned int uint_fast32_t; #define __int_fast32_t_defined 1 #endif #ifdef __INT_FAST64_TYPE__ typedef __INT_FAST64_TYPE__ int_fast64_t; typedef __UINT_FAST64_TYPE__ uint_fast64_t; #define __int_fast64_t_defined 1 #elif __STDINT_EXP(INT_MAX) > 0x7fffffff typedef signed int int_fast64_t; typedef unsigned int uint_fast64_t; #define __int_fast64_t_defined 1 #endif /* * Fall back to [u]int_least_t for [u]int_fast_t types * not having been defined, yet. * Leave undefined, if [u]int_least_t should not be available. */ #if !__int_fast8_t_defined #if __int_least8_t_defined typedef int_least8_t int_fast8_t; typedef uint_least8_t uint_fast8_t; #define __int_fast8_t_defined 1 #endif #endif #if !__int_fast16_t_defined #if __int_least16_t_defined typedef int_least16_t int_fast16_t; typedef uint_least16_t uint_fast16_t; #define __int_fast16_t_defined 1 #endif #endif #if !__int_fast32_t_defined #if __int_least32_t_defined typedef int_least32_t int_fast32_t; typedef uint_least32_t uint_fast32_t; #define __int_fast32_t_defined 1 #endif #endif #if !__int_fast64_t_defined #if __int_least64_t_defined typedef int_least64_t int_fast64_t; typedef uint_least64_t uint_fast64_t; #define __int_fast64_t_defined 1 #endif #endif /* Greatest-width integer types */ /* Modern GCCs provide __INTMAX_TYPE__ */ #if defined(__INTMAX_TYPE__) typedef __INTMAX_TYPE__ intmax_t; #elif __have_longlong64 typedef signed long long intmax_t; #else typedef signed long intmax_t; #endif /* Modern GCCs provide __UINTMAX_TYPE__ */ #if defined(__UINTMAX_TYPE__) typedef __UINTMAX_TYPE__ uintmax_t; #elif __have_longlong64 typedef unsigned long long uintmax_t; #else typedef unsigned long uintmax_t; #endif typedef __intptr_t intptr_t; typedef __uintptr_t uintptr_t; #ifdef __INTPTR_TYPE__ #define INTPTR_MIN (-__INTPTR_MAX__ - 1) #define INTPTR_MAX __INTPTR_MAX__ #define UINTPTR_MAX __UINTPTR_MAX__ #elif defined(__PTRDIFF_TYPE__) #define INTPTR_MAX PTRDIFF_MAX #define INTPTR_MIN PTRDIFF_MIN #ifdef __UINTPTR_MAX__ #define UINTPTR_MAX __UINTPTR_MAX__ #else #define UINTPTR_MAX (2UL * PTRDIFF_MAX + 1) #endif #else /* * Fallback to hardcoded values, * should be valid on cpu's with 32bit int/32bit void* */ #define INTPTR_MAX __STDINT_EXP(LONG_MAX) #define INTPTR_MIN (-__STDINT_EXP(LONG_MAX) - 1) #define UINTPTR_MAX (__STDINT_EXP(LONG_MAX) * 2UL + 1) #endif /* Limits of Specified-Width Integer Types */ #ifdef __INT8_MAX__ #define INT8_MIN (-__INT8_MAX__ - 1) #define INT8_MAX __INT8_MAX__ #define UINT8_MAX __UINT8_MAX__ #elif defined(__int8_t_defined) #define INT8_MIN -128 #define INT8_MAX 127 #define UINT8_MAX 255 #endif #ifdef __INT_LEAST8_MAX__ #define INT_LEAST8_MIN (-__INT_LEAST8_MAX__ - 1) #define INT_LEAST8_MAX __INT_LEAST8_MAX__ #define UINT_LEAST8_MAX __UINT_LEAST8_MAX__ #elif defined(__int_least8_t_defined) #define INT_LEAST8_MIN -128 #define INT_LEAST8_MAX 127 #define UINT_LEAST8_MAX 255 #else #error required type int_least8_t missing #endif #ifdef __INT16_MAX__ #define INT16_MIN (-__INT16_MAX__ - 1) #define INT16_MAX __INT16_MAX__ #define UINT16_MAX __UINT16_MAX__ #elif defined(__int16_t_defined) #define INT16_MIN -32768 #define INT16_MAX 32767 #define UINT16_MAX 65535 #endif #ifdef __INT_LEAST16_MAX__ #define INT_LEAST16_MIN (-__INT_LEAST16_MAX__ - 1) #define INT_LEAST16_MAX __INT_LEAST16_MAX__ #define UINT_LEAST16_MAX __UINT_LEAST16_MAX__ #elif defined(__int_least16_t_defined) #define INT_LEAST16_MIN -32768 #define INT_LEAST16_MAX 32767 #define UINT_LEAST16_MAX 65535 #else #error required type int_least16_t missing #endif #ifdef __INT32_MAX__ #define INT32_MIN (-__INT32_MAX__ - 1) #define INT32_MAX __INT32_MAX__ #define UINT32_MAX __UINT32_MAX__ #elif defined(__int32_t_defined) #if __have_long32 #define INT32_MIN (-2147483647L-1) #define INT32_MAX 2147483647L #define UINT32_MAX 4294967295UL #else #define INT32_MIN (-2147483647-1) #define INT32_MAX 2147483647 #define UINT32_MAX 4294967295U #endif #endif #ifdef __INT_LEAST32_MAX__ #define INT_LEAST32_MIN (-__INT_LEAST32_MAX__ - 1) #define INT_LEAST32_MAX __INT_LEAST32_MAX__ #define UINT_LEAST32_MAX __UINT_LEAST32_MAX__ #elif defined(__int_least32_t_defined) #if __have_long32 #define INT_LEAST32_MIN (-2147483647L-1) #define INT_LEAST32_MAX 2147483647L #define UINT_LEAST32_MAX 4294967295UL #else #define INT_LEAST32_MIN (-2147483647-1) #define INT_LEAST32_MAX 2147483647 #define UINT_LEAST32_MAX 4294967295U #endif #else #error required type int_least32_t missing #endif #ifdef __INT64_MAX__ #define INT64_MIN (-__INT64_MAX__ - 1) #define INT64_MAX __INT64_MAX__ #define UINT64_MAX __UINT64_MAX__ #elif defined(__int64_t_defined) #if __have_long64 #define INT64_MIN (-9223372036854775807L-1L) #define INT64_MAX 9223372036854775807L #define UINT64_MAX 18446744073709551615U #elif __have_longlong64 #define INT64_MIN (-9223372036854775807LL-1LL) #define INT64_MAX 9223372036854775807LL #define UINT64_MAX 18446744073709551615ULL #endif #endif #ifdef __INT_LEAST64_MAX__ #define INT_LEAST64_MIN (-__INT_LEAST64_MAX__ - 1) #define INT_LEAST64_MAX __INT_LEAST64_MAX__ #define UINT_LEAST64_MAX __UINT_LEAST64_MAX__ #elif defined(__int_least64_t_defined) #if __have_long64 #define INT_LEAST64_MIN (-9223372036854775807L-1L) #define INT_LEAST64_MAX 9223372036854775807L #define UINT_LEAST64_MAX 18446744073709551615U #elif __have_longlong64 #define INT_LEAST64_MIN (-9223372036854775807LL-1LL) #define INT_LEAST64_MAX 9223372036854775807LL #define UINT_LEAST64_MAX 18446744073709551615ULL #endif #endif #ifdef __INT_FAST8_MAX__ #define INT_FAST8_MIN (-__INT_FAST8_MAX__ - 1) #define INT_FAST8_MAX __INT_FAST8_MAX__ #define UINT_FAST8_MAX __UINT_FAST8_MAX__ #elif defined(__int_fast8_t_defined) #if __STDINT_EXP(INT_MAX) >= 0x7f #define INT_FAST8_MIN (-__STDINT_EXP(INT_MAX)-1) #define INT_FAST8_MAX __STDINT_EXP(INT_MAX) #define UINT_FAST8_MAX (__STDINT_EXP(INT_MAX)*2U+1U) #else #define INT_FAST8_MIN INT_LEAST8_MIN #define INT_FAST8_MAX INT_LEAST8_MAX #define UINT_FAST8_MAX UINT_LEAST8_MAX #endif #endif #ifdef __INT_FAST16_MAX__ #define INT_FAST16_MIN (-__INT_FAST16_MAX__ - 1) #define INT_FAST16_MAX __INT_FAST16_MAX__ #define UINT_FAST16_MAX __UINT_FAST16_MAX__ #elif defined(__int_fast16_t_defined) #if __STDINT_EXP(INT_MAX) >= 0x7fff #define INT_FAST16_MIN (-__STDINT_EXP(INT_MAX)-1) #define INT_FAST16_MAX __STDINT_EXP(INT_MAX) #define UINT_FAST16_MAX (__STDINT_EXP(INT_MAX)*2U+1U) #else #define INT_FAST16_MIN INT_LEAST16_MIN #define INT_FAST16_MAX INT_LEAST16_MAX #define UINT_FAST16_MAX UINT_LEAST16_MAX #endif #endif #ifdef __INT_FAST32_MAX__ #define INT_FAST32_MIN (-__INT_FAST32_MAX__ - 1) #define INT_FAST32_MAX __INT_FAST32_MAX__ #define UINT_FAST32_MAX __UINT_FAST32_MAX__ #elif defined(__int_fast32_t_defined) #if __STDINT_EXP(INT_MAX) >= 0x7fffffff #define INT_FAST32_MIN (-__STDINT_EXP(INT_MAX)-1) #define INT_FAST32_MAX __STDINT_EXP(INT_MAX) #define UINT_FAST32_MAX (__STDINT_EXP(INT_MAX)*2U+1U) #else #define INT_FAST32_MIN INT_LEAST32_MIN #define INT_FAST32_MAX INT_LEAST32_MAX #define UINT_FAST32_MAX UINT_LEAST32_MAX #endif #endif #ifdef __INT_FAST64_MAX__ #define INT_FAST64_MIN (-__INT_FAST64_MAX__ - 1) #define INT_FAST64_MAX __INT_FAST64_MAX__ #define UINT_FAST64_MAX __UINT_FAST64_MAX__ #elif defined(__int_fast64_t_defined) #if __STDINT_EXP(INT_MAX) > 0x7fffffff #define INT_FAST64_MIN (-__STDINT_EXP(INT_MAX)-1) #define INT_FAST64_MAX __STDINT_EXP(INT_MAX) #define UINT_FAST64_MAX (__STDINT_EXP(INT_MAX)*2U+1U) #else #define INT_FAST64_MIN INT_LEAST64_MIN #define INT_FAST64_MAX INT_LEAST64_MAX #define UINT_FAST64_MAX UINT_LEAST64_MAX #endif #endif #ifdef __INTMAX_MAX__ #define INTMAX_MAX __INTMAX_MAX__ #define INTMAX_MIN (-INTMAX_MAX - 1) #elif defined(__INTMAX_TYPE__) /* All relevant GCC versions prefer long to long long for intmax_t. */ #define INTMAX_MAX INT64_MAX #define INTMAX_MIN INT64_MIN #endif #ifdef __UINTMAX_MAX__ #define UINTMAX_MAX __UINTMAX_MAX__ #elif defined(__UINTMAX_TYPE__) /* All relevant GCC versions prefer long to long long for intmax_t. */ #define UINTMAX_MAX UINT64_MAX #endif /* This must match size_t in stddef.h, currently long unsigned int */ #ifdef __SIZE_MAX__ #define SIZE_MAX __SIZE_MAX__ #else #define SIZE_MAX (__STDINT_EXP(LONG_MAX) * 2UL + 1) #endif /* This must match sig_atomic_t in (currently int) */ #define SIG_ATOMIC_MIN (-__STDINT_EXP(INT_MAX) - 1) #define SIG_ATOMIC_MAX __STDINT_EXP(INT_MAX) /* This must match ptrdiff_t in (currently long int) */ #ifdef __PTRDIFF_MAX__ #define PTRDIFF_MAX __PTRDIFF_MAX__ #else #define PTRDIFF_MAX __STDINT_EXP(LONG_MAX) #endif #define PTRDIFF_MIN (-PTRDIFF_MAX - 1) /* This must match definition in */ #ifndef WCHAR_MIN #ifdef __WCHAR_MIN__ #define WCHAR_MIN __WCHAR_MIN__ #elif defined(__WCHAR_UNSIGNED__) || (L'\0' - 1 > 0) #define WCHAR_MIN (0 + L'\0') #else #define WCHAR_MIN (-0x7fffffff - 1 + L'\0') #endif #endif /* This must match definition in */ #ifndef WCHAR_MAX #ifdef __WCHAR_MAX__ #define WCHAR_MAX __WCHAR_MAX__ #elif defined(__WCHAR_UNSIGNED__) || (L'\0' - 1 > 0) #define WCHAR_MAX (0xffffffffu + L'\0') #else #define WCHAR_MAX (0x7fffffff + L'\0') #endif #endif /* wint_t is unsigned int on almost all GCC targets. */ #ifdef __WINT_MAX__ #define WINT_MAX __WINT_MAX__ #else #define WINT_MAX (__STDINT_EXP(INT_MAX) * 2U + 1U) #endif #ifdef __WINT_MIN__ #define WINT_MIN __WINT_MIN__ #else #define WINT_MIN 0U #endif /** Macros for minimum-width integer constant expressions */ #ifdef __INT8_C #define INT8_C(x) __INT8_C(x) #define UINT8_C(x) __UINT8_C(x) #else #define INT8_C(x) x #if __STDINT_EXP(INT_MAX) > 0x7f #define UINT8_C(x) x #else #define UINT8_C(x) x##U #endif #endif #ifdef __INT16_C #define INT16_C(x) __INT16_C(x) #define UINT16_C(x) __UINT16_C(x) #else #define INT16_C(x) x #if __STDINT_EXP(INT_MAX) > 0x7fff #define UINT16_C(x) x #else #define UINT16_C(x) x##U #endif #endif #ifdef __INT32_C #define INT32_C(x) __INT32_C(x) #define UINT32_C(x) __UINT32_C(x) #else #if __have_long32 #define INT32_C(x) x##L #define UINT32_C(x) x##UL #else #define INT32_C(x) x #define UINT32_C(x) x##U #endif #endif #ifdef __INT64_C #define INT64_C(x) __INT64_C(x) #define UINT64_C(x) __UINT64_C(x) #else #if __int64_t_defined #if __have_long64 #define INT64_C(x) x##L #define UINT64_C(x) x##UL #else #define INT64_C(x) x##LL #define UINT64_C(x) x##ULL #endif #endif #endif /** Macros for greatest-width integer constant expression */ #ifdef __INTMAX_C #define INTMAX_C(x) __INTMAX_C(x) #define UINTMAX_C(x) __UINTMAX_C(x) #else #if __have_long64 #define INTMAX_C(x) x##L #define UINTMAX_C(x) x##UL #else #define INTMAX_C(x) x##LL #define UINTMAX_C(x) x##ULL #endif #endif #ifdef __cplusplus } #endif #endif /* _STDINT_H */ 0707010000003d000081a40000000000000000000000016181423c00006f99000000000000000000000000000000000000002100000000./usr/nvptx-none/include/stdio.h/* * Copyright (c) 1990 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that the above copyright notice and this paragraph are * duplicated in all such forms and that any documentation, * advertising materials, and other materials related to such * distribution and use acknowledge that the software was developed * by the University of California, Berkeley. The name of the * University may not be used to endorse or promote products derived * from this software without specific prior written permission. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. * * @(#)stdio.h 5.3 (Berkeley) 3/15/86 */ /* * NB: to fit things in six character monocase externals, the * stdio code uses the prefix `__s' for stdio objects, typically * followed by a three-character attempt at a mnemonic. */ #ifndef _STDIO_H_ #define _STDIO_H_ #include "_ansi.h" #define _FSTDIO /* ``function stdio'' */ #define __need_size_t #define __need_NULL #include #include #define __need___va_list #include /* * defines __FILE, _fpos_t. * They must be defined there because struct _reent needs them (and we don't * want reent.h to include this file. */ #include #include _BEGIN_STD_C typedef __FILE FILE; #ifdef __CYGWIN__ typedef _fpos64_t fpos_t; #else typedef _fpos_t fpos_t; #ifdef __LARGE64_FILES typedef _fpos64_t fpos64_t; #endif #endif /* !__CYGWIN__ */ #include #define __SLBF 0x0001 /* line buffered */ #define __SNBF 0x0002 /* unbuffered */ #define __SRD 0x0004 /* OK to read */ #define __SWR 0x0008 /* OK to write */ /* RD and WR are never simultaneously asserted */ #define __SRW 0x0010 /* open for reading & writing */ #define __SEOF 0x0020 /* found EOF */ #define __SERR 0x0040 /* found error */ #define __SMBF 0x0080 /* _buf is from malloc */ #define __SAPP 0x0100 /* fdopen()ed in append mode - so must write to end */ #define __SSTR 0x0200 /* this is an sprintf/snprintf string */ #define __SOPT 0x0400 /* do fseek() optimisation */ #define __SNPT 0x0800 /* do not do fseek() optimisation */ #define __SOFF 0x1000 /* set iff _offset is in fact correct */ #define __SORD 0x2000 /* true => stream orientation (byte/wide) decided */ #if defined(__CYGWIN__) # define __SCLE 0x4000 /* convert line endings CR/LF <-> NL */ #endif #define __SL64 0x8000 /* is 64-bit offset large file */ /* _flags2 flags */ #define __SWID 0x2000 /* true => stream orientation wide, false => byte, only valid if __SORD in _flags is true */ /* * The following three definitions are for ANSI C, which took them * from System V, which stupidly took internal interface macros and * made them official arguments to setvbuf(), without renaming them. * Hence, these ugly _IOxxx names are *supposed* to appear in user code. * * Although these happen to match their counterparts above, the * implementation does not rely on that (so these could be renumbered). */ #define _IOFBF 0 /* setvbuf should set fully buffered */ #define _IOLBF 1 /* setvbuf should set line buffered */ #define _IONBF 2 /* setvbuf should set unbuffered */ #define EOF (-1) #ifdef __BUFSIZ__ #define BUFSIZ __BUFSIZ__ #else #define BUFSIZ 1024 #endif #ifdef __FOPEN_MAX__ #define FOPEN_MAX __FOPEN_MAX__ #else #define FOPEN_MAX 20 #endif #ifdef __FILENAME_MAX__ #define FILENAME_MAX __FILENAME_MAX__ #else #define FILENAME_MAX 1024 #endif #ifdef __L_tmpnam__ #define L_tmpnam __L_tmpnam__ #else #define L_tmpnam FILENAME_MAX #endif #ifndef __STRICT_ANSI__ #define P_tmpdir "/tmp" #endif #ifndef SEEK_SET #define SEEK_SET 0 /* set file offset to offset */ #endif #ifndef SEEK_CUR #define SEEK_CUR 1 /* set file offset to current plus offset */ #endif #ifndef SEEK_END #define SEEK_END 2 /* set file offset to EOF plus offset */ #endif #define TMP_MAX 26 #define stdin (_REENT->_stdin) #define stdout (_REENT->_stdout) #define stderr (_REENT->_stderr) #define _stdin_r(x) ((x)->_stdin) #define _stdout_r(x) ((x)->_stdout) #define _stderr_r(x) ((x)->_stderr) /* * Functions defined in ANSI C standard. */ #ifndef __VALIST #ifdef __GNUC__ #define __VALIST __gnuc_va_list #else #define __VALIST char* #endif #endif FILE * _EXFUN(tmpfile, (void)); char * _EXFUN(tmpnam, (char *)); #if __BSD_VISIBLE || __XSI_VISIBLE || __POSIX_VISIBLE >= 200112 char * _EXFUN(tempnam, (const char *, const char *)); #endif int _EXFUN(fclose, (FILE *)); int _EXFUN(fflush, (FILE *)); FILE * _EXFUN(freopen, (const char *__restrict, const char *__restrict, FILE *__restrict)); void _EXFUN(setbuf, (FILE *__restrict, char *__restrict)); int _EXFUN(setvbuf, (FILE *__restrict, char *__restrict, int, size_t)); int _EXFUN(fprintf, (FILE *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); int _EXFUN(fscanf, (FILE *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__scanf__, 2, 3)))); int _EXFUN(printf, (const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 1, 2)))); int _EXFUN(scanf, (const char *__restrict, ...) _ATTRIBUTE ((__format__ (__scanf__, 1, 2)))); int _EXFUN(sscanf, (const char *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__scanf__, 2, 3)))); int _EXFUN(vfprintf, (FILE *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(vprintf, (const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 1, 0)))); int _EXFUN(vsprintf, (char *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(fgetc, (FILE *)); char * _EXFUN(fgets, (char *__restrict, int, FILE *__restrict)); int _EXFUN(fputc, (int, FILE *)); int _EXFUN(fputs, (const char *__restrict, FILE *__restrict)); int _EXFUN(getc, (FILE *)); int _EXFUN(getchar, (void)); char * _EXFUN(gets, (char *)); int _EXFUN(putc, (int, FILE *)); int _EXFUN(putchar, (int)); int _EXFUN(puts, (const char *)); int _EXFUN(ungetc, (int, FILE *)); size_t _EXFUN(fread, (_PTR __restrict, size_t _size, size_t _n, FILE *__restrict)); size_t _EXFUN(fwrite, (const _PTR __restrict , size_t _size, size_t _n, FILE *)); #ifdef _COMPILING_NEWLIB int _EXFUN(fgetpos, (FILE *, _fpos_t *)); #else int _EXFUN(fgetpos, (FILE *__restrict, fpos_t *__restrict)); #endif int _EXFUN(fseek, (FILE *, long, int)); #ifdef _COMPILING_NEWLIB int _EXFUN(fsetpos, (FILE *, const _fpos_t *)); #else int _EXFUN(fsetpos, (FILE *, const fpos_t *)); #endif long _EXFUN(ftell, ( FILE *)); void _EXFUN(rewind, (FILE *)); void _EXFUN(clearerr, (FILE *)); int _EXFUN(feof, (FILE *)); int _EXFUN(ferror, (FILE *)); void _EXFUN(perror, (const char *)); #ifndef _REENT_ONLY FILE * _EXFUN(fopen, (const char *__restrict _name, const char *__restrict _type)); int _EXFUN(sprintf, (char *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); int _EXFUN(remove, (const char *)); int _EXFUN(rename, (const char *, const char *)); #ifdef _COMPILING_NEWLIB int _EXFUN(_rename, (const char *, const char *)); #endif #endif #if !defined(__STRICT_ANSI__) || defined(__USE_XOPEN2K) #ifdef _COMPILING_NEWLIB int _EXFUN(fseeko, (FILE *, _off_t, int)); _off_t _EXFUN(ftello, ( FILE *)); #else int _EXFUN(fseeko, (FILE *, off_t, int)); off_t _EXFUN(ftello, ( FILE *)); #endif #endif #if __GNU_VISIBLE int _EXFUN(fcloseall, (_VOID)); #endif #if !defined(__STRICT_ANSI__) || (__STDC_VERSION__ >= 199901L) || (__cplusplus >= 201103L) #ifndef _REENT_ONLY int _EXFUN(asiprintf, (char **, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); char * _EXFUN(asniprintf, (char *, size_t *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); char * _EXFUN(asnprintf, (char *__restrict, size_t *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(asprintf, (char **__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); #ifndef diprintf int _EXFUN(diprintf, (int, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); #endif int _EXFUN(fiprintf, (FILE *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); int _EXFUN(fiscanf, (FILE *, const char *, ...) _ATTRIBUTE ((__format__ (__scanf__, 2, 3)))); int _EXFUN(iprintf, (const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 1, 2)))); int _EXFUN(iscanf, (const char *, ...) _ATTRIBUTE ((__format__ (__scanf__, 1, 2)))); int _EXFUN(siprintf, (char *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); int _EXFUN(siscanf, (const char *, const char *, ...) _ATTRIBUTE ((__format__ (__scanf__, 2, 3)))); int _EXFUN(snprintf, (char *__restrict, size_t, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(sniprintf, (char *, size_t, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(vasiprintf, (char **, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); char * _EXFUN(vasniprintf, (char *, size_t *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); char * _EXFUN(vasnprintf, (char *, size_t *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(vasprintf, (char **, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(vdiprintf, (int, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(vfiprintf, (FILE *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(vfiscanf, (FILE *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 2, 0)))); int _EXFUN(vfscanf, (FILE *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 2, 0)))); int _EXFUN(viprintf, (const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 1, 0)))); int _EXFUN(viscanf, (const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 1, 0)))); int _EXFUN(vscanf, (const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 1, 0)))); int _EXFUN(vsiprintf, (char *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(vsiscanf, (const char *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 2, 0)))); int _EXFUN(vsniprintf, (char *, size_t, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(vsnprintf, (char *__restrict, size_t, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(vsscanf, (const char *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 2, 0)))); #endif /* !_REENT_ONLY */ #endif /* !__STRICT_ANSI__ */ /* * Routines in POSIX 1003.1:2001. */ #ifndef __STRICT_ANSI__ #ifndef _REENT_ONLY FILE * _EXFUN(fdopen, (int, const char *)); #endif int _EXFUN(fileno, (FILE *)); int _EXFUN(getw, (FILE *)); int _EXFUN(pclose, (FILE *)); FILE * _EXFUN(popen, (const char *, const char *)); int _EXFUN(putw, (int, FILE *)); void _EXFUN(setbuffer, (FILE *, char *, int)); int _EXFUN(setlinebuf, (FILE *)); int _EXFUN(getc_unlocked, (FILE *)); int _EXFUN(getchar_unlocked, (void)); void _EXFUN(flockfile, (FILE *)); int _EXFUN(ftrylockfile, (FILE *)); void _EXFUN(funlockfile, (FILE *)); int _EXFUN(putc_unlocked, (int, FILE *)); int _EXFUN(putchar_unlocked, (int)); #endif /* ! __STRICT_ANSI__ */ /* * Routines in POSIX 1003.1:200x. */ #ifndef __STRICT_ANSI__ # ifndef _REENT_ONLY # ifndef dprintf int _EXFUN(dprintf, (int, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); # endif FILE * _EXFUN(fmemopen, (void *__restrict, size_t, const char *__restrict)); /* getdelim - see __getdelim for now */ /* getline - see __getline for now */ FILE * _EXFUN(open_memstream, (char **, size_t *)); #if __BSD_VISIBLE || __POSIX_VISIBLE >= 200809 int _EXFUN(renameat, (int, const char *, int, const char *)); #endif int _EXFUN(vdprintf, (int, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); # endif #endif /* * Recursive versions of the above. */ int _EXFUN(_asiprintf_r, (struct _reent *, char **, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); char * _EXFUN(_asniprintf_r, (struct _reent *, char *, size_t *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 4, 5)))); char * _EXFUN(_asnprintf_r, (struct _reent *, char *__restrict, size_t *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 4, 5)))); int _EXFUN(_asprintf_r, (struct _reent *, char **__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_diprintf_r, (struct _reent *, int, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_dprintf_r, (struct _reent *, int, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_fclose_r, (struct _reent *, FILE *)); int _EXFUN(_fcloseall_r, (struct _reent *)); FILE * _EXFUN(_fdopen_r, (struct _reent *, int, const char *)); int _EXFUN(_fflush_r, (struct _reent *, FILE *)); int _EXFUN(_fgetc_r, (struct _reent *, FILE *)); char * _EXFUN(_fgets_r, (struct _reent *, char *__restrict, int, FILE *__restrict)); #ifdef _COMPILING_NEWLIB int _EXFUN(_fgetpos_r, (struct _reent *, FILE *__restrict, _fpos_t *__restrict)); int _EXFUN(_fsetpos_r, (struct _reent *, FILE *, const _fpos_t *)); #else int _EXFUN(_fgetpos_r, (struct _reent *, FILE *, fpos_t *)); int _EXFUN(_fsetpos_r, (struct _reent *, FILE *, const fpos_t *)); #endif int _EXFUN(_fiprintf_r, (struct _reent *, FILE *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_fiscanf_r, (struct _reent *, FILE *, const char *, ...) _ATTRIBUTE ((__format__ (__scanf__, 3, 4)))); FILE * _EXFUN(_fmemopen_r, (struct _reent *, void *__restrict, size_t, const char *__restrict)); FILE * _EXFUN(_fopen_r, (struct _reent *, const char *__restrict, const char *__restrict)); FILE * _EXFUN(_freopen_r, (struct _reent *, const char *__restrict, const char *__restrict, FILE *__restrict)); int _EXFUN(_fprintf_r, (struct _reent *, FILE *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_fpurge_r, (struct _reent *, FILE *)); int _EXFUN(_fputc_r, (struct _reent *, int, FILE *)); int _EXFUN(_fputs_r, (struct _reent *, const char *__restrict, FILE *__restrict)); size_t _EXFUN(_fread_r, (struct _reent *, _PTR __restrict, size_t _size, size_t _n, FILE *__restrict)); int _EXFUN(_fscanf_r, (struct _reent *, FILE *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__scanf__, 3, 4)))); int _EXFUN(_fseek_r, (struct _reent *, FILE *, long, int)); int _EXFUN(_fseeko_r,(struct _reent *, FILE *, _off_t, int)); long _EXFUN(_ftell_r, (struct _reent *, FILE *)); _off_t _EXFUN(_ftello_r,(struct _reent *, FILE *)); void _EXFUN(_rewind_r, (struct _reent *, FILE *)); size_t _EXFUN(_fwrite_r, (struct _reent *, const _PTR __restrict, size_t _size, size_t _n, FILE *__restrict)); int _EXFUN(_getc_r, (struct _reent *, FILE *)); int _EXFUN(_getc_unlocked_r, (struct _reent *, FILE *)); int _EXFUN(_getchar_r, (struct _reent *)); int _EXFUN(_getchar_unlocked_r, (struct _reent *)); char * _EXFUN(_gets_r, (struct _reent *, char *)); int _EXFUN(_iprintf_r, (struct _reent *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); int _EXFUN(_iscanf_r, (struct _reent *, const char *, ...) _ATTRIBUTE ((__format__ (__scanf__, 2, 3)))); FILE * _EXFUN(_open_memstream_r, (struct _reent *, char **, size_t *)); void _EXFUN(_perror_r, (struct _reent *, const char *)); int _EXFUN(_printf_r, (struct _reent *, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 2, 3)))); int _EXFUN(_putc_r, (struct _reent *, int, FILE *)); int _EXFUN(_putc_unlocked_r, (struct _reent *, int, FILE *)); int _EXFUN(_putchar_unlocked_r, (struct _reent *, int)); int _EXFUN(_putchar_r, (struct _reent *, int)); int _EXFUN(_puts_r, (struct _reent *, const char *)); int _EXFUN(_remove_r, (struct _reent *, const char *)); int _EXFUN(_rename_r, (struct _reent *, const char *_old, const char *_new)); int _EXFUN(_scanf_r, (struct _reent *, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__scanf__, 2, 3)))); int _EXFUN(_siprintf_r, (struct _reent *, char *, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_siscanf_r, (struct _reent *, const char *, const char *, ...) _ATTRIBUTE ((__format__ (__scanf__, 3, 4)))); int _EXFUN(_sniprintf_r, (struct _reent *, char *, size_t, const char *, ...) _ATTRIBUTE ((__format__ (__printf__, 4, 5)))); int _EXFUN(_snprintf_r, (struct _reent *, char *__restrict, size_t, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 4, 5)))); int _EXFUN(_sprintf_r, (struct _reent *, char *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__printf__, 3, 4)))); int _EXFUN(_sscanf_r, (struct _reent *, const char *__restrict, const char *__restrict, ...) _ATTRIBUTE ((__format__ (__scanf__, 3, 4)))); char * _EXFUN(_tempnam_r, (struct _reent *, const char *, const char *)); FILE * _EXFUN(_tmpfile_r, (struct _reent *)); char * _EXFUN(_tmpnam_r, (struct _reent *, char *)); int _EXFUN(_ungetc_r, (struct _reent *, int, FILE *)); int _EXFUN(_vasiprintf_r, (struct _reent *, char **, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); char * _EXFUN(_vasniprintf_r, (struct _reent*, char *, size_t *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 4, 0)))); char * _EXFUN(_vasnprintf_r, (struct _reent*, char *, size_t *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 4, 0)))); int _EXFUN(_vasprintf_r, (struct _reent *, char **, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vdiprintf_r, (struct _reent *, int, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vdprintf_r, (struct _reent *, int, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vfiprintf_r, (struct _reent *, FILE *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vfiscanf_r, (struct _reent *, FILE *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 3, 0)))); int _EXFUN(_vfprintf_r, (struct _reent *, FILE *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vfscanf_r, (struct _reent *, FILE *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 3, 0)))); int _EXFUN(_viprintf_r, (struct _reent *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(_viscanf_r, (struct _reent *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 2, 0)))); int _EXFUN(_vprintf_r, (struct _reent *, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 2, 0)))); int _EXFUN(_vscanf_r, (struct _reent *, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 2, 0)))); int _EXFUN(_vsiprintf_r, (struct _reent *, char *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vsiscanf_r, (struct _reent *, const char *, const char *, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 3, 0)))); int _EXFUN(_vsniprintf_r, (struct _reent *, char *, size_t, const char *, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 4, 0)))); int _EXFUN(_vsnprintf_r, (struct _reent *, char *__restrict, size_t, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 4, 0)))); int _EXFUN(_vsprintf_r, (struct _reent *, char *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__printf__, 3, 0)))); int _EXFUN(_vsscanf_r, (struct _reent *, const char *__restrict, const char *__restrict, __VALIST) _ATTRIBUTE ((__format__ (__scanf__, 3, 0)))); /* Other extensions. */ int _EXFUN(fpurge, (FILE *)); ssize_t _EXFUN(__getdelim, (char **, size_t *, int, FILE *)); ssize_t _EXFUN(__getline, (char **, size_t *, FILE *)); #ifdef __LARGE64_FILES #if !defined(__CYGWIN__) || defined(_COMPILING_NEWLIB) FILE * _EXFUN(fdopen64, (int, const char *)); FILE * _EXFUN(fopen64, (const char *, const char *)); FILE * _EXFUN(freopen64, (_CONST char *, _CONST char *, FILE *)); _off64_t _EXFUN(ftello64, (FILE *)); _off64_t _EXFUN(fseeko64, (FILE *, _off64_t, int)); int _EXFUN(fgetpos64, (FILE *, _fpos64_t *)); int _EXFUN(fsetpos64, (FILE *, const _fpos64_t *)); FILE * _EXFUN(tmpfile64, (void)); FILE * _EXFUN(_fdopen64_r, (struct _reent *, int, const char *)); FILE * _EXFUN(_fopen64_r, (struct _reent *,const char *, const char *)); FILE * _EXFUN(_freopen64_r, (struct _reent *, _CONST char *, _CONST char *, FILE *)); _off64_t _EXFUN(_ftello64_r, (struct _reent *, FILE *)); _off64_t _EXFUN(_fseeko64_r, (struct _reent *, FILE *, _off64_t, int)); int _EXFUN(_fgetpos64_r, (struct _reent *, FILE *, _fpos64_t *)); int _EXFUN(_fsetpos64_r, (struct _reent *, FILE *, const _fpos64_t *)); FILE * _EXFUN(_tmpfile64_r, (struct _reent *)); #endif /* !__CYGWIN__ */ #endif /* __LARGE64_FILES */ /* * Routines internal to the implementation. */ int _EXFUN(__srget_r, (struct _reent *, FILE *)); int _EXFUN(__swbuf_r, (struct _reent *, int, FILE *)); /* * Stdio function-access interface. */ #ifndef __STRICT_ANSI__ # ifdef __LARGE64_FILES FILE *_EXFUN(funopen,(const _PTR __cookie, int (*__readfn)(_PTR __c, char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), int (*__writefn)(_PTR __c, const char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), _fpos64_t (*__seekfn)(_PTR __c, _fpos64_t __off, int __whence), int (*__closefn)(_PTR __c))); FILE *_EXFUN(_funopen_r,(struct _reent *, const _PTR __cookie, int (*__readfn)(_PTR __c, char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), int (*__writefn)(_PTR __c, const char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), _fpos64_t (*__seekfn)(_PTR __c, _fpos64_t __off, int __whence), int (*__closefn)(_PTR __c))); # else FILE *_EXFUN(funopen,(const _PTR __cookie, int (*__readfn)(_PTR __cookie, char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), int (*__writefn)(_PTR __cookie, const char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), fpos_t (*__seekfn)(_PTR __cookie, fpos_t __off, int __whence), int (*__closefn)(_PTR __cookie))); FILE *_EXFUN(_funopen_r,(struct _reent *, const _PTR __cookie, int (*__readfn)(_PTR __cookie, char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), int (*__writefn)(_PTR __cookie, const char *__buf, _READ_WRITE_BUFSIZE_TYPE __n), fpos_t (*__seekfn)(_PTR __cookie, fpos_t __off, int __whence), int (*__closefn)(_PTR __cookie))); # endif /* !__LARGE64_FILES */ # define fropen(__cookie, __fn) funopen(__cookie, __fn, (int (*)())0, \ (fpos_t (*)())0, (int (*)())0) # define fwopen(__cookie, __fn) funopen(__cookie, (int (*)())0, __fn, \ (fpos_t (*)())0, (int (*)())0) typedef ssize_t cookie_read_function_t(void *__cookie, char *__buf, size_t __n); typedef ssize_t cookie_write_function_t(void *__cookie, const char *__buf, size_t __n); # ifdef __LARGE64_FILES typedef int cookie_seek_function_t(void *__cookie, _off64_t *__off, int __whence); # else typedef int cookie_seek_function_t(void *__cookie, off_t *__off, int __whence); # endif /* !__LARGE64_FILES */ typedef int cookie_close_function_t(void *__cookie); typedef struct { /* These four struct member names are dictated by Linux; hopefully, they don't conflict with any macros. */ cookie_read_function_t *read; cookie_write_function_t *write; cookie_seek_function_t *seek; cookie_close_function_t *close; } cookie_io_functions_t; FILE *_EXFUN(fopencookie,(void *__cookie, const char *__mode, cookie_io_functions_t __functions)); FILE *_EXFUN(_fopencookie_r,(struct _reent *, void *__cookie, const char *__mode, cookie_io_functions_t __functions)); #endif /* ! __STRICT_ANSI__ */ #ifndef __CUSTOM_FILE_IO__ /* * The __sfoo macros are here so that we can * define function versions in the C library. */ #define __sgetc_raw_r(__ptr, __f) (--(__f)->_r < 0 ? __srget_r(__ptr, __f) : (int)(*(__f)->_p++)) #ifdef __SCLE /* For a platform with CR/LF, additional logic is required by __sgetc_r which would otherwise simply be a macro; therefore we use an inlined function. The function is only meant to be inlined in place as used and the function body should never be emitted. There are two possible means to this end when compiling with GCC, one when compiling with a standard C99 compiler, and for other compilers we're just stuck. At the moment, this issue only affects the Cygwin target, so we'll most likely be using GCC. */ _ELIDABLE_INLINE int __sgetc_r(struct _reent *__ptr, FILE *__p); _ELIDABLE_INLINE int __sgetc_r(struct _reent *__ptr, FILE *__p) { int __c = __sgetc_raw_r(__ptr, __p); if ((__p->_flags & __SCLE) && (__c == '\r')) { int __c2 = __sgetc_raw_r(__ptr, __p); if (__c2 == '\n') __c = __c2; else ungetc(__c2, __p); } return __c; } #else #define __sgetc_r(__ptr, __p) __sgetc_raw_r(__ptr, __p) #endif #ifdef _never /* __GNUC__ */ /* If this inline is actually used, then systems using coff debugging info get hopelessly confused. 21sept93 rich@cygnus.com. */ _ELIDABLE_INLINE int __sputc_r(struct _reent *_ptr, int _c, FILE *_p) { if (--_p->_w >= 0 || (_p->_w >= _p->_lbfsize && (char)_c != '\n')) return (*_p->_p++ = _c); else return (__swbuf_r(_ptr, _c, _p)); } #else /* * This has been tuned to generate reasonable code on the vax using pcc */ #define __sputc_raw_r(__ptr, __c, __p) \ (--(__p)->_w < 0 ? \ (__p)->_w >= (__p)->_lbfsize ? \ (*(__p)->_p = (__c)), *(__p)->_p != '\n' ? \ (int)*(__p)->_p++ : \ __swbuf_r(__ptr, '\n', __p) : \ __swbuf_r(__ptr, (int)(__c), __p) : \ (*(__p)->_p = (__c), (int)*(__p)->_p++)) #ifdef __SCLE #define __sputc_r(__ptr, __c, __p) \ ((((__p)->_flags & __SCLE) && ((__c) == '\n')) \ ? __sputc_raw_r(__ptr, '\r', (__p)) : 0 , \ __sputc_raw_r((__ptr), (__c), (__p))) #else #define __sputc_r(__ptr, __c, __p) __sputc_raw_r(__ptr, __c, __p) #endif #endif #define __sfeof(p) (((p)->_flags & __SEOF) != 0) #define __sferror(p) (((p)->_flags & __SERR) != 0) #define __sclearerr(p) ((void)((p)->_flags &= ~(__SERR|__SEOF))) #define __sfileno(p) ((p)->_file) #ifndef _REENT_SMALL #define feof(p) __sfeof(p) #define ferror(p) __sferror(p) #define clearerr(p) __sclearerr(p) #endif #if 0 /*ndef __STRICT_ANSI__ - FIXME: must initialize stdio first, use fn */ #define fileno(p) __sfileno(p) #endif #ifndef __CYGWIN__ #ifndef lint #define getc(fp) __sgetc_r(_REENT, fp) #define putc(x, fp) __sputc_r(_REENT, x, fp) #endif /* lint */ #endif /* __CYGWIN__ */ #ifndef __STRICT_ANSI__ /* fast always-buffered version, true iff error */ #define fast_putc(x,p) (--(p)->_w < 0 ? \ __swbuf_r(_REENT, (int)(x), p) == EOF : (*(p)->_p = (x), (p)->_p++, 0)) #define L_cuserid 9 /* posix says it goes in stdio.h :( */ #ifdef __CYGWIN__ #define L_ctermid 16 #endif #endif #endif /* !__CUSTOM_FILE_IO__ */ #define getchar() getc(stdin) #define putchar(x) putc(x, stdout) _END_STD_C #endif /* _STDIO_H_ */ 0707010000003e000081a40000000000000000000000016181423c0000060a000000000000000000000000000000000000002500000000./usr/nvptx-none/include/stdio_ext.h/* * stdio_ext.h * * Definitions for I/O internal operations, originally from Solaris. */ #ifndef _STDIO_EXT_H_ #define _STDIO_EXT_H_ #ifdef __rtems__ #error " not supported" #endif #include _BEGIN_STD_C void _EXFUN(__fpurge,(FILE *)); /* TODO: void _flushlbf (void); int __fsetlocking (FILE *__fp, int __type); */ #ifdef __GNUC__ _ELIDABLE_INLINE inline size_t __fbufsize (FILE *__fp) { return (size_t) __fp->_bf._size; } _ELIDABLE_INLINE inline int __freading (FILE *__fp) { return (__fp->_flags & __SRD) != 0; } _ELIDABLE_INLINE inline int __fwriting (FILE *__fp) { return (__fp->_flags & __SWR) != 0; } _ELIDABLE_INLINE inline int __freadable (FILE *__fp) { return (__fp->_flags & (__SRD | __SRW)) != 0; } _ELIDABLE_INLINE inline int __fwriteable (FILE *__fp) { return (__fp->_flags & (__SWR | __SRW)) != 0; } _ELIDABLE_INLINE inline int __flbf (FILE *__fp) { return (__fp->_flags & __SLBF) != 0; } _ELIDABLE_INLINE inline size_t __fpending (FILE *__fp) { return __fp->_p - __fp->_bf._base; } #else #define __fbufsize(__fp) ((size_t) (__fp)->_bf._size) #define __freading(__fp) (((__fp)->_flags & __SRD) != 0) #define __fwriting(__fp) (((__fp)->_flags & __SWR) != 0) #define __freadable(__fp) (((__fp)->_flags & (__SRD | __SRW)) != 0) #define __fwriteable(__fp) (((__fp)->_flags & (__SWR | __SRW)) != 0) #define __flbf(__fp) (((__fp)->_flags & __SLBF) != 0) #define __fpending(__fp) ((size_t) ((__fp)->_p - (__fp)->_bf._base)) #endif /* __GNUC__ */ _END_STD_C #endif /* _STDIO_EXT_H_ */ 0707010000003f000081a40000000000000000000000016181423c00002532000000000000000000000000000000000000002200000000./usr/nvptx-none/include/stdlib.h/* * stdlib.h * * Definitions for common types, variables, and functions. */ #ifndef _STDLIB_H_ #define _STDLIB_H_ #include #include "_ansi.h" #define __need_size_t #define __need_wchar_t #define __need_NULL #include #include #include #ifndef __STRICT_ANSI__ #include #endif #ifdef __CYGWIN__ #include #endif _BEGIN_STD_C typedef struct { int quot; /* quotient */ int rem; /* remainder */ } div_t; typedef struct { long quot; /* quotient */ long rem; /* remainder */ } ldiv_t; #if !defined(__STRICT_ANSI__) || \ (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) || \ (defined(__cplusplus) && __cplusplus >= 201103L) typedef struct { long long int quot; /* quotient */ long long int rem; /* remainder */ } lldiv_t; #endif #ifndef __compar_fn_t_defined #define __compar_fn_t_defined typedef int (*__compar_fn_t) (const _PTR, const _PTR); #endif #define EXIT_FAILURE 1 #define EXIT_SUCCESS 0 #define RAND_MAX __RAND_MAX int _EXFUN(__locale_mb_cur_max,(_VOID)); #define MB_CUR_MAX __locale_mb_cur_max() _VOID _EXFUN(abort,(_VOID) _ATTRIBUTE ((noreturn))); int _EXFUN(abs,(int)); int _EXFUN(atexit,(_VOID (*__func)(_VOID))); double _EXFUN(atof,(const char *__nptr)); #ifndef __STRICT_ANSI__ float _EXFUN(atoff,(const char *__nptr)); #endif int _EXFUN(atoi,(const char *__nptr)); int _EXFUN(_atoi_r,(struct _reent *, const char *__nptr)); long _EXFUN(atol,(const char *__nptr)); long _EXFUN(_atol_r,(struct _reent *, const char *__nptr)); _PTR _EXFUN(bsearch,(const _PTR __key, const _PTR __base, size_t __nmemb, size_t __size, __compar_fn_t _compar)); _PTR _EXFUN_NOTHROW(calloc,(size_t __nmemb, size_t __size)); div_t _EXFUN(div,(int __numer, int __denom)); _VOID _EXFUN(exit,(int __status) _ATTRIBUTE ((noreturn))); _VOID _EXFUN_NOTHROW(free,(_PTR)); char * _EXFUN(getenv,(const char *__string)); char * _EXFUN(_getenv_r,(struct _reent *, const char *__string)); char * _EXFUN(_findenv,(_CONST char *, int *)); char * _EXFUN(_findenv_r,(struct _reent *, _CONST char *, int *)); #ifndef __STRICT_ANSI__ extern char *suboptarg; /* getsubopt(3) external variable */ int _EXFUN(getsubopt,(char **, char * const *, char **)); #endif long _EXFUN(labs,(long)); ldiv_t _EXFUN(ldiv,(long __numer, long __denom)); _PTR _EXFUN_NOTHROW(malloc,(size_t __size)); int _EXFUN(mblen,(const char *, size_t)); int _EXFUN(_mblen_r,(struct _reent *, const char *, size_t, _mbstate_t *)); int _EXFUN(mbtowc,(wchar_t *__restrict, const char *__restrict, size_t)); int _EXFUN(_mbtowc_r,(struct _reent *, wchar_t *__restrict, const char *__restrict, size_t, _mbstate_t *)); int _EXFUN(wctomb,(char *, wchar_t)); int _EXFUN(_wctomb_r,(struct _reent *, char *, wchar_t, _mbstate_t *)); size_t _EXFUN(mbstowcs,(wchar_t *__restrict, const char *__restrict, size_t)); size_t _EXFUN(_mbstowcs_r,(struct _reent *, wchar_t *__restrict, const char *__restrict, size_t, _mbstate_t *)); size_t _EXFUN(wcstombs,(char *__restrict, const wchar_t *__restrict, size_t)); size_t _EXFUN(_wcstombs_r,(struct _reent *, char *__restrict, const wchar_t *__restrict, size_t, _mbstate_t *)); #ifndef __STRICT_ANSI__ #ifndef _REENT_ONLY char * _EXFUN(mkdtemp,(char *)); int _EXFUN(mkostemp,(char *, int)); int _EXFUN(mkostemps,(char *, int, int)); int _EXFUN(mkstemp,(char *)); int _EXFUN(mkstemps,(char *, int)); char * _EXFUN(mktemp,(char *) _ATTRIBUTE ((__warning__ ("the use of `mktemp' is dangerous; use `mkstemp' instead")))); #endif char * _EXFUN(_mkdtemp_r, (struct _reent *, char *)); int _EXFUN(_mkostemp_r, (struct _reent *, char *, int)); int _EXFUN(_mkostemps_r, (struct _reent *, char *, int, int)); int _EXFUN(_mkstemp_r, (struct _reent *, char *)); int _EXFUN(_mkstemps_r, (struct _reent *, char *, int)); char * _EXFUN(_mktemp_r, (struct _reent *, char *) _ATTRIBUTE ((__warning__ ("the use of `mktemp' is dangerous; use `mkstemp' instead")))); #endif _VOID _EXFUN(qsort,(_PTR __base, size_t __nmemb, size_t __size, __compar_fn_t _compar)); int _EXFUN(rand,(_VOID)); _PTR _EXFUN_NOTHROW(realloc,(_PTR __r, size_t __size)); #ifndef __STRICT_ANSI__ _PTR _EXFUN(reallocf,(_PTR __r, size_t __size)); char * _EXFUN(realpath, (const char *__restrict path, char *__restrict resolved_path)); #endif _VOID _EXFUN(srand,(unsigned __seed)); double _EXFUN(strtod,(const char *__restrict __n, char **__restrict __end_PTR)); double _EXFUN(_strtod_r,(struct _reent *,const char *__restrict __n, char **__restrict __end_PTR)); #if !defined(__STRICT_ANSI__) || (__STDC_VERSION__ >= 199901L) || (__cplusplus >= 201103L) float _EXFUN(strtof,(const char *__restrict __n, char **__restrict __end_PTR)); #endif #ifndef __STRICT_ANSI__ /* the following strtodf interface is deprecated...use strtof instead */ # ifndef strtodf # define strtodf strtof # endif #endif long _EXFUN(strtol,(const char *__restrict __n, char **__restrict __end_PTR, int __base)); long _EXFUN(_strtol_r,(struct _reent *,const char *__restrict __n, char **__restrict __end_PTR, int __base)); unsigned long _EXFUN(strtoul,(const char *__restrict __n, char **__restrict __end_PTR, int __base)); unsigned long _EXFUN(_strtoul_r,(struct _reent *,const char *__restrict __n, char **__restrict __end_PTR, int __base)); int _EXFUN(system,(const char *__string)); #ifndef __STRICT_ANSI__ long _EXFUN(a64l,(const char *__input)); char * _EXFUN(l64a,(long __input)); char * _EXFUN(_l64a_r,(struct _reent *,long __input)); int _EXFUN(on_exit,(_VOID (*__func)(int, _PTR),_PTR __arg)); _VOID _EXFUN(_Exit,(int __status) _ATTRIBUTE ((noreturn))); int _EXFUN(putenv,(char *__string)); int _EXFUN(_putenv_r,(struct _reent *, char *__string)); _PTR _EXFUN(_reallocf_r,(struct _reent *, _PTR, size_t)); int _EXFUN(setenv,(const char *__string, const char *__value, int __overwrite)); int _EXFUN(_setenv_r,(struct _reent *, const char *__string, const char *__value, int __overwrite)); char * _EXFUN(gcvt,(double,int,char *)); char * _EXFUN(gcvtf,(float,int,char *)); char * _EXFUN(fcvt,(double,int,int *,int *)); char * _EXFUN(fcvtf,(float,int,int *,int *)); char * _EXFUN(ecvt,(double,int,int *,int *)); char * _EXFUN(ecvtbuf,(double, int, int*, int*, char *)); char * _EXFUN(fcvtbuf,(double, int, int*, int*, char *)); char * _EXFUN(ecvtf,(float,int,int *,int *)); char * _EXFUN(dtoa,(double, int, int, int *, int*, char**)); int _EXFUN(rand_r,(unsigned *__seed)); double _EXFUN(drand48,(_VOID)); double _EXFUN(_drand48_r,(struct _reent *)); double _EXFUN(erand48,(unsigned short [3])); double _EXFUN(_erand48_r,(struct _reent *, unsigned short [3])); long _EXFUN(jrand48,(unsigned short [3])); long _EXFUN(_jrand48_r,(struct _reent *, unsigned short [3])); _VOID _EXFUN(lcong48,(unsigned short [7])); _VOID _EXFUN(_lcong48_r,(struct _reent *, unsigned short [7])); long _EXFUN(lrand48,(_VOID)); long _EXFUN(_lrand48_r,(struct _reent *)); long _EXFUN(mrand48,(_VOID)); long _EXFUN(_mrand48_r,(struct _reent *)); long _EXFUN(nrand48,(unsigned short [3])); long _EXFUN(_nrand48_r,(struct _reent *, unsigned short [3])); unsigned short * _EXFUN(seed48,(unsigned short [3])); unsigned short * _EXFUN(_seed48_r,(struct _reent *, unsigned short [3])); _VOID _EXFUN(srand48,(long)); _VOID _EXFUN(_srand48_r,(struct _reent *, long)); long long _EXFUN(atoll,(const char *__nptr)); long long _EXFUN(_atoll_r,(struct _reent *, const char *__nptr)); long long _EXFUN(llabs,(long long)); lldiv_t _EXFUN(lldiv,(long long __numer, long long __denom)); #endif /* ! __STRICT_ANSI__ */ #if !defined(__STRICT_ANSI__) || (__STDC_VERSION__ >= 199901L) || (__cplusplus >= 201103L) long long _EXFUN(strtoll,(const char *__restrict __n, char **__restrict __end_PTR, int __base)); #endif #ifndef __STRICT_ANSI__ long long _EXFUN(_strtoll_r,(struct _reent *, const char *__restrict __n, char **__restrict __end_PTR, int __base)); #endif /* ! __STRICT_ANSI__ */ #if !defined(__STRICT_ANSI__) || (__STDC_VERSION__ >= 199901L) || (__cplusplus >= 201103L) unsigned long long _EXFUN(strtoull,(const char *__restrict __n, char **__restrict __end_PTR, int __base)); #endif #ifndef __STRICT_ANSI__ unsigned long long _EXFUN(_strtoull_r,(struct _reent *, const char *__restrict __n, char **__restrict __end_PTR, int __base)); #ifndef __CYGWIN__ _VOID _EXFUN(cfree,(_PTR)); int _EXFUN(unsetenv,(const char *__string)); int _EXFUN(_unsetenv_r,(struct _reent *, const char *__string)); #endif #ifdef __rtems__ int _EXFUN(posix_memalign,(void **, size_t, size_t)); #endif #endif /* ! __STRICT_ANSI__ */ char * _EXFUN(_dtoa_r,(struct _reent *, double, int, int, int *, int*, char**)); #ifndef __CYGWIN__ _PTR _EXFUN_NOTHROW(_malloc_r,(struct _reent *, size_t)); _PTR _EXFUN_NOTHROW(_calloc_r,(struct _reent *, size_t, size_t)); _VOID _EXFUN_NOTHROW(_free_r,(struct _reent *, _PTR)); _PTR _EXFUN_NOTHROW(_realloc_r,(struct _reent *, _PTR, size_t)); _PTR _EXFUN_NOTHROW(_realloc_os_r,(struct _reent *, _PTR, size_t, size_t)); _VOID _EXFUN(_mstats_r,(struct _reent *, char *)); #endif int _EXFUN(_system_r,(struct _reent *, const char *)); _VOID _EXFUN(__eprintf,(const char *, const char *, unsigned int, const char *)); /* On platforms where long double equals double. */ #ifdef _HAVE_LONG_DOUBLE #if !defined(__STRICT_ANSI__) || (__STDC_VERSION__ >= 199901L) || (__cplusplus >= 201103L) extern long double strtold (const char *__restrict, char **__restrict); #endif #endif /* _HAVE_LONG_DOUBLE */ _END_STD_C #endif /* _STDLIB_H_ */ 07070100000040000081a40000000000000000000000016181423c0000138c000000000000000000000000000000000000002200000000./usr/nvptx-none/include/string.h/* * string.h * * Definitions for memory and string functions. */ #ifndef _STRING_H_ #define _STRING_H_ #include "_ansi.h" #include #include #include #define __need_size_t #define __need_NULL #include _BEGIN_STD_C _PTR _EXFUN(memchr,(const _PTR, int, size_t)); int _EXFUN(memcmp,(const _PTR, const _PTR, size_t)); _PTR _EXFUN(memcpy,(_PTR __restrict, const _PTR __restrict, size_t)); _PTR _EXFUN(memmove,(_PTR, const _PTR, size_t)); _PTR _EXFUN(memset,(_PTR, int, size_t)); char *_EXFUN(strcat,(char *__restrict, const char *__restrict)); char *_EXFUN(strchr,(const char *, int)); int _EXFUN(strcmp,(const char *, const char *)); int _EXFUN(strcoll,(const char *, const char *)); char *_EXFUN(strcpy,(char *__restrict, const char *__restrict)); size_t _EXFUN(strcspn,(const char *, const char *)); char *_EXFUN(strerror,(int)); size_t _EXFUN(strlen,(const char *)); char *_EXFUN(strncat,(char *__restrict, const char *__restrict, size_t)); int _EXFUN(strncmp,(const char *, const char *, size_t)); char *_EXFUN(strncpy,(char *__restrict, const char *__restrict, size_t)); char *_EXFUN(strpbrk,(const char *, const char *)); char *_EXFUN(strrchr,(const char *, int)); size_t _EXFUN(strspn,(const char *, const char *)); char *_EXFUN(strstr,(const char *, const char *)); #ifndef _REENT_ONLY char *_EXFUN(strtok,(char *__restrict, const char *__restrict)); #endif size_t _EXFUN(strxfrm,(char *__restrict, const char *__restrict, size_t)); #ifndef __STRICT_ANSI__ char *_EXFUN(strtok_r,(char *__restrict, const char *__restrict, char **__restrict)); int _EXFUN(bcmp,(const void *, const void *, size_t)); void _EXFUN(bcopy,(const void *, void *, size_t)); void _EXFUN(bzero,(void *, size_t)); int _EXFUN(ffs,(int)); char *_EXFUN(index,(const char *, int)); _PTR _EXFUN(memccpy,(_PTR __restrict, const _PTR __restrict, int, size_t)); _PTR _EXFUN(mempcpy,(_PTR, const _PTR, size_t)); _PTR _EXFUN(memmem, (const _PTR, size_t, const _PTR, size_t)); _PTR _EXFUN(memrchr,(const _PTR, int, size_t)); _PTR _EXFUN(rawmemchr,(const _PTR, int)); char *_EXFUN(rindex,(const char *, int)); char *_EXFUN(stpcpy,(char *__restrict, const char *__restrict)); char *_EXFUN(stpncpy,(char *__restrict, const char *__restrict, size_t)); int _EXFUN(strcasecmp,(const char *, const char *)); char *_EXFUN(strcasestr,(const char *, const char *)); char *_EXFUN(strchrnul,(const char *, int)); #endif #if !defined(__STRICT_ANSI__) || (_XOPEN_SOURCE - 0) >= 500 char *_EXFUN(strdup,(const char *)); #endif #ifndef __STRICT_ANSI__ char *_EXFUN(_strdup_r,(struct _reent *, const char *)); #endif #if !defined(__STRICT_ANSI__) || (_XOPEN_SOURCE - 0) >= 700 char *_EXFUN(strndup,(const char *, size_t)); #endif #ifndef __STRICT_ANSI__ char *_EXFUN(_strndup_r,(struct _reent *, const char *, size_t)); /* There are two common strerror_r variants. If you request _GNU_SOURCE, you get the GNU version; otherwise you get the POSIX version. POSIX requires that #undef strerror_r will still let you invoke the underlying function, but that requires gcc support. */ #ifdef _GNU_SOURCE char *_EXFUN(strerror_r,(int, char *, size_t)); #else # ifdef __GNUC__ int _EXFUN(strerror_r,(int, char *, size_t)) __asm__ (__ASMNAME ("__xpg_strerror_r")); # else int _EXFUN(__xpg_strerror_r,(int, char *, size_t)); # define strerror_r __xpg_strerror_r # endif #endif size_t _EXFUN(strlcat,(char *, const char *, size_t)); size_t _EXFUN(strlcpy,(char *, const char *, size_t)); int _EXFUN(strncasecmp,(const char *, const char *, size_t)); size_t _EXFUN(strnlen,(const char *, size_t)); char *_EXFUN(strsep,(char **, const char *)); char *_EXFUN(strlwr,(char *)); char *_EXFUN(strupr,(char *)); #ifndef DEFS_H /* Kludge to work around problem compiling in gdb */ char *_EXFUN(strsignal, (int __signo)); #endif #ifdef __CYGWIN__ int _EXFUN(strtosigno, (const char *__name)); #endif /* Recursive version of strerror. */ char * _EXFUN(_strerror_r, (struct _reent *, int, int, int *)); #if defined _GNU_SOURCE && defined __GNUC__ #define strdupa(__s) \ (__extension__ ({const char *__in = (__s); \ size_t __len = strlen (__in) + 1; \ char * __out = (char *) __builtin_alloca (__len); \ (char *) memcpy (__out, __in, __len);})) #define strndupa(__s, __n) \ (__extension__ ({const char *__in = (__s); \ size_t __len = strnlen (__in, (__n)) + 1; \ char *__out = (char *) __builtin_alloca (__len); \ __out[__len-1] = '\0'; \ (char *) memcpy (__out, __in, __len-1);})) #endif /* _GNU_SOURCE && __GNUC__ */ /* These function names are used on Windows and perhaps other systems. */ #ifndef strcmpi #define strcmpi strcasecmp #endif #ifndef stricmp #define stricmp strcasecmp #endif #ifndef strncmpi #define strncmpi strncasecmp #endif #ifndef strnicmp #define strnicmp strncasecmp #endif #endif /* ! __STRICT_ANSI__ */ #include _END_STD_C #endif /* _STRING_H_ */ 07070100000041000081a40000000000000000000000016181423c00000360000000000000000000000000000000000000002300000000./usr/nvptx-none/include/strings.h/* * strings.h * * Definitions for string operations. */ #ifndef _STRINGS_H_ #define _STRINGS_H_ #include "_ansi.h" #include #include /* for size_t */ _BEGIN_STD_C #if !defined __STRICT_ANSI__ && _POSIX_VERSION < 200809L /* * Marked LEGACY in Open Group Base Specifications Issue 6/IEEE Std 1003.1-2004 * Removed from Open Group Base Specifications Issue 7/IEEE Std 1003.1-2008 */ int _EXFUN(bcmp,(const void *, const void *, size_t)); void _EXFUN(bcopy,(const void *, void *, size_t)); void _EXFUN(bzero,(void *, size_t)); char *_EXFUN(index,(const char *, int)); char *_EXFUN(rindex,(const char *, int)); #endif /* ! __STRICT_ANSI__ */ int _EXFUN(ffs,(int)); int _EXFUN(strcasecmp,(const char *, const char *)); int _EXFUN(strncasecmp,(const char *, const char *, size_t)); _END_STD_C #endif /* _STRINGS_H_ */ 07070100000042000041ed0000000000000000000000016181423d00000000000000000000000000000000000000000000001d00000000./usr/nvptx-none/include/sys07070100000043000081a40000000000000000000000016181423c00001b98000000000000000000000000000000000000002e00000000./usr/nvptx-none/include/sys/_default_fcntl.h #ifndef _SYS__DEFAULT_FCNTL_H_ #ifdef __cplusplus extern "C" { #endif #define _SYS__DEFAULT_FCNTL_H_ #include <_ansi.h> #include #define _FOPEN (-1) /* from sys/file.h, kernel use only */ #define _FREAD 0x0001 /* read enabled */ #define _FWRITE 0x0002 /* write enabled */ #define _FAPPEND 0x0008 /* append (writes guaranteed at the end) */ #define _FMARK 0x0010 /* internal; mark during gc() */ #define _FDEFER 0x0020 /* internal; defer for next gc pass */ #define _FASYNC 0x0040 /* signal pgrp when data ready */ #define _FSHLOCK 0x0080 /* BSD flock() shared lock present */ #define _FEXLOCK 0x0100 /* BSD flock() exclusive lock present */ #define _FCREAT 0x0200 /* open with file create */ #define _FTRUNC 0x0400 /* open with truncation */ #define _FEXCL 0x0800 /* error on open if file exists */ #define _FNBIO 0x1000 /* non blocking I/O (sys5 style) */ #define _FSYNC 0x2000 /* do all writes synchronously */ #define _FNONBLOCK 0x4000 /* non blocking I/O (POSIX style) */ #define _FNDELAY _FNONBLOCK /* non blocking I/O (4.2 style) */ #define _FNOCTTY 0x8000 /* don't assign a ctty on this open */ #define O_ACCMODE (O_RDONLY|O_WRONLY|O_RDWR) /* * Flag values for open(2) and fcntl(2) * The kernel adds 1 to the open modes to turn it into some * combination of FREAD and FWRITE. */ #define O_RDONLY 0 /* +1 == FREAD */ #define O_WRONLY 1 /* +1 == FWRITE */ #define O_RDWR 2 /* +1 == FREAD|FWRITE */ #define O_APPEND _FAPPEND #define O_CREAT _FCREAT #define O_TRUNC _FTRUNC #define O_EXCL _FEXCL #define O_SYNC _FSYNC /* O_NDELAY _FNDELAY set in include/fcntl.h */ /* O_NDELAY _FNBIO set in include/fcntl.h */ #define O_NONBLOCK _FNONBLOCK #define O_NOCTTY _FNOCTTY /* For machines which care - */ #if defined (_WIN32) || defined (__CYGWIN__) #define _FBINARY 0x10000 #define _FTEXT 0x20000 #define _FNOINHERIT 0x40000 #define O_BINARY _FBINARY #define O_TEXT _FTEXT #define O_NOINHERIT _FNOINHERIT /* O_CLOEXEC is the Linux equivalent to O_NOINHERIT */ #define O_CLOEXEC _FNOINHERIT /* The windows header files define versions with a leading underscore. */ #define _O_RDONLY O_RDONLY #define _O_WRONLY O_WRONLY #define _O_RDWR O_RDWR #define _O_APPEND O_APPEND #define _O_CREAT O_CREAT #define _O_TRUNC O_TRUNC #define _O_EXCL O_EXCL #define _O_TEXT O_TEXT #define _O_BINARY O_BINARY #define _O_RAW O_BINARY #define _O_NOINHERIT O_NOINHERIT #endif #ifndef _POSIX_SOURCE /* * Flags that work for fcntl(fd, F_SETFL, FXXXX) */ #define FAPPEND _FAPPEND #define FSYNC _FSYNC #define FASYNC _FASYNC #define FNBIO _FNBIO #define FNONBIO _FNONBLOCK /* XXX fix to be NONBLOCK everywhere */ #define FNDELAY _FNDELAY /* * Flags that are disallowed for fcntl's (FCNTLCANT); * used for opens, internal state, or locking. */ #define FREAD _FREAD #define FWRITE _FWRITE #define FMARK _FMARK #define FDEFER _FDEFER #define FSHLOCK _FSHLOCK #define FEXLOCK _FEXLOCK /* * The rest of the flags, used only for opens */ #define FOPEN _FOPEN #define FCREAT _FCREAT #define FTRUNC _FTRUNC #define FEXCL _FEXCL #define FNOCTTY _FNOCTTY #endif /* !_POSIX_SOURCE */ /* XXX close on exec request; must match UF_EXCLOSE in user.h */ #define FD_CLOEXEC 1 /* posix */ /* fcntl(2) requests */ #define F_DUPFD 0 /* Duplicate fildes */ #define F_GETFD 1 /* Get fildes flags (close on exec) */ #define F_SETFD 2 /* Set fildes flags (close on exec) */ #define F_GETFL 3 /* Get file flags */ #define F_SETFL 4 /* Set file flags */ #ifndef _POSIX_SOURCE #define F_GETOWN 5 /* Get owner - for ASYNC */ #define F_SETOWN 6 /* Set owner - for ASYNC */ #endif /* !_POSIX_SOURCE */ #define F_GETLK 7 /* Get record-locking information */ #define F_SETLK 8 /* Set or Clear a record-lock (Non-Blocking) */ #define F_SETLKW 9 /* Set or Clear a record-lock (Blocking) */ #ifndef _POSIX_SOURCE #define F_RGETLK 10 /* Test a remote lock to see if it is blocked */ #define F_RSETLK 11 /* Set or unlock a remote lock */ #define F_CNVT 12 /* Convert a fhandle to an open fd */ #define F_RSETLKW 13 /* Set or Clear remote record-lock(Blocking) */ #endif /* !_POSIX_SOURCE */ #ifdef __CYGWIN__ #define F_DUPFD_CLOEXEC 14 /* As F_DUPFD, but set close-on-exec flag */ #endif /* fcntl(2) flags (l_type field of flock structure) */ #define F_RDLCK 1 /* read lock */ #define F_WRLCK 2 /* write lock */ #define F_UNLCK 3 /* remove lock(s) */ #ifndef _POSIX_SOURCE #define F_UNLKSYS 4 /* remove remote locks for a given system */ #endif /* !_POSIX_SOURCE */ #if __BSD_VISIBLE || __POSIX_VISIBLE >= 200809 || defined(__CYGWIN__) /* Special descriptor value to denote the cwd in calls to openat(2) etc. */ #define AT_FDCWD -2 /* Flag values for faccessat2) et al. */ #define AT_EACCESS 1 #define AT_SYMLINK_NOFOLLOW 2 #define AT_SYMLINK_FOLLOW 4 #define AT_REMOVEDIR 8 #endif #if __BSD_VISIBLE /* lock operations for flock(2) */ #define LOCK_SH 0x01 /* shared file lock */ #define LOCK_EX 0x02 /* exclusive file lock */ #define LOCK_NB 0x04 /* don't block when locking */ #define LOCK_UN 0x08 /* unlock file */ #endif /*#include */ #ifndef __CYGWIN__ /* file segment locking set data type - information passed to system by user */ struct flock { short l_type; /* F_RDLCK, F_WRLCK, or F_UNLCK */ short l_whence; /* flag to choose starting offset */ long l_start; /* relative offset, in bytes */ long l_len; /* length, in bytes; 0 means lock to EOF */ short l_pid; /* returned with F_GETLK */ short l_xxx; /* reserved for future use */ }; #endif /* __CYGWIN__ */ #ifndef _POSIX_SOURCE /* extended file segment locking set data type */ struct eflock { short l_type; /* F_RDLCK, F_WRLCK, or F_UNLCK */ short l_whence; /* flag to choose starting offset */ long l_start; /* relative offset, in bytes */ long l_len; /* length, in bytes; 0 means lock to EOF */ short l_pid; /* returned with F_GETLK */ short l_xxx; /* reserved for future use */ long l_rpid; /* Remote process id wanting this lock */ long l_rsys; /* Remote system id wanting this lock */ }; #endif /* !_POSIX_SOURCE */ #include #include /* sigh. for the mode bits for open/creat */ extern int open _PARAMS ((const char *, int, ...)); #if __BSD_VISIBLE || __POSIX_VISIBLE >= 200809 || defined(__CYGWIN__) extern int openat _PARAMS ((int, const char *, int, ...)); #endif extern int creat _PARAMS ((const char *, mode_t)); extern int fcntl _PARAMS ((int, int, ...)); #if __BSD_VISIBLE extern int flock _PARAMS ((int, int)); #endif #ifdef __CYGWIN__ #include extern int futimesat _PARAMS ((int, const char *, const struct timeval *)); #endif /* Provide _ prototypes for functions provided by some versions of newlib. */ #ifdef _COMPILING_NEWLIB extern int _open _PARAMS ((const char *, int, ...)); extern int _fcntl _PARAMS ((int, int, ...)); #ifdef __LARGE64_FILES extern int _open64 _PARAMS ((const char *, int, ...)); #endif #endif #ifdef __cplusplus } #endif #endif /* !_SYS__DEFAULT_FCNTL_H_ */ 07070100000044000081a40000000000000000000000016181423c000007da000000000000000000000000000000000000002600000000./usr/nvptx-none/include/sys/_types.h/* ANSI C namespace clean utility typedefs */ /* This file defines various typedefs needed by the system calls that support the C library. Basically, they're just the POSIX versions with an '_' prepended. This file lives in the `sys' directory so targets can provide their own if desired (or they can put target dependant conditionals here). */ #ifndef _SYS__TYPES_H #define _SYS__TYPES_H #include #include #ifndef __off_t_defined typedef long _off_t; #endif #ifndef __dev_t_defined typedef short __dev_t; #endif #ifndef __uid_t_defined typedef unsigned short __uid_t; #endif #ifndef __gid_t_defined typedef unsigned short __gid_t; #endif #ifndef __off64_t_defined __extension__ typedef long long _off64_t; #endif /* * We need fpos_t for the following, but it doesn't have a leading "_", * so we use _fpos_t instead. */ #ifndef __fpos_t_defined typedef long _fpos_t; /* XXX must match off_t in */ /* (and must be `long' for now) */ #endif #ifdef __LARGE64_FILES #ifndef __fpos64_t_defined typedef _off64_t _fpos64_t; #endif #endif #ifndef __ssize_t_defined #ifdef __SIZE_TYPE__ /* If __SIZE_TYPE__ is defined (gcc) we define ssize_t based on size_t. We simply change "unsigned" to "signed" for this single definition to make sure ssize_t and size_t only differ by their signedness. */ #define unsigned signed typedef __SIZE_TYPE__ _ssize_t; #undef unsigned #else #if defined(__INT_MAX__) && __INT_MAX__ == 2147483647 typedef int _ssize_t; #else typedef long _ssize_t; #endif #endif #endif #define __need_wint_t #include #ifndef __mbstate_t_defined /* Conversion state information. */ typedef struct { int __count; union { wint_t __wch; unsigned char __wchb[4]; } __value; /* Value so far. */ } _mbstate_t; #endif #ifndef __flock_t_defined typedef _LOCK_RECURSIVE_T _flock_t; #endif #ifndef __iconv_t_defined /* Iconv descriptor type */ typedef void *_iconv_t; #endif #endif /* _SYS__TYPES_H */ 07070100000045000081a40000000000000000000000016181423c0000597e000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/cdefs.h/* libc/sys/linux/sys/cdefs.h - Helper macros for K&R vs. ANSI C compat. */ /* Written 2000 by Werner Almesberger */ /*- * Copyright (c) 1991, 1993 * The Regents of the University of California. All rights reserved. * * This code is derived from software contributed to Berkeley by * Berkeley Software Design, Inc. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)cdefs.h 8.8 (Berkeley) 1/9/95 * $FreeBSD$ */ #ifndef _SYS_CDEFS_H_ #define _SYS_CDEFS_H_ #include #include #include #define __PMT(args) args #define __DOTS , ... #define __THROW #ifdef __GNUC__ # define __ASMNAME(cname) __XSTRING (__USER_LABEL_PREFIX__) cname #endif #define __ptr_t void * #define __long_double_t long double #define __attribute_malloc__ #define __attribute_pure__ #define __attribute_format_strfmon__(a,b) #define __flexarr [0] #ifndef __BOUNDED_POINTERS__ # define __bounded /* nothing */ # define __unbounded /* nothing */ # define __ptrvalue /* nothing */ #endif /* * Testing against Clang-specific extensions. */ #ifndef __has_extension #define __has_extension __has_feature #endif #ifndef __has_feature #define __has_feature(x) 0 #endif #ifndef __has_include #define __has_include(x) 0 #endif #ifndef __has_builtin #define __has_builtin(x) 0 #endif #if defined(__cplusplus) #define __BEGIN_DECLS extern "C" { #define __END_DECLS } #else #define __BEGIN_DECLS #define __END_DECLS #endif /* * This code has been put in place to help reduce the addition of * compiler specific defines in FreeBSD code. It helps to aid in * having a compiler-agnostic source tree. */ #if defined(__GNUC__) || defined(__INTEL_COMPILER) #if __GNUC__ >= 3 || defined(__INTEL_COMPILER) #define __GNUCLIKE_ASM 3 #define __GNUCLIKE_MATH_BUILTIN_CONSTANTS #else #define __GNUCLIKE_ASM 2 #endif #define __GNUCLIKE___TYPEOF 1 #define __GNUCLIKE___OFFSETOF 1 #define __GNUCLIKE___SECTION 1 #ifndef __INTEL_COMPILER # define __GNUCLIKE_CTOR_SECTION_HANDLING 1 #endif #define __GNUCLIKE_BUILTIN_CONSTANT_P 1 # if defined(__INTEL_COMPILER) && defined(__cplusplus) \ && __INTEL_COMPILER < 800 # undef __GNUCLIKE_BUILTIN_CONSTANT_P # endif #if (__GNUC_MINOR__ > 95 || __GNUC__ >= 3) && !defined(__INTEL_COMPILER) # define __GNUCLIKE_BUILTIN_VARARGS 1 # define __GNUCLIKE_BUILTIN_STDARG 1 # define __GNUCLIKE_BUILTIN_VAALIST 1 #endif #if defined(__GNUC__) # define __GNUC_VA_LIST_COMPATIBILITY 1 #endif /* * Compiler memory barriers, specific to gcc and clang. */ #if defined(__GNUC__) #define __compiler_membar() __asm __volatile(" " : : : "memory") #endif #ifndef __INTEL_COMPILER # define __GNUCLIKE_BUILTIN_NEXT_ARG 1 # define __GNUCLIKE_MATH_BUILTIN_RELOPS #endif #define __GNUCLIKE_BUILTIN_MEMCPY 1 /* XXX: if __GNUC__ >= 2: not tested everywhere originally, where replaced */ #define __CC_SUPPORTS_INLINE 1 #define __CC_SUPPORTS___INLINE 1 #define __CC_SUPPORTS___INLINE__ 1 #define __CC_SUPPORTS___FUNC__ 1 #define __CC_SUPPORTS_WARNING 1 #define __CC_SUPPORTS_VARADIC_XXX 1 /* see varargs.h */ #define __CC_SUPPORTS_DYNAMIC_ARRAY_INIT 1 #endif /* __GNUC__ || __INTEL_COMPILER */ /* * The __CONCAT macro is used to concatenate parts of symbol names, e.g. * with "#define OLD(foo) __CONCAT(old,foo)", OLD(foo) produces oldfoo. * The __CONCAT macro is a bit tricky to use if it must work in non-ANSI * mode -- there must be no spaces between its arguments, and for nested * __CONCAT's, all the __CONCAT's must be at the left. __CONCAT can also * concatenate double-quoted strings produced by the __STRING macro, but * this only works with ANSI C. * * __XSTRING is like __STRING, but it expands any macros in its argument * first. It is only available with ANSI C. */ #if defined(__STDC__) || defined(__cplusplus) #define __P(protos) protos /* full-blown ANSI C */ #define __CONCAT1(x,y) x ## y #define __CONCAT(x,y) __CONCAT1(x,y) #define __STRING(x) #x /* stringify without expanding x */ #define __XSTRING(x) __STRING(x) /* expand x, then stringify */ #define __const const /* define reserved names to standard */ #define __signed signed #define __volatile volatile #if defined(__cplusplus) #define __inline inline /* convert to C++ keyword */ #else #if !(defined(__CC_SUPPORTS___INLINE)) #define __inline /* delete GCC keyword */ #endif /* ! __CC_SUPPORTS___INLINE */ #endif /* !__cplusplus */ #else /* !(__STDC__ || __cplusplus) */ #define __P(protos) () /* traditional C preprocessor */ #define __CONCAT(x,y) x/**/y #define __STRING(x) "x" #if !defined(__CC_SUPPORTS___INLINE) #define __const /* delete pseudo-ANSI C keywords */ #define __inline #define __signed #define __volatile /* * In non-ANSI C environments, new programs will want ANSI-only C keywords * deleted from the program and old programs will want them left alone. * When using a compiler other than gcc, programs using the ANSI C keywords * const, inline etc. as normal identifiers should define -DNO_ANSI_KEYWORDS. * When using "gcc -traditional", we assume that this is the intent; if * __GNUC__ is defined but __STDC__ is not, we leave the new keywords alone. */ #ifndef NO_ANSI_KEYWORDS #define const /* delete ANSI C keywords */ #define inline #define signed #define volatile #endif /* !NO_ANSI_KEYWORDS */ #endif /* !__CC_SUPPORTS___INLINE */ #endif /* !(__STDC__ || __cplusplus) */ /* * Compiler-dependent macros to help declare dead (non-returning) and * pure (no side effects) functions, and unused variables. They are * null except for versions of gcc that are known to support the features * properly (old versions of gcc-2 supported the dead and pure features * in a different (wrong) way). If we do not provide an implementation * for a given compiler, let the compile fail if it is told to use * a feature that we cannot live without. */ #ifdef lint #define __dead2 #define __pure2 #define __unused #define __packed #define __aligned(x) #define __section(x) #else #if !__GNUC_PREREQ__(2, 5) && !defined(__INTEL_COMPILER) #define __dead2 #define __pure2 #define __unused #endif #if __GNUC__ == 2 && __GNUC_MINOR__ >= 5 && __GNUC_MINOR__ < 7 && !defined(__INTEL_COMPILER) #define __dead2 __attribute__((__noreturn__)) #define __pure2 __attribute__((__const__)) #define __unused /* XXX Find out what to do for __packed, __aligned and __section */ #endif #if __GNUC_PREREQ__(2, 7) #define __dead2 __attribute__((__noreturn__)) #define __pure2 __attribute__((__const__)) #define __unused __attribute__((__unused__)) #define __used __attribute__((__used__)) #define __packed __attribute__((__packed__)) #define __aligned(x) __attribute__((__aligned__(x))) #define __section(x) __attribute__((__section__(x))) #endif #if defined(__INTEL_COMPILER) #define __dead2 __attribute__((__noreturn__)) #define __pure2 __attribute__((__const__)) #define __unused __attribute__((__unused__)) #define __used __attribute__((__used__)) #define __packed __attribute__((__packed__)) #define __aligned(x) __attribute__((__aligned__(x))) #define __section(x) __attribute__((__section__(x))) #endif #endif #if !__GNUC_PREREQ__(2, 95) #define __alignof(x) __offsetof(struct { char __a; x __b; }, __b) #endif /* * Keywords added in C11. */ #if !defined(__STDC_VERSION__) || __STDC_VERSION__ < 201112L #if !__has_extension(c_alignas) #if (defined(__cplusplus) && __cplusplus >= 201103L) || \ __has_extension(cxx_alignas) #define _Alignas(x) alignas(x) #else /* XXX: Only emulates _Alignas(constant-expression); not _Alignas(type-name). */ #define _Alignas(x) __aligned(x) #endif #endif #if defined(__cplusplus) && __cplusplus >= 201103L #define _Alignof(x) alignof(x) #else #define _Alignof(x) __alignof(x) #endif #if !__has_extension(c_atomic) && !__has_extension(cxx_atomic) /* * No native support for _Atomic(). Place object in structure to prevent * most forms of direct non-atomic access. */ #define _Atomic(T) struct { T volatile __val; } #endif #if defined(__cplusplus) && __cplusplus >= 201103L #define _Noreturn [[noreturn]] #else #define _Noreturn __dead2 #endif #if __GNUC_PREREQ__(4, 6) && !defined(__cplusplus) /* Do nothing: _Static_assert() works as per C11 */ #elif !__has_extension(c_static_assert) #if (defined(__cplusplus) && __cplusplus >= 201103L) || \ __has_extension(cxx_static_assert) #define _Static_assert(x, y) static_assert(x, y) #elif defined(__COUNTER__) #define _Static_assert(x, y) __Static_assert(x, __COUNTER__) #define __Static_assert(x, y) ___Static_assert(x, y) #define ___Static_assert(x, y) typedef char __assert_ ## y[(x) ? 1 : -1] #else #define _Static_assert(x, y) struct __hack #endif #endif #if !__has_extension(c_thread_local) /* XXX: Change this to test against C++11 when clang in base supports it. */ #if /* (defined(__cplusplus) && __cplusplus >= 201103L) || */ \ __has_extension(cxx_thread_local) #define _Thread_local thread_local #else #define _Thread_local __thread #endif #endif #endif /* __STDC_VERSION__ || __STDC_VERSION__ < 201112L */ /* * Emulation of C11 _Generic(). Unlike the previously defined C11 * keywords, it is not possible to implement this using exactly the same * syntax. Therefore implement something similar under the name * __generic(). Unlike _Generic(), this macro can only distinguish * between a single type, so it requires nested invocations to * distinguish multiple cases. */ #if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L #define __generic(expr, t, yes, no) \ _Generic(expr, t: yes, default: no) #elif __GNUC_PREREQ__(3, 1) && !defined(__cplusplus) #define __generic(expr, t, yes, no) \ __builtin_choose_expr( \ __builtin_types_compatible_p(__typeof(expr), t), yes, no) #endif #if __GNUC_PREREQ__(2, 96) #define __malloc_like __attribute__((__malloc__)) #define __pure __attribute__((__pure__)) #else #define __malloc_like #define __pure #endif #if __GNUC_PREREQ__(3, 1) || (defined(__INTEL_COMPILER) && __INTEL_COMPILER >= 800) #define __always_inline __attribute__((__always_inline__)) #else #define __always_inline #endif #if __GNUC_PREREQ__(3, 1) #define __noinline __attribute__ ((__noinline__)) #else #define __noinline #endif #if __GNUC_PREREQ__(3, 3) #define __nonnull(x) __attribute__((__nonnull__(x))) #else #define __nonnull(x) #endif #if __GNUC_PREREQ__(3, 4) #define __fastcall __attribute__((__fastcall__)) #else #define __fastcall #endif #if __GNUC_PREREQ__(4, 1) #define __returns_twice __attribute__((__returns_twice__)) #else #define __returns_twice #endif /* XXX: should use `#if __STDC_VERSION__ < 199901'. */ #if !__GNUC_PREREQ__(2, 7) && !defined(__INTEL_COMPILER) #define __func__ NULL #endif /* * GCC 2.95 provides `__restrict' as an extension to C90 to support the * C99-specific `restrict' type qualifier. We happen to use `__restrict' as * a way to define the `restrict' type qualifier without disturbing older * software that is unaware of C99 keywords. */ #if !(__GNUC__ == 2 && __GNUC_MINOR__ == 95) #if !defined(__STDC_VERSION__) || __STDC_VERSION__ < 199901 || defined(lint) #define __restrict #else #define __restrict restrict #endif #endif /* * GNU C version 2.96 adds explicit branch prediction so that * the CPU back-end can hint the processor and also so that * code blocks can be reordered such that the predicted path * sees a more linear flow, thus improving cache behavior, etc. * * The following two macros provide us with a way to utilize this * compiler feature. Use __predict_true() if you expect the expression * to evaluate to true, and __predict_false() if you expect the * expression to evaluate to false. * * A few notes about usage: * * * Generally, __predict_false() error condition checks (unless * you have some _strong_ reason to do otherwise, in which case * document it), and/or __predict_true() `no-error' condition * checks, assuming you want to optimize for the no-error case. * * * Other than that, if you don't know the likelihood of a test * succeeding from empirical or other `hard' evidence, don't * make predictions. * * * These are meant to be used in places that are run `a lot'. * It is wasteful to make predictions in code that is run * seldomly (e.g. at subsystem initialization time) as the * basic block reordering that this affects can often generate * larger code. */ #if __GNUC_PREREQ__(2, 96) #define __predict_true(exp) __builtin_expect((exp), 1) #define __predict_false(exp) __builtin_expect((exp), 0) #else #define __predict_true(exp) (exp) #define __predict_false(exp) (exp) #endif #if __GNUC_PREREQ__(4, 2) #define __hidden __attribute__((__visibility__("hidden"))) #define __exported __attribute__((__visibility__("default"))) #else #define __hidden #define __exported #endif #define __offsetof(type, field) offsetof(type, field) #define __rangeof(type, start, end) \ (__offsetof(type, end) - __offsetof(type, start)) /* * Given the pointer x to the member m of the struct s, return * a pointer to the containing structure. When using GCC, we first * assign pointer x to a local variable, to check that its type is * compatible with member m. */ #if __GNUC_PREREQ__(3, 1) #define __containerof(x, s, m) ({ \ const volatile __typeof__(((s *)0)->m) *__x = (x); \ __DEQUALIFY(s *, (const volatile char *)__x - __offsetof(s, m));\ }) #else #define __containerof(x, s, m) \ __DEQUALIFY(s *, (const volatile char *)(x) - __offsetof(s, m)) #endif /* * Compiler-dependent macros to declare that functions take printf-like * or scanf-like arguments. They are null except for versions of gcc * that are known to support the features properly (old versions of gcc-2 * didn't permit keeping the keywords out of the application namespace). */ #if !__GNUC_PREREQ__(2, 7) && !defined(__INTEL_COMPILER) #define __printflike(fmtarg, firstvararg) #define __scanflike(fmtarg, firstvararg) #define __format_arg(fmtarg) #define __strfmonlike(fmtarg, firstvararg) #define __strftimelike(fmtarg, firstvararg) #else #define __printflike(fmtarg, firstvararg) \ __attribute__((__format__ (__printf__, fmtarg, firstvararg))) #define __scanflike(fmtarg, firstvararg) \ __attribute__((__format__ (__scanf__, fmtarg, firstvararg))) #define __format_arg(fmtarg) __attribute__((__format_arg__ (fmtarg))) #define __strfmonlike(fmtarg, firstvararg) \ __attribute__((__format__ (__strfmon__, fmtarg, firstvararg))) #define __strftimelike(fmtarg, firstvararg) \ __attribute__((__format__ (__strftime__, fmtarg, firstvararg))) #endif /* Compiler-dependent macros that rely on FreeBSD-specific extensions. */ #if defined(__FreeBSD_cc_version) && __FreeBSD_cc_version >= 300001 && \ defined(__GNUC__) && !defined(__INTEL_COMPILER) #define __printf0like(fmtarg, firstvararg) \ __attribute__((__format__ (__printf0__, fmtarg, firstvararg))) #else #define __printf0like(fmtarg, firstvararg) #endif #if defined(__GNUC__) || defined(__INTEL_COMPILER) #ifndef __INTEL_COMPILER #define __strong_reference(sym,aliassym) \ extern __typeof (sym) aliassym __attribute__ ((__alias__ (#sym))) #endif #ifdef __ELF__ #ifdef __STDC__ #define __weak_reference(sym,alias) \ __asm__(".weak " #alias); \ __asm__(".equ " #alias ", " #sym) #define __warn_references(sym,msg) \ __asm__(".section .gnu.warning." #sym); \ __asm__(".asciz \"" msg "\""); \ __asm__(".previous") #define __sym_compat(sym,impl,verid) \ __asm__(".symver " #impl ", " #sym "@" #verid) #define __sym_default(sym,impl,verid) \ __asm__(".symver " #impl ", " #sym "@@" #verid) #else #define __weak_reference(sym,alias) \ __asm__(".weak alias"); \ __asm__(".equ alias, sym") #define __warn_references(sym,msg) \ __asm__(".section .gnu.warning.sym"); \ __asm__(".asciz \"msg\""); \ __asm__(".previous") #define __sym_compat(sym,impl,verid) \ __asm__(".symver impl, sym@verid") #define __sym_default(impl,sym,verid) \ __asm__(".symver impl, sym@@verid") #endif /* __STDC__ */ #else /* !__ELF__ */ #ifdef __STDC__ #define __weak_reference(sym,alias) \ __asm__(".stabs \"_" #alias "\",11,0,0,0"); \ __asm__(".stabs \"_" #sym "\",1,0,0,0") #define __warn_references(sym,msg) \ __asm__(".stabs \"" msg "\",30,0,0,0"); \ __asm__(".stabs \"_" #sym "\",1,0,0,0") #else #define __weak_reference(sym,alias) \ __asm__(".stabs \"_/**/alias\",11,0,0,0"); \ __asm__(".stabs \"_/**/sym\",1,0,0,0") #define __warn_references(sym,msg) \ __asm__(".stabs msg,30,0,0,0"); \ __asm__(".stabs \"_/**/sym\",1,0,0,0") #endif /* __STDC__ */ #endif /* __ELF__ */ #endif /* __GNUC__ || __INTEL_COMPILER */ #ifndef __FBSDID #define __FBSDID(s) struct __hack #endif #ifndef __RCSID #define __RCSID(s) struct __hack #endif #ifndef __RCSID_SOURCE #define __RCSID_SOURCE(s) struct __hack #endif #ifndef __SCCSID #define __SCCSID(s) struct __hack #endif #ifndef __COPYRIGHT #define __COPYRIGHT(s) struct __hack #endif #ifndef __DECONST #define __DECONST(type, var) ((type)(__uintptr_t)(const void *)(var)) #endif #ifndef __DEVOLATILE #define __DEVOLATILE(type, var) ((type)(__uintptr_t)(volatile void *)(var)) #endif #ifndef __DEQUALIFY #define __DEQUALIFY(type, var) ((type)(__uintptr_t)(const volatile void *)(var)) #endif /*- * The following definitions are an extension of the behavior originally * implemented in , but with a different level of granularity. * POSIX.1 requires that the macros we test be defined before any standard * header file is included. * * Here's a quick run-down of the versions: * defined(_POSIX_SOURCE) 1003.1-1988 * _POSIX_C_SOURCE == 1 1003.1-1990 * _POSIX_C_SOURCE == 2 1003.2-1992 C Language Binding Option * _POSIX_C_SOURCE == 199309 1003.1b-1993 * _POSIX_C_SOURCE == 199506 1003.1c-1995, 1003.1i-1995, * and the omnibus ISO/IEC 9945-1: 1996 * _POSIX_C_SOURCE == 200112 1003.1-2001 * _POSIX_C_SOURCE == 200809 1003.1-2008 * * In addition, the X/Open Portability Guide, which is now the Single UNIX * Specification, defines a feature-test macro which indicates the version of * that specification, and which subsumes _POSIX_C_SOURCE. * * Our macros begin with two underscores to avoid namespace screwage. */ /* Deal with IEEE Std. 1003.1-1990, in which _POSIX_C_SOURCE == 1. */ #if defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE == 1 #undef _POSIX_C_SOURCE /* Probably illegal, but beyond caring now. */ #define _POSIX_C_SOURCE 199009 #endif /* Deal with IEEE Std. 1003.2-1992, in which _POSIX_C_SOURCE == 2. */ #if defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE == 2 #undef _POSIX_C_SOURCE #define _POSIX_C_SOURCE 199209 #endif /* Deal with various X/Open Portability Guides and Single UNIX Spec. */ #ifdef _XOPEN_SOURCE #if _XOPEN_SOURCE - 0 >= 700 #define __XSI_VISIBLE 700 #undef _POSIX_C_SOURCE #define _POSIX_C_SOURCE 200809 #elif _XOPEN_SOURCE - 0 >= 600 #define __XSI_VISIBLE 600 #undef _POSIX_C_SOURCE #define _POSIX_C_SOURCE 200112 #elif _XOPEN_SOURCE - 0 >= 500 #define __XSI_VISIBLE 500 #undef _POSIX_C_SOURCE #define _POSIX_C_SOURCE 199506 #endif #endif /* * Deal with all versions of POSIX. The ordering relative to the tests above is * important. */ #if defined(_POSIX_SOURCE) && !defined(_POSIX_C_SOURCE) #define _POSIX_C_SOURCE 198808 #endif #ifdef _POSIX_C_SOURCE #if _POSIX_C_SOURCE >= 200809 #define __POSIX_VISIBLE 200809 #define __ISO_C_VISIBLE 1999 #elif _POSIX_C_SOURCE >= 200112 #define __POSIX_VISIBLE 200112 #define __ISO_C_VISIBLE 1999 #elif _POSIX_C_SOURCE >= 199506 #define __POSIX_VISIBLE 199506 #define __ISO_C_VISIBLE 1990 #elif _POSIX_C_SOURCE >= 199309 #define __POSIX_VISIBLE 199309 #define __ISO_C_VISIBLE 1990 #elif _POSIX_C_SOURCE >= 199209 #define __POSIX_VISIBLE 199209 #define __ISO_C_VISIBLE 1990 #elif _POSIX_C_SOURCE >= 199009 #define __POSIX_VISIBLE 199009 #define __ISO_C_VISIBLE 1990 #else #define __POSIX_VISIBLE 198808 #define __ISO_C_VISIBLE 0 #endif /* _POSIX_C_SOURCE */ #else /*- * Deal with _ANSI_SOURCE: * If it is defined, and no other compilation environment is explicitly * requested, then define our internal feature-test macros to zero. This * makes no difference to the preprocessor (undefined symbols in preprocessing * expressions are defined to have value zero), but makes it more convenient for * a test program to print out the values. * * If a program mistakenly defines _ANSI_SOURCE and some other macro such as * _POSIX_C_SOURCE, we will assume that it wants the broader compilation * environment (and in fact we will never get here). */ #if defined(_ANSI_SOURCE) /* Hide almost everything. */ #define __POSIX_VISIBLE 0 #define __XSI_VISIBLE 0 #define __BSD_VISIBLE 0 #define __ISO_C_VISIBLE 1990 #elif defined(_C99_SOURCE) /* Localism to specify strict C99 env. */ #define __POSIX_VISIBLE 0 #define __XSI_VISIBLE 0 #define __BSD_VISIBLE 0 #define __ISO_C_VISIBLE 1999 #elif defined(_C11_SOURCE) /* Localism to specify strict C11 env. */ #define __POSIX_VISIBLE 0 #define __XSI_VISIBLE 0 #define __BSD_VISIBLE 0 #define __ISO_C_VISIBLE 2011 #elif defined(_GNU_SOURCE) /* Everything and the kitchen sink. */ #define __POSIX_VISIBLE 200809 #define __XSI_VISIBLE 700 #define __BSD_VISIBLE 1 #define __ISO_C_VISIBLE 2011 #define __GNU_VISIBLE 1 #else /* Default: everything except __GNU_VISIBLE. */ #define __POSIX_VISIBLE 200809 #define __XSI_VISIBLE 700 #define __BSD_VISIBLE 1 #define __ISO_C_VISIBLE 2011 #endif #endif #endif /* !_SYS_CDEFS_H_ */ 07070100000046000081a40000000000000000000000016181423c00001a4f000000000000000000000000000000000000002600000000./usr/nvptx-none/include/sys/config.h#ifndef __SYS_CONFIG_H__ #define __SYS_CONFIG_H__ #include /* floating point macros */ #include /* POSIX defs */ #ifdef __aarch64__ #define MALLOC_ALIGNMENT 16 #endif /* exceptions first */ #if defined(__H8500__) || defined(__W65__) #define __SMALL_BITFIELDS /* ??? This conditional is true for the h8500 and the w65, defining H8300 in those cases probably isn't the right thing to do. */ #define H8300 1 #endif /* 16 bit integer machines */ #if defined(__Z8001__) || defined(__Z8002__) || defined(__H8500__) || defined(__W65__) || defined (__mn10200__) || defined (__AVR__) #undef INT_MAX #undef UINT_MAX #define INT_MAX 32767 #define UINT_MAX 65535 #endif #if defined (__H8300__) || defined (__H8300H__) || defined(__H8300S__) || defined (__H8300SX__) #define __SMALL_BITFIELDS #define H8300 1 #undef INT_MAX #undef UINT_MAX #define INT_MAX __INT_MAX__ #define UINT_MAX (__INT_MAX__ * 2U + 1) #endif #if (defined(__CR16__) || defined(__CR16C__) ||defined(__CR16CP__)) #ifndef __INT32__ #define __SMALL_BITFIELDS #undef INT_MAX #undef UINT_MAX #define INT_MAX 32767 #define UINT_MAX (__INT_MAX__ * 2U + 1) #else /* INT32 */ #undef INT_MAX #undef UINT_MAX #define INT_MAX 2147483647 #define UINT_MAX (__INT_MAX__ * 2U + 1) #endif /* INT32 */ #endif /* CR16C */ #if defined (__xc16x__) || defined (__xc16xL__) || defined (__xc16xS__) #define __SMALL_BITFIELDS #endif #ifdef __W65__ #define __SMALL_BITFIELDS #endif #if defined(__D10V__) #define __SMALL_BITFIELDS #undef INT_MAX #undef UINT_MAX #define INT_MAX __INT_MAX__ #define UINT_MAX (__INT_MAX__ * 2U + 1) #define _POINTER_INT short #endif #if defined(__mc68hc11__) || defined(__mc68hc12__) || defined(__mc68hc1x__) #undef INT_MAX #undef UINT_MAX #define INT_MAX __INT_MAX__ #define UINT_MAX (__INT_MAX__ * 2U + 1) #define _POINTER_INT short #endif #ifdef ___AM29K__ #define _FLOAT_RET double #endif #ifdef __i386__ #ifndef __unix__ /* in other words, go32 */ #define _FLOAT_RET double #endif #if defined(__linux__) || defined(__RDOS__) /* we want the reentrancy structure to be returned by a function */ #define __DYNAMIC_REENT__ #define HAVE_GETDATE #define _HAVE_SYSTYPES #define _READ_WRITE_RETURN_TYPE _ssize_t #define __LARGE64_FILES 1 /* we use some glibc header files so turn on glibc large file feature */ #define _LARGEFILE64_SOURCE 1 #endif #endif #ifdef __mn10200__ #define __SMALL_BITFIELDS #endif #ifdef __AVR__ #define __SMALL_BITFIELDS #define _POINTER_INT short #endif #ifdef __v850 #define __ATTRIBUTE_IMPURE_PTR__ __attribute__((__sda__)) #endif /* For the PowerPC eabi, force the _impure_ptr to be in .sdata */ #if defined(__PPC__) #if defined(_CALL_SYSV) #define __ATTRIBUTE_IMPURE_PTR__ __attribute__((__section__(".sdata"))) #endif #ifdef __SPE__ #define _LONG_DOUBLE double #endif #endif /* Configure small REENT structure for Xilinx MicroBlaze platforms */ #if defined (__MICROBLAZE__) #ifndef _REENT_SMALL #define _REENT_SMALL #endif /* Xilinx XMK uses Unix98 mutex */ #ifdef __XMK__ #define _UNIX98_THREAD_MUTEX_ATTRIBUTES #endif #endif #if defined(__mips__) && !defined(__rtems__) #define __ATTRIBUTE_IMPURE_PTR__ __attribute__((__section__(".sdata"))) #endif #ifdef __xstormy16__ #define __SMALL_BITFIELDS #undef INT_MAX #undef UINT_MAX #define INT_MAX __INT_MAX__ #define UINT_MAX (__INT_MAX__ * 2U + 1) #define MALLOC_ALIGNMENT 8 #define _POINTER_INT short #define __BUFSIZ__ 16 #define _REENT_SMALL #endif #if defined __MSP430__ #ifndef _REENT_SMALL #define _REENT_SMALL #endif #define __SMALL_BITFIELDS #ifdef __MSP430X_LARGE__ #define _POINTER_INT long #else #define _POINTER_INT int #endif #endif #ifdef __m32c__ #define __SMALL_BITFIELDS #undef INT_MAX #undef UINT_MAX #define INT_MAX __INT_MAX__ #define UINT_MAX (__INT_MAX__ * 2U + 1) #define MALLOC_ALIGNMENT 8 #if defined(__r8c_cpu__) || defined(__m16c_cpu__) #define _POINTER_INT short #else #define _POINTER_INT long #endif #define __BUFSIZ__ 16 #define _REENT_SMALL #endif /* __m32c__ */ #ifdef __SPU__ #define MALLOC_ALIGNMENT 16 #define __CUSTOM_FILE_IO__ #endif /* This block should be kept in sync with GCC's limits.h. The point of having these definitions here is to not include limits.h, which would pollute the user namespace, while still using types of the the correct widths when deciding how to define __int32_t and __int64_t. */ #ifndef __INT_MAX__ # ifdef INT_MAX # define __INT_MAX__ INT_MAX # else # define __INT_MAX__ 2147483647 # endif #endif #ifndef __LONG_MAX__ # ifdef LONG_MAX # define __LONG_MAX__ LONG_MAX # else # if defined (__alpha__) || (defined (__sparc__) && defined(__arch64__)) \ || defined (__sparcv9) # define __LONG_MAX__ 9223372036854775807L # else # define __LONG_MAX__ 2147483647L # endif /* __alpha__ || sparc64 */ # endif #endif /* End of block that should be kept in sync with GCC's limits.h. */ #ifndef _POINTER_INT #define _POINTER_INT long #endif #ifdef __frv__ #define __ATTRIBUTE_IMPURE_PTR__ __attribute__((__section__(".sdata"))) #endif #undef __RAND_MAX #if __INT_MAX__ == 32767 #define __RAND_MAX 32767 #else #define __RAND_MAX 0x7fffffff #endif #if defined(__CYGWIN__) #include #if !defined (__STRICT_ANSI__) || (__STDC_VERSION__ >= 199901L) #define __USE_XOPEN2K 1 #endif #endif #if defined(__rtems__) #define __FILENAME_MAX__ 255 #define _READ_WRITE_RETURN_TYPE _ssize_t #define __DYNAMIC_REENT__ #define _REENT_GLOBAL_ATEXIT #endif #ifndef __EXPORT #define __EXPORT #endif #ifndef __IMPORT #define __IMPORT #endif /* Define return type of read/write routines. In POSIX, the return type for read()/write() is "ssize_t" but legacy newlib code has been using "int" for some time. If not specified, "int" is defaulted. */ #ifndef _READ_WRITE_RETURN_TYPE #define _READ_WRITE_RETURN_TYPE int #endif /* Define `count' parameter of read/write routines. In POSIX, the `count' parameter is "size_t" but legacy newlib code has been using "int" for some time. If not specified, "int" is defaulted. */ #ifndef _READ_WRITE_BUFSIZE_TYPE #define _READ_WRITE_BUFSIZE_TYPE int #endif #ifndef __WCHAR_MAX__ #if __INT_MAX__ == 32767 || defined (_WIN32) #define __WCHAR_MAX__ 0xffffu #endif #endif /* See if small reent asked for at configuration time and is not chosen by the platform by default. */ #ifdef _WANT_REENT_SMALL #ifndef _REENT_SMALL #define _REENT_SMALL #endif #endif /* If _MB_EXTENDED_CHARSETS_ALL is set, we want all of the extended charsets. The extended charsets add a few functions and a couple of tables of a few K each. */ #ifdef _MB_EXTENDED_CHARSETS_ALL #define _MB_EXTENDED_CHARSETS_ISO 1 #define _MB_EXTENDED_CHARSETS_WINDOWS 1 #endif #endif /* __SYS_CONFIG_H__ */ 07070100000047000081a40000000000000000000000016181423c00000032000000000000000000000000000000000000002b00000000./usr/nvptx-none/include/sys/custom_file.h#error System-specific custom_file.h is missing. 07070100000048000081a40000000000000000000000016181423c000000ab000000000000000000000000000000000000002300000000./usr/nvptx-none/include/sys/dir.h/* BSD predecessor of POSIX.1 and struct dirent */ #ifndef _SYS_DIR_H_ #define _SYS_DIR_H_ #include #define direct dirent #endif /*_SYS_DIR_H_*/ 07070100000049000081a40000000000000000000000016181423c0000018b000000000000000000000000000000000000002600000000./usr/nvptx-none/include/sys/dirent.h/* includes , which is this file. On a system which supports , this file is overridden by dirent.h in the libc/sys/.../sys directory. On a system which does not support , we will get this file which uses #error to force an error. */ #ifdef __cplusplus extern "C" { #endif #error " not supported" #ifdef __cplusplus } #endif 0707010000004a000081a40000000000000000000000016181423c00001cf9000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/errno.h/* errno is not a global variable, because that would make using it non-reentrant. Instead, its address is returned by the function __errno. */ #ifndef _SYS_ERRNO_H_ #ifdef __cplusplus extern "C" { #endif #define _SYS_ERRNO_H_ #include #ifndef _REENT_ONLY #define errno (*__errno()) extern int *__errno _PARAMS ((void)); #endif /* Please don't use these variables directly. Use strerror instead. */ extern __IMPORT _CONST char * _CONST _sys_errlist[]; extern __IMPORT int _sys_nerr; #ifdef __CYGWIN__ extern __IMPORT const char * const sys_errlist[]; extern __IMPORT int sys_nerr; extern __IMPORT char *program_invocation_name; extern __IMPORT char *program_invocation_short_name; #endif #define __errno_r(ptr) ((ptr)->_errno) #define EPERM 1 /* Not super-user */ #define ENOENT 2 /* No such file or directory */ #define ESRCH 3 /* No such process */ #define EINTR 4 /* Interrupted system call */ #define EIO 5 /* I/O error */ #define ENXIO 6 /* No such device or address */ #define E2BIG 7 /* Arg list too long */ #define ENOEXEC 8 /* Exec format error */ #define EBADF 9 /* Bad file number */ #define ECHILD 10 /* No children */ #define EAGAIN 11 /* No more processes */ #define ENOMEM 12 /* Not enough core */ #define EACCES 13 /* Permission denied */ #define EFAULT 14 /* Bad address */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ENOTBLK 15 /* Block device required */ #endif #define EBUSY 16 /* Mount device busy */ #define EEXIST 17 /* File exists */ #define EXDEV 18 /* Cross-device link */ #define ENODEV 19 /* No such device */ #define ENOTDIR 20 /* Not a directory */ #define EISDIR 21 /* Is a directory */ #define EINVAL 22 /* Invalid argument */ #define ENFILE 23 /* Too many open files in system */ #define EMFILE 24 /* Too many open files */ #define ENOTTY 25 /* Not a typewriter */ #define ETXTBSY 26 /* Text file busy */ #define EFBIG 27 /* File too large */ #define ENOSPC 28 /* No space left on device */ #define ESPIPE 29 /* Illegal seek */ #define EROFS 30 /* Read only file system */ #define EMLINK 31 /* Too many links */ #define EPIPE 32 /* Broken pipe */ #define EDOM 33 /* Math arg out of domain of func */ #define ERANGE 34 /* Math result not representable */ #define ENOMSG 35 /* No message of desired type */ #define EIDRM 36 /* Identifier removed */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ECHRNG 37 /* Channel number out of range */ #define EL2NSYNC 38 /* Level 2 not synchronized */ #define EL3HLT 39 /* Level 3 halted */ #define EL3RST 40 /* Level 3 reset */ #define ELNRNG 41 /* Link number out of range */ #define EUNATCH 42 /* Protocol driver not attached */ #define ENOCSI 43 /* No CSI structure available */ #define EL2HLT 44 /* Level 2 halted */ #endif #define EDEADLK 45 /* Deadlock condition */ #define ENOLCK 46 /* No record locks available */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define EBADE 50 /* Invalid exchange */ #define EBADR 51 /* Invalid request descriptor */ #define EXFULL 52 /* Exchange full */ #define ENOANO 53 /* No anode */ #define EBADRQC 54 /* Invalid request code */ #define EBADSLT 55 /* Invalid slot */ #define EDEADLOCK 56 /* File locking deadlock error */ #define EBFONT 57 /* Bad font file fmt */ #endif #define ENOSTR 60 /* Device not a stream */ #define ENODATA 61 /* No data (for no delay io) */ #define ETIME 62 /* Timer expired */ #define ENOSR 63 /* Out of streams resources */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ENONET 64 /* Machine is not on the network */ #define ENOPKG 65 /* Package not installed */ #define EREMOTE 66 /* The object is remote */ #endif #define ENOLINK 67 /* The link has been severed */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define EADV 68 /* Advertise error */ #define ESRMNT 69 /* Srmount error */ #define ECOMM 70 /* Communication error on send */ #endif #define EPROTO 71 /* Protocol error */ #define EMULTIHOP 74 /* Multihop attempted */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ELBIN 75 /* Inode is remote (not really error) */ #define EDOTDOT 76 /* Cross mount point (not really error) */ #endif #define EBADMSG 77 /* Trying to read unreadable message */ #define EFTYPE 79 /* Inappropriate file type or format */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ENOTUNIQ 80 /* Given log. name not unique */ #define EBADFD 81 /* f.d. invalid for this operation */ #define EREMCHG 82 /* Remote address changed */ #define ELIBACC 83 /* Can't access a needed shared lib */ #define ELIBBAD 84 /* Accessing a corrupted shared lib */ #define ELIBSCN 85 /* .lib section in a.out corrupted */ #define ELIBMAX 86 /* Attempting to link in too many libs */ #define ELIBEXEC 87 /* Attempting to exec a shared library */ #endif #define ENOSYS 88 /* Function not implemented */ #ifdef __CYGWIN__ #define ENMFILE 89 /* No more files */ #endif #define ENOTEMPTY 90 /* Directory not empty */ #define ENAMETOOLONG 91 /* File or path name too long */ #define ELOOP 92 /* Too many symbolic links */ #define EOPNOTSUPP 95 /* Operation not supported on transport endpoint */ #define EPFNOSUPPORT 96 /* Protocol family not supported */ #define ECONNRESET 104 /* Connection reset by peer */ #define ENOBUFS 105 /* No buffer space available */ #define EAFNOSUPPORT 106 /* Address family not supported by protocol family */ #define EPROTOTYPE 107 /* Protocol wrong type for socket */ #define ENOTSOCK 108 /* Socket operation on non-socket */ #define ENOPROTOOPT 109 /* Protocol not available */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ESHUTDOWN 110 /* Can't send after socket shutdown */ #endif #define ECONNREFUSED 111 /* Connection refused */ #define EADDRINUSE 112 /* Address already in use */ #define ECONNABORTED 113 /* Connection aborted */ #define ENETUNREACH 114 /* Network is unreachable */ #define ENETDOWN 115 /* Network interface is not configured */ #define ETIMEDOUT 116 /* Connection timed out */ #define EHOSTDOWN 117 /* Host is down */ #define EHOSTUNREACH 118 /* Host is unreachable */ #define EINPROGRESS 119 /* Connection already in progress */ #define EALREADY 120 /* Socket already connected */ #define EDESTADDRREQ 121 /* Destination address required */ #define EMSGSIZE 122 /* Message too long */ #define EPROTONOSUPPORT 123 /* Unknown protocol */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ESOCKTNOSUPPORT 124 /* Socket type not supported */ #endif #define EADDRNOTAVAIL 125 /* Address not available */ #define ENETRESET 126 #define EISCONN 127 /* Socket is already connected */ #define ENOTCONN 128 /* Socket is not connected */ #define ETOOMANYREFS 129 #ifdef __LINUX_ERRNO_EXTENSIONS__ #define EPROCLIM 130 #define EUSERS 131 #endif #define EDQUOT 132 #define ESTALE 133 #define ENOTSUP 134 /* Not supported */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ENOMEDIUM 135 /* No medium (in tape drive) */ #endif #ifdef __CYGWIN__ #define ENOSHARE 136 /* No such host or network path */ #define ECASECLASH 137 /* Filename exists with different case */ #endif #define EILSEQ 138 #define EOVERFLOW 139 /* Value too large for defined data type */ #define ECANCELED 140 /* Operation canceled */ #define ENOTRECOVERABLE 141 /* State not recoverable */ #define EOWNERDEAD 142 /* Previous owner died */ #ifdef __LINUX_ERRNO_EXTENSIONS__ #define ESTRPIPE 143 /* Streams pipe error */ #endif #define EWOULDBLOCK EAGAIN /* Operation would block */ #define __ELASTERROR 2000 /* Users can add values starting here */ #ifdef __cplusplus } #endif #endif /* _SYS_ERRNO_H */ 0707010000004b000081a40000000000000000000000016181423c00000053000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/fcntl.h#ifndef _SYS_FCNTL_H_ #define _SYS_FCNTL_H_ #include #endif 0707010000004c000081a40000000000000000000000016181423c00001f2b000000000000000000000000000000000000002800000000./usr/nvptx-none/include/sys/features.h/* * Written by Joel Sherrill . * * COPYRIGHT (c) 1989-2000. * * On-Line Applications Research Corporation (OAR). * * Permission to use, copy, modify, and distribute this software for any * purpose without fee is hereby granted, provided that this entire notice * is included in all copies of any software which is or includes a copy * or modification of this software. * * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED * WARRANTY. IN PARTICULAR, THE AUTHOR MAKES NO REPRESENTATION * OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY OF THIS * SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE. * * $Id$ */ #ifndef _SYS_FEATURES_H #define _SYS_FEATURES_H #ifdef __cplusplus extern "C" { #endif /* Macro to test version of GCC. Returns 0 for non-GCC or too old GCC. */ #ifndef __GNUC_PREREQ # if defined __GNUC__ && defined __GNUC_MINOR__ # define __GNUC_PREREQ(maj, min) \ ((__GNUC__ << 16) + __GNUC_MINOR__ >= ((maj) << 16) + (min)) # else # define __GNUC_PREREQ(maj, min) 0 # endif #endif /* __GNUC_PREREQ */ /* Version with trailing underscores for BSD compatibility. */ #define __GNUC_PREREQ__(ma, mi) __GNUC_PREREQ(ma, mi) /* RTEMS adheres to POSIX -- 1003.1b with some features from annexes. */ #ifdef __rtems__ #define _POSIX_JOB_CONTROL 1 #define _POSIX_SAVED_IDS 1 #define _POSIX_VERSION 199309L #define _POSIX_ASYNCHRONOUS_IO 1 #define _POSIX_FSYNC 1 #define _POSIX_MAPPED_FILES 1 #define _POSIX_MEMLOCK 1 #define _POSIX_MEMLOCK_RANGE 1 #define _POSIX_MEMORY_PROTECTION 1 #define _POSIX_MESSAGE_PASSING 1 #define _POSIX_MONOTONIC_CLOCK 200112L #define _POSIX_PRIORITIZED_IO 1 #define _POSIX_PRIORITY_SCHEDULING 1 #define _POSIX_REALTIME_SIGNALS 1 #define _POSIX_SEMAPHORES 1 /* #define _POSIX_SHARED_MEMORY_OBJECTS 1 */ #define _POSIX_SYNCHRONIZED_IO 1 #define _POSIX_TIMERS 1 #define _POSIX_BARRIERS 200112L #define _POSIX_READER_WRITER_LOCKS 200112L #define _POSIX_SPIN_LOCKS 200112L /* In P1003.1b but defined by drafts at least as early as P1003.1c/D10 */ #define _POSIX_THREADS 1 #define _POSIX_THREAD_ATTR_STACKADDR 1 #define _POSIX_THREAD_ATTR_STACKSIZE 1 #define _POSIX_THREAD_PRIORITY_SCHEDULING 1 #define _POSIX_THREAD_PRIO_INHERIT 1 #define _POSIX_THREAD_PRIO_PROTECT 1 #define _POSIX_THREAD_PROCESS_SHARED 1 #define _POSIX_THREAD_SAFE_FUNCTIONS 1 /* P1003.4b/D8 defines the constants below this comment. */ #define _POSIX_SPAWN 1 #define _POSIX_TIMEOUTS 1 #define _POSIX_CPUTIME 1 #define _POSIX_THREAD_CPUTIME 1 #define _POSIX_SPORADIC_SERVER 1 #define _POSIX_THREAD_SPORADIC_SERVER 1 #define _POSIX_DEVICE_CONTROL 1 #define _POSIX_DEVCTL_DIRECTION 1 #define _POSIX_INTERRUPT_CONTROL 1 #define _POSIX_ADVISORY_INFO 1 /* UNIX98 added some new pthread mutex attributes */ #define _UNIX98_THREAD_MUTEX_ATTRIBUTES 1 #endif /* XMK loosely adheres to POSIX -- 1003.1 */ #ifdef __XMK__ #define _POSIX_THREADS 1 #define _POSIX_THREAD_PRIORITY_SCHEDULING 1 #endif #ifdef __svr4__ # define _POSIX_JOB_CONTROL 1 # define _POSIX_SAVED_IDS 1 # define _POSIX_VERSION 199009L #endif #ifdef __CYGWIN__ #if !defined(__STRICT_ANSI__) || defined(__cplusplus) || __STDC_VERSION__ >= 199901L #define _POSIX_VERSION 200112L #define _POSIX2_VERSION 200112L #define _XOPEN_VERSION 600 #define _POSIX_ADVISORY_INFO 200112L /* #define _POSIX_ASYNCHRONOUS_IO -1 */ /* #define _POSIX_BARRIERS -1 */ #define _POSIX_CHOWN_RESTRICTED 1 #define _POSIX_CLOCK_SELECTION 200112L #define _POSIX_CPUTIME 200112L #define _POSIX_FSYNC 200112L #define _POSIX_IPV6 200112L #define _POSIX_JOB_CONTROL 1 #define _POSIX_MAPPED_FILES 200112L /* #define _POSIX_MEMLOCK -1 */ #define _POSIX_MEMLOCK_RANGE 200112L #define _POSIX_MEMORY_PROTECTION 200112L #define _POSIX_MESSAGE_PASSING 200112L #define _POSIX_MONOTONIC_CLOCK 200112L #define _POSIX_NO_TRUNC 1 /* #define _POSIX_PRIORITIZED_IO -1 */ #define _POSIX_PRIORITY_SCHEDULING 200112L #define _POSIX_RAW_SOCKETS 200112L #define _POSIX_READER_WRITER_LOCKS 200112L #define _POSIX_REALTIME_SIGNALS 200112L #define _POSIX_REGEXP 1 #define _POSIX_SAVED_IDS 1 #define _POSIX_SEMAPHORES 200112L #define _POSIX_SHARED_MEMORY_OBJECTS 200112L #define _POSIX_SHELL 1 /* #define _POSIX_SPAWN -1 */ #define _POSIX_SPIN_LOCKS 200112L /* #define _POSIX_SPORADIC_SERVER -1 */ #define _POSIX_SYNCHRONIZED_IO 200112L #define _POSIX_THREAD_ATTR_STACKADDR 200112L #define _POSIX_THREAD_ATTR_STACKSIZE 200112L #define _POSIX_THREAD_CPUTIME 200112L /* #define _POSIX_THREAD_PRIO_INHERIT -1 */ /* #define _POSIX_THREAD_PRIO_PROTECT -1 */ #define _POSIX_THREAD_PRIORITY_SCHEDULING 200112L #define _POSIX_THREAD_PROCESS_SHARED 200112L #define _POSIX_THREAD_SAFE_FUNCTIONS 200112L /* #define _POSIX_THREAD_SPORADIC_SERVER -1 */ #define _POSIX_THREADS 200112L /* #define _POSIX_TIMEOUTS -1 */ #define _POSIX_TIMERS 1 /* #define _POSIX_TRACE -1 */ /* #define _POSIX_TRACE_EVENT_FILTER -1 */ /* #define _POSIX_TRACE_INHERIT -1 */ /* #define _POSIX_TRACE_LOG -1 */ /* #define _POSIX_TYPED_MEMORY_OBJECTS -1 */ #define _POSIX_VDISABLE '\0' #define _POSIX2_C_BIND 200112L #define _POSIX2_C_DEV 200112L #define _POSIX2_CHAR_TERM 200112L /* #define _POSIX2_FORT_DEV -1 */ /* #define _POSIX2_FORT_RUN -1 */ /* #define _POSIX2_LOCALEDEF -1 */ /* #define _POSIX2_PBS -1 */ /* #define _POSIX2_PBS_ACCOUNTING -1 */ /* #define _POSIX2_PBS_CHECKPOINT -1 */ /* #define _POSIX2_PBS_LOCATE -1 */ /* #define _POSIX2_PBS_MESSAGE -1 */ /* #define _POSIX2_PBS_TRACK -1 */ #define _POSIX2_SW_DEV 200112L #define _POSIX2_UPE 200112L #define _POSIX_V6_ILP32_OFF32 -1 #ifdef __LP64__ #define _POSIX_V6_ILP32_OFFBIG -1 #define _POSIX_V6_LP64_OFF64 1 #define _POSIX_V6_LPBIG_OFFBIG 1 #else #define _POSIX_V6_ILP32_OFFBIG 1 #define _POSIX_V6_LP64_OFF64 -1 #define _POSIX_V6_LPBIG_OFFBIG -1 #endif #define _XBS5_ILP32_OFF32 _POSIX_V6_ILP32_OFF32 #define _XBS5_ILP32_OFFBIG _POSIX_V6_ILP32_OFFBIG #define _XBS5_LP64_OFF64 _POSIX_V6_LP64_OFF64 #define _XBS5_LPBIG_OFFBIG _POSIX_V6_LPBIG_OFFBIG #define _XOPEN_CRYPT 1 #define _XOPEN_ENH_I18N 1 /* #define _XOPEN_LEGACY -1 */ /* #define _XOPEN_REALTIME -1 */ /* #define _XOPEN_REALTIME_THREADS -1 */ #define _XOPEN_SHM 1 /* #define _XOPEN_STREAMS -1 */ /* #define _XOPEN_UNIX -1 */ #endif /* !__STRICT_ANSI__ || __cplusplus || __STDC_VERSION__ >= 199901L */ /* The value corresponds to UNICODE version 4.0, which is the version supported by XP. Newlib supports 5.2 (2011) but so far Cygwin needs the MS conversions for double-byte charsets. */ #define __STDC_ISO_10646__ 200305L #endif /* __CYGWIN__ */ /* Per the permission given in POSIX.1-2008 section 2.2.1, define * _POSIX_C_SOURCE if _XOPEN_SOURCE is defined and _POSIX_C_SOURCE is not. * (_XOPEN_SOURCE indicates that XSI extensions are desired by an application.) * This permission is first granted in 2008, but use it for older ones, also. * Allow for _XOPEN_SOURCE to be empty (from the earliest form of it, before it * was required to have specific values). */ #if !defined(_POSIX_C_SOURCE) && defined(_XOPEN_SOURCE) #if (_XOPEN_SOURCE - 0) == 700 /* POSIX.1-2008 */ #define _POSIX_C_SOURCE 200809L #elif (_XOPEN_SOURCE - 0) == 600 /* POSIX.1-2001 or 2004 */ #define _POSIX_C_SOURCE 200112L #elif (_XOPEN_SOURCE - 0) == 500 /* POSIX.1-1995 */ #define _POSIX_C_SOURCE 199506L #elif (_XOPEN_SOURCE - 0) < 500 /* really old */ #define _POSIX_C_SOURCE 2 #endif #endif #ifdef __cplusplus } #endif #endif /* _SYS_FEATURES_H */ 0707010000004d000081a40000000000000000000000016181423c00000018000000000000000000000000000000000000002400000000./usr/nvptx-none/include/sys/file.h #include 0707010000004e000081a40000000000000000000000016181423c00000aea000000000000000000000000000000000000002800000000./usr/nvptx-none/include/sys/iconvnls.h/* * Copyright (c) 2003-2004, Artem B. Bityuckiy. * Rights transferred to Franklin Electronic Publishers. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. */ /* * Funtions, macros, etc implimented in iconv library but used by other * NLS-related subsystems too. */ #ifndef __SYS_ICONVNLS_H__ #define __SYS_ICONVNLS_H__ #include <_ansi.h> #include #include #include /* Iconv data path environment variable name */ #define NLS_ENVVAR_NAME "NLSPATH" /* Default NLSPATH value */ #define ICONV_DEFAULT_NLSPATH "/usr/locale" /* Direction markers */ #define ICONV_NLS_FROM 0 #define ICONV_NLS_TO 1 _VOID _EXFUN(_iconv_nls_get_state, (iconv_t cd, mbstate_t *ps, int direction)); int _EXFUN(_iconv_nls_set_state, (iconv_t cd, mbstate_t *ps, int direction)); int _EXFUN(_iconv_nls_is_stateful, (iconv_t cd, int direction)); int _EXFUN(_iconv_nls_get_mb_cur_max, (iconv_t cd, int direction)); size_t _EXFUN(_iconv_nls_conv, (struct _reent *rptr, iconv_t cd, _CONST char **inbuf, size_t *inbytesleft, char **outbuf, size_t *outbytesleft)); _CONST char * _EXFUN(_iconv_nls_construct_filename, (struct _reent *rptr, _CONST char *file, _CONST char *dir, _CONST char *ext)); int _EXFUN(_iconv_nls_open, (struct _reent *rptr, _CONST char *encoding, iconv_t *towc, iconv_t *fromwc, int flag)); char * _EXFUN(_iconv_resolve_encoding_name, (struct _reent *rptr, _CONST char *ca)); #endif /* __SYS_ICONVNLS_H__ */ 0707010000004f000081a40000000000000000000000016181423c00000325000000000000000000000000000000000000002400000000./usr/nvptx-none/include/sys/lock.h#ifndef __SYS_LOCK_H__ #define __SYS_LOCK_H__ /* dummy lock routines for single-threaded aps */ typedef int _LOCK_T; typedef int _LOCK_RECURSIVE_T; #include <_ansi.h> #define __LOCK_INIT(class,lock) static int lock = 0; #define __LOCK_INIT_RECURSIVE(class,lock) static int lock = 0; #define __lock_init(lock) (_CAST_VOID 0) #define __lock_init_recursive(lock) (_CAST_VOID 0) #define __lock_close(lock) (_CAST_VOID 0) #define __lock_close_recursive(lock) (_CAST_VOID 0) #define __lock_acquire(lock) (_CAST_VOID 0) #define __lock_acquire_recursive(lock) (_CAST_VOID 0) #define __lock_try_acquire(lock) (_CAST_VOID 0) #define __lock_try_acquire_recursive(lock) (_CAST_VOID 0) #define __lock_release(lock) (_CAST_VOID 0) #define __lock_release_recursive(lock) (_CAST_VOID 0) #endif /* __SYS_LOCK_H__ */ 07070100000050000081a40000000000000000000000016181423c00000234000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/param.h/* This is a dummy file, not customized for any particular system. If there is a param.h in libc/sys/SYSDIR/sys, it will override this one. */ #ifndef _SYS_PARAM_H # define _SYS_PARAM_H #include #include #include #include #ifndef HZ # define HZ (60) #endif #ifndef NOFILE # define NOFILE (60) #endif #ifndef PATHSIZE # define PATHSIZE (1024) #endif #define MAXPATHLEN PATH_MAX #define MAX(a,b) ((a) > (b) ? (a) : (b)) #define MIN(a,b) ((a) < (b) ? (a) : (b)) #endif 07070100000051000081a40000000000000000000000016181423c0000591a000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/queue.h/*- * Copyright (c) 1991, 1993 * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)queue.h 8.5 (Berkeley) 8/20/94 * $FreeBSD$ */ #ifndef _SYS_QUEUE_H_ #define _SYS_QUEUE_H_ #include /* * This file defines four types of data structures: singly-linked lists, * singly-linked tail queues, lists and tail queues. * * A singly-linked list is headed by a single forward pointer. The elements * are singly linked for minimum space and pointer manipulation overhead at * the expense of O(n) removal for arbitrary elements. New elements can be * added to the list after an existing element or at the head of the list. * Elements being removed from the head of the list should use the explicit * macro for this purpose for optimum efficiency. A singly-linked list may * only be traversed in the forward direction. Singly-linked lists are ideal * for applications with large datasets and few or no removals or for * implementing a LIFO queue. * * A singly-linked tail queue is headed by a pair of pointers, one to the * head of the list and the other to the tail of the list. The elements are * singly linked for minimum space and pointer manipulation overhead at the * expense of O(n) removal for arbitrary elements. New elements can be added * to the list after an existing element, at the head of the list, or at the * end of the list. Elements being removed from the head of the tail queue * should use the explicit macro for this purpose for optimum efficiency. * A singly-linked tail queue may only be traversed in the forward direction. * Singly-linked tail queues are ideal for applications with large datasets * and few or no removals or for implementing a FIFO queue. * * A list is headed by a single forward pointer (or an array of forward * pointers for a hash table header). The elements are doubly linked * so that an arbitrary element can be removed without a need to * traverse the list. New elements can be added to the list before * or after an existing element or at the head of the list. A list * may be traversed in either direction. * * A tail queue is headed by a pair of pointers, one to the head of the * list and the other to the tail of the list. The elements are doubly * linked so that an arbitrary element can be removed without a need to * traverse the list. New elements can be added to the list before or * after an existing element, at the head of the list, or at the end of * the list. A tail queue may be traversed in either direction. * * For details on the use of these macros, see the queue(3) manual page. * * * SLIST LIST STAILQ TAILQ * _HEAD + + + + * _HEAD_INITIALIZER + + + + * _ENTRY + + + + * _INIT + + + + * _EMPTY + + + + * _FIRST + + + + * _NEXT + + + + * _PREV - + - + * _LAST - - + + * _FOREACH + + + + * _FOREACH_SAFE + + + + * _FOREACH_REVERSE - - - + * _FOREACH_REVERSE_SAFE - - - + * _INSERT_HEAD + + + + * _INSERT_BEFORE - + - + * _INSERT_AFTER + + + + * _INSERT_TAIL - - + + * _CONCAT - - + + * _REMOVE_AFTER + - + - * _REMOVE_HEAD + - + - * _REMOVE + + + + * _SWAP + + + + * */ #ifdef QUEUE_MACRO_DEBUG /* Store the last 2 places the queue element or head was altered */ struct qm_trace { unsigned long lastline; unsigned long prevline; const char *lastfile; const char *prevfile; }; #define TRACEBUF struct qm_trace trace; #define TRACEBUF_INITIALIZER { __FILE__, __LINE__, NULL, 0 } , #define TRASHIT(x) do {(x) = (void *)-1;} while (0) #define QMD_SAVELINK(name, link) void **name = (void *)&(link) #define QMD_TRACE_HEAD(head) do { \ (head)->trace.prevline = (head)->trace.lastline; \ (head)->trace.prevfile = (head)->trace.lastfile; \ (head)->trace.lastline = __LINE__; \ (head)->trace.lastfile = __FILE__; \ } while (0) #define QMD_TRACE_ELEM(elem) do { \ (elem)->trace.prevline = (elem)->trace.lastline; \ (elem)->trace.prevfile = (elem)->trace.lastfile; \ (elem)->trace.lastline = __LINE__; \ (elem)->trace.lastfile = __FILE__; \ } while (0) #else #define QMD_TRACE_ELEM(elem) #define QMD_TRACE_HEAD(head) #define QMD_SAVELINK(name, link) #define TRACEBUF #define TRACEBUF_INITIALIZER #define TRASHIT(x) #endif /* QUEUE_MACRO_DEBUG */ /* * Singly-linked List declarations. */ #define SLIST_HEAD(name, type) \ struct name { \ struct type *slh_first; /* first element */ \ } #define SLIST_HEAD_INITIALIZER(head) \ { NULL } #define SLIST_ENTRY(type) \ struct { \ struct type *sle_next; /* next element */ \ } /* * Singly-linked List functions. */ #define SLIST_EMPTY(head) ((head)->slh_first == NULL) #define SLIST_FIRST(head) ((head)->slh_first) #define SLIST_FOREACH(var, head, field) \ for ((var) = SLIST_FIRST((head)); \ (var); \ (var) = SLIST_NEXT((var), field)) #define SLIST_FOREACH_SAFE(var, head, field, tvar) \ for ((var) = SLIST_FIRST((head)); \ (var) && ((tvar) = SLIST_NEXT((var), field), 1); \ (var) = (tvar)) #define SLIST_FOREACH_PREVPTR(var, varp, head, field) \ for ((varp) = &SLIST_FIRST((head)); \ ((var) = *(varp)) != NULL; \ (varp) = &SLIST_NEXT((var), field)) #define SLIST_INIT(head) do { \ SLIST_FIRST((head)) = NULL; \ } while (0) #define SLIST_INSERT_AFTER(slistelm, elm, field) do { \ SLIST_NEXT((elm), field) = SLIST_NEXT((slistelm), field); \ SLIST_NEXT((slistelm), field) = (elm); \ } while (0) #define SLIST_INSERT_HEAD(head, elm, field) do { \ SLIST_NEXT((elm), field) = SLIST_FIRST((head)); \ SLIST_FIRST((head)) = (elm); \ } while (0) #define SLIST_NEXT(elm, field) ((elm)->field.sle_next) #define SLIST_REMOVE(head, elm, type, field) do { \ QMD_SAVELINK(oldnext, (elm)->field.sle_next); \ if (SLIST_FIRST((head)) == (elm)) { \ SLIST_REMOVE_HEAD((head), field); \ } \ else { \ struct type *curelm = SLIST_FIRST((head)); \ while (SLIST_NEXT(curelm, field) != (elm)) \ curelm = SLIST_NEXT(curelm, field); \ SLIST_REMOVE_AFTER(curelm, field); \ } \ TRASHIT(*oldnext); \ } while (0) #define SLIST_REMOVE_AFTER(elm, field) do { \ SLIST_NEXT(elm, field) = \ SLIST_NEXT(SLIST_NEXT(elm, field), field); \ } while (0) #define SLIST_REMOVE_HEAD(head, field) do { \ SLIST_FIRST((head)) = SLIST_NEXT(SLIST_FIRST((head)), field); \ } while (0) #define SLIST_SWAP(head1, head2, type) do { \ struct type *swap_first = SLIST_FIRST(head1); \ SLIST_FIRST(head1) = SLIST_FIRST(head2); \ SLIST_FIRST(head2) = swap_first; \ } while (0) /* * Singly-linked Tail queue declarations. */ #define STAILQ_HEAD(name, type) \ struct name { \ struct type *stqh_first;/* first element */ \ struct type **stqh_last;/* addr of last next element */ \ } #define STAILQ_HEAD_INITIALIZER(head) \ { NULL, &(head).stqh_first } #define STAILQ_ENTRY(type) \ struct { \ struct type *stqe_next; /* next element */ \ } /* * Singly-linked Tail queue functions. */ #define STAILQ_CONCAT(head1, head2) do { \ if (!STAILQ_EMPTY((head2))) { \ *(head1)->stqh_last = (head2)->stqh_first; \ (head1)->stqh_last = (head2)->stqh_last; \ STAILQ_INIT((head2)); \ } \ } while (0) #define STAILQ_EMPTY(head) ((head)->stqh_first == NULL) #define STAILQ_FIRST(head) ((head)->stqh_first) #define STAILQ_FOREACH(var, head, field) \ for((var) = STAILQ_FIRST((head)); \ (var); \ (var) = STAILQ_NEXT((var), field)) #define STAILQ_FOREACH_SAFE(var, head, field, tvar) \ for ((var) = STAILQ_FIRST((head)); \ (var) && ((tvar) = STAILQ_NEXT((var), field), 1); \ (var) = (tvar)) #define STAILQ_INIT(head) do { \ STAILQ_FIRST((head)) = NULL; \ (head)->stqh_last = &STAILQ_FIRST((head)); \ } while (0) #define STAILQ_INSERT_AFTER(head, tqelm, elm, field) do { \ if ((STAILQ_NEXT((elm), field) = STAILQ_NEXT((tqelm), field)) == NULL)\ (head)->stqh_last = &STAILQ_NEXT((elm), field); \ STAILQ_NEXT((tqelm), field) = (elm); \ } while (0) #define STAILQ_INSERT_HEAD(head, elm, field) do { \ if ((STAILQ_NEXT((elm), field) = STAILQ_FIRST((head))) == NULL) \ (head)->stqh_last = &STAILQ_NEXT((elm), field); \ STAILQ_FIRST((head)) = (elm); \ } while (0) #define STAILQ_INSERT_TAIL(head, elm, field) do { \ STAILQ_NEXT((elm), field) = NULL; \ *(head)->stqh_last = (elm); \ (head)->stqh_last = &STAILQ_NEXT((elm), field); \ } while (0) #define STAILQ_LAST(head, type, field) \ (STAILQ_EMPTY((head)) ? NULL : \ __containerof((head)->stqh_last, struct type, field.stqe_next)) #define STAILQ_NEXT(elm, field) ((elm)->field.stqe_next) #define STAILQ_REMOVE(head, elm, type, field) do { \ QMD_SAVELINK(oldnext, (elm)->field.stqe_next); \ if (STAILQ_FIRST((head)) == (elm)) { \ STAILQ_REMOVE_HEAD((head), field); \ } \ else { \ struct type *curelm = STAILQ_FIRST((head)); \ while (STAILQ_NEXT(curelm, field) != (elm)) \ curelm = STAILQ_NEXT(curelm, field); \ STAILQ_REMOVE_AFTER(head, curelm, field); \ } \ TRASHIT(*oldnext); \ } while (0) #define STAILQ_REMOVE_AFTER(head, elm, field) do { \ if ((STAILQ_NEXT(elm, field) = \ STAILQ_NEXT(STAILQ_NEXT(elm, field), field)) == NULL) \ (head)->stqh_last = &STAILQ_NEXT((elm), field); \ } while (0) #define STAILQ_REMOVE_HEAD(head, field) do { \ if ((STAILQ_FIRST((head)) = \ STAILQ_NEXT(STAILQ_FIRST((head)), field)) == NULL) \ (head)->stqh_last = &STAILQ_FIRST((head)); \ } while (0) #define STAILQ_REMOVE_HEAD_UNTIL(head, elm, field) do { \ if ((STAILQ_FIRST((head)) = STAILQ_NEXT((elm), field)) == NULL) \ (head)->stqh_last = &STAILQ_FIRST((head)); \ } while (0) #define STAILQ_SWAP(head1, head2, type) do { \ struct type *swap_first = STAILQ_FIRST(head1); \ struct type **swap_last = (head1)->stqh_last; \ STAILQ_FIRST(head1) = STAILQ_FIRST(head2); \ (head1)->stqh_last = (head2)->stqh_last; \ STAILQ_FIRST(head2) = swap_first; \ (head2)->stqh_last = swap_last; \ if (STAILQ_EMPTY(head1)) \ (head1)->stqh_last = &STAILQ_FIRST(head1); \ if (STAILQ_EMPTY(head2)) \ (head2)->stqh_last = &STAILQ_FIRST(head2); \ } while (0) /* * List declarations. */ #define LIST_HEAD(name, type) \ struct name { \ struct type *lh_first; /* first element */ \ } #define LIST_HEAD_INITIALIZER(head) \ { NULL } #define LIST_ENTRY(type) \ struct { \ struct type *le_next; /* next element */ \ struct type **le_prev; /* address of previous next element */ \ } /* * List functions. */ #if (defined(_KERNEL) && defined(INVARIANTS)) #define QMD_LIST_CHECK_HEAD(head, field) do { \ if (LIST_FIRST((head)) != NULL && \ LIST_FIRST((head))->field.le_prev != \ &LIST_FIRST((head))) \ panic("Bad list head %p first->prev != head", (head)); \ } while (0) #define QMD_LIST_CHECK_NEXT(elm, field) do { \ if (LIST_NEXT((elm), field) != NULL && \ LIST_NEXT((elm), field)->field.le_prev != \ &((elm)->field.le_next)) \ panic("Bad link elm %p next->prev != elm", (elm)); \ } while (0) #define QMD_LIST_CHECK_PREV(elm, field) do { \ if (*(elm)->field.le_prev != (elm)) \ panic("Bad link elm %p prev->next != elm", (elm)); \ } while (0) #else #define QMD_LIST_CHECK_HEAD(head, field) #define QMD_LIST_CHECK_NEXT(elm, field) #define QMD_LIST_CHECK_PREV(elm, field) #endif /* (_KERNEL && INVARIANTS) */ #define LIST_EMPTY(head) ((head)->lh_first == NULL) #define LIST_FIRST(head) ((head)->lh_first) #define LIST_FOREACH(var, head, field) \ for ((var) = LIST_FIRST((head)); \ (var); \ (var) = LIST_NEXT((var), field)) #define LIST_FOREACH_SAFE(var, head, field, tvar) \ for ((var) = LIST_FIRST((head)); \ (var) && ((tvar) = LIST_NEXT((var), field), 1); \ (var) = (tvar)) #define LIST_INIT(head) do { \ LIST_FIRST((head)) = NULL; \ } while (0) #define LIST_INSERT_AFTER(listelm, elm, field) do { \ QMD_LIST_CHECK_NEXT(listelm, field); \ if ((LIST_NEXT((elm), field) = LIST_NEXT((listelm), field)) != NULL)\ LIST_NEXT((listelm), field)->field.le_prev = \ &LIST_NEXT((elm), field); \ LIST_NEXT((listelm), field) = (elm); \ (elm)->field.le_prev = &LIST_NEXT((listelm), field); \ } while (0) #define LIST_INSERT_BEFORE(listelm, elm, field) do { \ QMD_LIST_CHECK_PREV(listelm, field); \ (elm)->field.le_prev = (listelm)->field.le_prev; \ LIST_NEXT((elm), field) = (listelm); \ *(listelm)->field.le_prev = (elm); \ (listelm)->field.le_prev = &LIST_NEXT((elm), field); \ } while (0) #define LIST_INSERT_HEAD(head, elm, field) do { \ QMD_LIST_CHECK_HEAD((head), field); \ if ((LIST_NEXT((elm), field) = LIST_FIRST((head))) != NULL) \ LIST_FIRST((head))->field.le_prev = &LIST_NEXT((elm), field);\ LIST_FIRST((head)) = (elm); \ (elm)->field.le_prev = &LIST_FIRST((head)); \ } while (0) #define LIST_NEXT(elm, field) ((elm)->field.le_next) #define LIST_PREV(elm, head, type, field) \ ((elm)->field.le_prev == &LIST_FIRST((head)) ? NULL : \ __containerof((elm)->field.le_prev, struct type, field.le_next)) #define LIST_REMOVE(elm, field) do { \ QMD_SAVELINK(oldnext, (elm)->field.le_next); \ QMD_SAVELINK(oldprev, (elm)->field.le_prev); \ QMD_LIST_CHECK_NEXT(elm, field); \ QMD_LIST_CHECK_PREV(elm, field); \ if (LIST_NEXT((elm), field) != NULL) \ LIST_NEXT((elm), field)->field.le_prev = \ (elm)->field.le_prev; \ *(elm)->field.le_prev = LIST_NEXT((elm), field); \ TRASHIT(*oldnext); \ TRASHIT(*oldprev); \ } while (0) #define LIST_SWAP(head1, head2, type, field) do { \ struct type *swap_tmp = LIST_FIRST((head1)); \ LIST_FIRST((head1)) = LIST_FIRST((head2)); \ LIST_FIRST((head2)) = swap_tmp; \ if ((swap_tmp = LIST_FIRST((head1))) != NULL) \ swap_tmp->field.le_prev = &LIST_FIRST((head1)); \ if ((swap_tmp = LIST_FIRST((head2))) != NULL) \ swap_tmp->field.le_prev = &LIST_FIRST((head2)); \ } while (0) /* * Tail queue declarations. */ #define TAILQ_HEAD(name, type) \ struct name { \ struct type *tqh_first; /* first element */ \ struct type **tqh_last; /* addr of last next element */ \ TRACEBUF \ } #define TAILQ_HEAD_INITIALIZER(head) \ { NULL, &(head).tqh_first, TRACEBUF_INITIALIZER } #define TAILQ_ENTRY(type) \ struct { \ struct type *tqe_next; /* next element */ \ struct type **tqe_prev; /* address of previous next element */ \ TRACEBUF \ } /* * Tail queue functions. */ #if (defined(_KERNEL) && defined(INVARIANTS)) #define QMD_TAILQ_CHECK_HEAD(head, field) do { \ if (!TAILQ_EMPTY(head) && \ TAILQ_FIRST((head))->field.tqe_prev != \ &TAILQ_FIRST((head))) \ panic("Bad tailq head %p first->prev != head", (head)); \ } while (0) #define QMD_TAILQ_CHECK_TAIL(head, field) do { \ if (*(head)->tqh_last != NULL) \ panic("Bad tailq NEXT(%p->tqh_last) != NULL", (head)); \ } while (0) #define QMD_TAILQ_CHECK_NEXT(elm, field) do { \ if (TAILQ_NEXT((elm), field) != NULL && \ TAILQ_NEXT((elm), field)->field.tqe_prev != \ &((elm)->field.tqe_next)) \ panic("Bad link elm %p next->prev != elm", (elm)); \ } while (0) #define QMD_TAILQ_CHECK_PREV(elm, field) do { \ if (*(elm)->field.tqe_prev != (elm)) \ panic("Bad link elm %p prev->next != elm", (elm)); \ } while (0) #else #define QMD_TAILQ_CHECK_HEAD(head, field) #define QMD_TAILQ_CHECK_TAIL(head, headname) #define QMD_TAILQ_CHECK_NEXT(elm, field) #define QMD_TAILQ_CHECK_PREV(elm, field) #endif /* (_KERNEL && INVARIANTS) */ #define TAILQ_CONCAT(head1, head2, field) do { \ if (!TAILQ_EMPTY(head2)) { \ *(head1)->tqh_last = (head2)->tqh_first; \ (head2)->tqh_first->field.tqe_prev = (head1)->tqh_last; \ (head1)->tqh_last = (head2)->tqh_last; \ TAILQ_INIT((head2)); \ QMD_TRACE_HEAD(head1); \ QMD_TRACE_HEAD(head2); \ } \ } while (0) #define TAILQ_EMPTY(head) ((head)->tqh_first == NULL) #define TAILQ_FIRST(head) ((head)->tqh_first) #define TAILQ_FOREACH(var, head, field) \ for ((var) = TAILQ_FIRST((head)); \ (var); \ (var) = TAILQ_NEXT((var), field)) #define TAILQ_FOREACH_SAFE(var, head, field, tvar) \ for ((var) = TAILQ_FIRST((head)); \ (var) && ((tvar) = TAILQ_NEXT((var), field), 1); \ (var) = (tvar)) #define TAILQ_FOREACH_REVERSE(var, head, headname, field) \ for ((var) = TAILQ_LAST((head), headname); \ (var); \ (var) = TAILQ_PREV((var), headname, field)) #define TAILQ_FOREACH_REVERSE_SAFE(var, head, headname, field, tvar) \ for ((var) = TAILQ_LAST((head), headname); \ (var) && ((tvar) = TAILQ_PREV((var), headname, field), 1); \ (var) = (tvar)) #define TAILQ_INIT(head) do { \ TAILQ_FIRST((head)) = NULL; \ (head)->tqh_last = &TAILQ_FIRST((head)); \ QMD_TRACE_HEAD(head); \ } while (0) #define TAILQ_INSERT_AFTER(head, listelm, elm, field) do { \ QMD_TAILQ_CHECK_NEXT(listelm, field); \ if ((TAILQ_NEXT((elm), field) = TAILQ_NEXT((listelm), field)) != NULL)\ TAILQ_NEXT((elm), field)->field.tqe_prev = \ &TAILQ_NEXT((elm), field); \ else { \ (head)->tqh_last = &TAILQ_NEXT((elm), field); \ QMD_TRACE_HEAD(head); \ } \ TAILQ_NEXT((listelm), field) = (elm); \ (elm)->field.tqe_prev = &TAILQ_NEXT((listelm), field); \ QMD_TRACE_ELEM(&(elm)->field); \ QMD_TRACE_ELEM(&listelm->field); \ } while (0) #define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \ QMD_TAILQ_CHECK_PREV(listelm, field); \ (elm)->field.tqe_prev = (listelm)->field.tqe_prev; \ TAILQ_NEXT((elm), field) = (listelm); \ *(listelm)->field.tqe_prev = (elm); \ (listelm)->field.tqe_prev = &TAILQ_NEXT((elm), field); \ QMD_TRACE_ELEM(&(elm)->field); \ QMD_TRACE_ELEM(&listelm->field); \ } while (0) #define TAILQ_INSERT_HEAD(head, elm, field) do { \ QMD_TAILQ_CHECK_HEAD(head, field); \ if ((TAILQ_NEXT((elm), field) = TAILQ_FIRST((head))) != NULL) \ TAILQ_FIRST((head))->field.tqe_prev = \ &TAILQ_NEXT((elm), field); \ else \ (head)->tqh_last = &TAILQ_NEXT((elm), field); \ TAILQ_FIRST((head)) = (elm); \ (elm)->field.tqe_prev = &TAILQ_FIRST((head)); \ QMD_TRACE_HEAD(head); \ QMD_TRACE_ELEM(&(elm)->field); \ } while (0) #define TAILQ_INSERT_TAIL(head, elm, field) do { \ QMD_TAILQ_CHECK_TAIL(head, field); \ TAILQ_NEXT((elm), field) = NULL; \ (elm)->field.tqe_prev = (head)->tqh_last; \ *(head)->tqh_last = (elm); \ (head)->tqh_last = &TAILQ_NEXT((elm), field); \ QMD_TRACE_HEAD(head); \ QMD_TRACE_ELEM(&(elm)->field); \ } while (0) #define TAILQ_LAST(head, headname) \ (*(((struct headname *)((head)->tqh_last))->tqh_last)) #define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next) #define TAILQ_PREV(elm, headname, field) \ (*(((struct headname *)((elm)->field.tqe_prev))->tqh_last)) #define TAILQ_REMOVE(head, elm, field) do { \ QMD_SAVELINK(oldnext, (elm)->field.tqe_next); \ QMD_SAVELINK(oldprev, (elm)->field.tqe_prev); \ QMD_TAILQ_CHECK_NEXT(elm, field); \ QMD_TAILQ_CHECK_PREV(elm, field); \ if ((TAILQ_NEXT((elm), field)) != NULL) \ TAILQ_NEXT((elm), field)->field.tqe_prev = \ (elm)->field.tqe_prev; \ else { \ (head)->tqh_last = (elm)->field.tqe_prev; \ QMD_TRACE_HEAD(head); \ } \ *(elm)->field.tqe_prev = TAILQ_NEXT((elm), field); \ TRASHIT(*oldnext); \ TRASHIT(*oldprev); \ QMD_TRACE_ELEM(&(elm)->field); \ } while (0) #define TAILQ_SWAP(head1, head2, type, field) do { \ struct type *swap_first = (head1)->tqh_first; \ struct type **swap_last = (head1)->tqh_last; \ (head1)->tqh_first = (head2)->tqh_first; \ (head1)->tqh_last = (head2)->tqh_last; \ (head2)->tqh_first = swap_first; \ (head2)->tqh_last = swap_last; \ if ((swap_first = (head1)->tqh_first) != NULL) \ swap_first->field.tqe_prev = &(head1)->tqh_first; \ else \ (head1)->tqh_last = &(head1)->tqh_first; \ if ((swap_first = (head2)->tqh_first) != NULL) \ swap_first->field.tqe_prev = &(head2)->tqh_first; \ else \ (head2)->tqh_last = &(head2)->tqh_first; \ } while (0) #ifdef _KERNEL /* * XXX insque() and remque() are an old way of handling certain queues. * They bogusly assumes that all queue heads look alike. */ struct quehead { struct quehead *qh_link; struct quehead *qh_rlink; }; #ifdef __GNUC__ static __inline void insque(void *a, void *b) { struct quehead *element = (struct quehead *)a, *head = (struct quehead *)b; element->qh_link = head->qh_link; element->qh_rlink = head; head->qh_link = element; element->qh_link->qh_rlink = element; } static __inline void remque(void *a) { struct quehead *element = (struct quehead *)a; element->qh_link->qh_rlink = element->qh_rlink; element->qh_rlink->qh_link = element->qh_link; element->qh_rlink = 0; } #else /* !__GNUC__ */ void insque(void *a, void *b); void remque(void *a); #endif /* __GNUC__ */ #endif /* _KERNEL */ #endif /* !_SYS_QUEUE_H_ */ 07070100000052000081a40000000000000000000000016181423c00005f64000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/reent.h/* This header file provides the reentrancy. */ /* WARNING: All identifiers here must begin with an underscore. This file is included by stdio.h and others and we therefore must only use identifiers in the namespace allotted to us. */ #ifndef _SYS_REENT_H_ #ifdef __cplusplus extern "C" { #endif #define _SYS_REENT_H_ #include <_ansi.h> #include #include #define _NULL 0 #ifndef __Long #if __LONG_MAX__ == 2147483647L #define __Long long typedef unsigned __Long __ULong; #elif __INT_MAX__ == 2147483647 #define __Long int typedef unsigned __Long __ULong; #endif #endif #if !defined( __Long) #include #endif #ifndef __Long #define __Long __int32_t typedef __uint32_t __ULong; #endif struct _reent; /* * If _REENT_SMALL is defined, we make struct _reent as small as possible, * by having nearly everything possible allocated at first use. */ struct _Bigint { struct _Bigint *_next; int _k, _maxwds, _sign, _wds; __ULong _x[1]; }; /* needed by reentrant structure */ struct __tm { int __tm_sec; int __tm_min; int __tm_hour; int __tm_mday; int __tm_mon; int __tm_year; int __tm_wday; int __tm_yday; int __tm_isdst; }; /* * atexit() support. */ #define _ATEXIT_SIZE 32 /* must be at least 32 to guarantee ANSI conformance */ struct _on_exit_args { void * _fnargs[_ATEXIT_SIZE]; /* user fn args */ void * _dso_handle[_ATEXIT_SIZE]; /* Bitmask is set if user function takes arguments. */ __ULong _fntypes; /* type of exit routine - Must have at least _ATEXIT_SIZE bits */ /* Bitmask is set if function was registered via __cxa_atexit. */ __ULong _is_cxa; }; #ifdef _REENT_SMALL struct _atexit { struct _atexit *_next; /* next in list */ int _ind; /* next index in this table */ void (*_fns[_ATEXIT_SIZE])(void); /* the table itself */ struct _on_exit_args * _on_exit_args_ptr; }; # define _ATEXIT_INIT {_NULL, 0, {_NULL}, _NULL} #else struct _atexit { struct _atexit *_next; /* next in list */ int _ind; /* next index in this table */ /* Some entries may already have been called, and will be NULL. */ void (*_fns[_ATEXIT_SIZE])(void); /* the table itself */ struct _on_exit_args _on_exit_args; }; # define _ATEXIT_INIT {_NULL, 0, {_NULL}, {{_NULL}, {_NULL}, 0, 0}} #endif #ifdef _REENT_GLOBAL_ATEXIT # define _REENT_INIT_ATEXIT #else # define _REENT_INIT_ATEXIT \ _NULL, _ATEXIT_INIT, #endif /* * Stdio buffers. * * This and __FILE are defined here because we need them for struct _reent, * but we don't want stdio.h included when stdlib.h is. */ struct __sbuf { unsigned char *_base; int _size; }; /* * Stdio state variables. * * The following always hold: * * if (_flags&(__SLBF|__SWR)) == (__SLBF|__SWR), * _lbfsize is -_bf._size, else _lbfsize is 0 * if _flags&__SRD, _w is 0 * if _flags&__SWR, _r is 0 * * This ensures that the getc and putc macros (or inline functions) never * try to write or read from a file that is in `read' or `write' mode. * (Moreover, they can, and do, automatically switch from read mode to * write mode, and back, on "r+" and "w+" files.) * * _lbfsize is used only to make the inline line-buffered output stream * code as compact as possible. * * _ub, _up, and _ur are used when ungetc() pushes back more characters * than fit in the current _bf, or when ungetc() pushes back a character * that does not match the previous one in _bf. When this happens, * _ub._base becomes non-nil (i.e., a stream has ungetc() data iff * _ub._base!=NULL) and _up and _ur save the current values of _p and _r. */ #ifdef _REENT_SMALL /* * struct __sFILE_fake is the start of a struct __sFILE, with only the * minimal fields allocated. In __sinit() we really allocate the 3 * standard streams, etc., and point away from this fake. */ struct __sFILE_fake { unsigned char *_p; /* current position in (some) buffer */ int _r; /* read space left for getc() */ int _w; /* write space left for putc() */ short _flags; /* flags, below; this FILE is free if 0 */ short _file; /* fileno, if Unix descriptor, else -1 */ struct __sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */ int _lbfsize; /* 0 or -_bf._size, for inline putc */ struct _reent *_data; }; /* Following is needed both in libc/stdio and libc/stdlib so we put it * here instead of libc/stdio/local.h where it was previously. */ extern _VOID _EXFUN(__sinit,(struct _reent *)); # define _REENT_SMALL_CHECK_INIT(ptr) \ do \ { \ if ((ptr) && !(ptr)->__sdidinit) \ __sinit (ptr); \ } \ while (0) #else # define _REENT_SMALL_CHECK_INIT(ptr) /* nothing */ #endif struct __sFILE { unsigned char *_p; /* current position in (some) buffer */ int _r; /* read space left for getc() */ int _w; /* write space left for putc() */ short _flags; /* flags, below; this FILE is free if 0 */ short _file; /* fileno, if Unix descriptor, else -1 */ struct __sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */ int _lbfsize; /* 0 or -_bf._size, for inline putc */ #ifdef _REENT_SMALL struct _reent *_data; #endif /* operations */ _PTR _cookie; /* cookie passed to io functions */ _READ_WRITE_RETURN_TYPE _EXFNPTR(_read, (struct _reent *, _PTR, char *, _READ_WRITE_BUFSIZE_TYPE)); _READ_WRITE_RETURN_TYPE _EXFNPTR(_write, (struct _reent *, _PTR, const char *, _READ_WRITE_BUFSIZE_TYPE)); _fpos_t _EXFNPTR(_seek, (struct _reent *, _PTR, _fpos_t, int)); int _EXFNPTR(_close, (struct _reent *, _PTR)); /* separate buffer for long sequences of ungetc() */ struct __sbuf _ub; /* ungetc buffer */ unsigned char *_up; /* saved _p when _p is doing ungetc data */ int _ur; /* saved _r when _r is counting ungetc data */ /* tricks to meet minimum requirements even when malloc() fails */ unsigned char _ubuf[3]; /* guarantee an ungetc() buffer */ unsigned char _nbuf[1]; /* guarantee a getc() buffer */ /* separate buffer for fgetline() when line crosses buffer boundary */ struct __sbuf _lb; /* buffer for fgetline() */ /* Unix stdio files get aligned to block boundaries on fseek() */ int _blksize; /* stat.st_blksize (may be != _bf._size) */ _off_t _offset; /* current lseek offset */ #ifndef _REENT_SMALL struct _reent *_data; /* Here for binary compatibility? Remove? */ #endif #ifndef __SINGLE_THREAD__ _flock_t _lock; /* for thread-safety locking */ #endif _mbstate_t _mbstate; /* for wide char stdio functions. */ int _flags2; /* for future use */ }; #ifdef __CUSTOM_FILE_IO__ /* Get custom _FILE definition. */ #include #else /* !__CUSTOM_FILE_IO__ */ #ifdef __LARGE64_FILES struct __sFILE64 { unsigned char *_p; /* current position in (some) buffer */ int _r; /* read space left for getc() */ int _w; /* write space left for putc() */ short _flags; /* flags, below; this FILE is free if 0 */ short _file; /* fileno, if Unix descriptor, else -1 */ struct __sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */ int _lbfsize; /* 0 or -_bf._size, for inline putc */ struct _reent *_data; /* operations */ _PTR _cookie; /* cookie passed to io functions */ _READ_WRITE_RETURN_TYPE _EXFNPTR(_read, (struct _reent *, _PTR, char *, _READ_WRITE_BUFSIZE_TYPE)); _READ_WRITE_RETURN_TYPE _EXFNPTR(_write, (struct _reent *, _PTR, const char *, _READ_WRITE_BUFSIZE_TYPE)); _fpos_t _EXFNPTR(_seek, (struct _reent *, _PTR, _fpos_t, int)); int _EXFNPTR(_close, (struct _reent *, _PTR)); /* separate buffer for long sequences of ungetc() */ struct __sbuf _ub; /* ungetc buffer */ unsigned char *_up; /* saved _p when _p is doing ungetc data */ int _ur; /* saved _r when _r is counting ungetc data */ /* tricks to meet minimum requirements even when malloc() fails */ unsigned char _ubuf[3]; /* guarantee an ungetc() buffer */ unsigned char _nbuf[1]; /* guarantee a getc() buffer */ /* separate buffer for fgetline() when line crosses buffer boundary */ struct __sbuf _lb; /* buffer for fgetline() */ /* Unix stdio files get aligned to block boundaries on fseek() */ int _blksize; /* stat.st_blksize (may be != _bf._size) */ int _flags2; /* for future use */ _off64_t _offset; /* current lseek offset */ _fpos64_t _EXFNPTR(_seek64, (struct _reent *, _PTR, _fpos64_t, int)); #ifndef __SINGLE_THREAD__ _flock_t _lock; /* for thread-safety locking */ #endif _mbstate_t _mbstate; /* for wide char stdio functions. */ }; typedef struct __sFILE64 __FILE; #else typedef struct __sFILE __FILE; #endif /* __LARGE64_FILES */ #endif /* !__CUSTOM_FILE_IO__ */ struct _glue { struct _glue *_next; int _niobs; __FILE *_iobs; }; /* * rand48 family support * * Copyright (c) 1993 Martin Birgmeier * All rights reserved. * * You may redistribute unmodified or modified versions of this source * code provided that the above copyright notice and this and the * following conditions are retained. * * This software is provided ``as is'', and comes with no warranties * of any kind. I shall in no event be liable for anything that happens * to anyone/anything when using this software. */ #define _RAND48_SEED_0 (0x330e) #define _RAND48_SEED_1 (0xabcd) #define _RAND48_SEED_2 (0x1234) #define _RAND48_MULT_0 (0xe66d) #define _RAND48_MULT_1 (0xdeec) #define _RAND48_MULT_2 (0x0005) #define _RAND48_ADD (0x000b) struct _rand48 { unsigned short _seed[3]; unsigned short _mult[3]; unsigned short _add; #ifdef _REENT_SMALL /* Put this in here as well, for good luck. */ __extension__ unsigned long long _rand_next; #endif }; /* How big the some arrays are. */ #define _REENT_EMERGENCY_SIZE 25 #define _REENT_ASCTIME_SIZE 26 #define _REENT_SIGNAL_SIZE 24 /* * struct _reent * * This structure contains *all* globals needed by the library. * It's raison d'etre is to facilitate threads by making all library routines * reentrant. IE: All state information is contained here. */ #ifdef _REENT_SMALL struct _mprec { /* used by mprec routines */ struct _Bigint *_result; int _result_k; struct _Bigint *_p5s; struct _Bigint **_freelist; }; struct _misc_reent { /* miscellaneous reentrant data */ char *_strtok_last; _mbstate_t _mblen_state; _mbstate_t _wctomb_state; _mbstate_t _mbtowc_state; char _l64a_buf[8]; int _getdate_err; _mbstate_t _mbrlen_state; _mbstate_t _mbrtowc_state; _mbstate_t _mbsrtowcs_state; _mbstate_t _wcrtomb_state; _mbstate_t _wcsrtombs_state; }; /* This version of _reent is laid out with "int"s in pairs, to help * ports with 16-bit int's but 32-bit pointers, align nicely. */ struct _reent { /* As an exception to the above put _errno first for binary compatibility with non _REENT_SMALL targets. */ int _errno; /* local copy of errno */ /* FILE is a big struct and may change over time. To try to achieve binary compatibility with future versions, put stdin,stdout,stderr here. These are pointers into member __sf defined below. */ __FILE *_stdin, *_stdout, *_stderr; /* XXX */ int _inc; /* used by tmpnam */ char *_emergency; int __sdidinit; /* 1 means stdio has been init'd */ int _current_category; /* unused */ _CONST char *_current_locale; /* unused */ struct _mprec *_mp; void _EXFNPTR(__cleanup, (struct _reent *)); int _gamma_signgam; /* used by some fp conversion routines */ int _cvtlen; /* should be size_t */ char *_cvtbuf; struct _rand48 *_r48; struct __tm *_localtime_buf; char *_asctime_buf; /* signal info */ void (**(_sig_func))(int); # ifndef _REENT_GLOBAL_ATEXIT /* atexit stuff */ struct _atexit *_atexit; struct _atexit _atexit0; # endif struct _glue __sglue; /* root of glue chain */ __FILE *__sf; /* file descriptors */ struct _misc_reent *_misc; /* strtok, multibyte states */ char *_signal_buf; /* strsignal */ }; extern const struct __sFILE_fake __sf_fake_stdin; extern const struct __sFILE_fake __sf_fake_stdout; extern const struct __sFILE_fake __sf_fake_stderr; # define _REENT_INIT(var) \ { 0, \ (__FILE *)&__sf_fake_stdin, \ (__FILE *)&__sf_fake_stdout, \ (__FILE *)&__sf_fake_stderr, \ 0, \ _NULL, \ 0, \ 0, \ "C", \ _NULL, \ _NULL, \ 0, \ 0, \ _NULL, \ _NULL, \ _NULL, \ _NULL, \ _NULL, \ _REENT_INIT_ATEXIT \ {_NULL, 0, _NULL}, \ _NULL, \ _NULL, \ _NULL \ } #define _REENT_INIT_PTR(var) \ { memset((var), 0, sizeof(*(var))); \ (var)->_stdin = (__FILE *)&__sf_fake_stdin; \ (var)->_stdout = (__FILE *)&__sf_fake_stdout; \ (var)->_stderr = (__FILE *)&__sf_fake_stderr; \ (var)->_current_locale = "C"; \ } /* Only built the assert() calls if we are built with debugging. */ #if DEBUG #include #define __reent_assert(x) assert(x) #else #define __reent_assert(x) ((void)0) #endif #ifdef __CUSTOM_FILE_IO__ #error Custom FILE I/O and _REENT_SMALL not currently supported. #endif /* Generic _REENT check macro. */ #define _REENT_CHECK(var, what, type, size, init) do { \ struct _reent *_r = (var); \ if (_r->what == NULL) { \ _r->what = (type)malloc(size); \ __reent_assert(_r->what); \ init; \ } \ } while (0) #define _REENT_CHECK_TM(var) \ _REENT_CHECK(var, _localtime_buf, struct __tm *, sizeof *((var)->_localtime_buf), \ /* nothing */) #define _REENT_CHECK_ASCTIME_BUF(var) \ _REENT_CHECK(var, _asctime_buf, char *, _REENT_ASCTIME_SIZE, \ memset((var)->_asctime_buf, 0, _REENT_ASCTIME_SIZE)) /* Handle the dynamically allocated rand48 structure. */ #define _REENT_INIT_RAND48(var) do { \ struct _reent *_r = (var); \ _r->_r48->_seed[0] = _RAND48_SEED_0; \ _r->_r48->_seed[1] = _RAND48_SEED_1; \ _r->_r48->_seed[2] = _RAND48_SEED_2; \ _r->_r48->_mult[0] = _RAND48_MULT_0; \ _r->_r48->_mult[1] = _RAND48_MULT_1; \ _r->_r48->_mult[2] = _RAND48_MULT_2; \ _r->_r48->_add = _RAND48_ADD; \ _r->_r48->_rand_next = 1; \ } while (0) #define _REENT_CHECK_RAND48(var) \ _REENT_CHECK(var, _r48, struct _rand48 *, sizeof *((var)->_r48), _REENT_INIT_RAND48((var))) #define _REENT_INIT_MP(var) do { \ struct _reent *_r = (var); \ _r->_mp->_result_k = 0; \ _r->_mp->_result = _r->_mp->_p5s = _NULL; \ _r->_mp->_freelist = _NULL; \ } while (0) #define _REENT_CHECK_MP(var) \ _REENT_CHECK(var, _mp, struct _mprec *, sizeof *((var)->_mp), _REENT_INIT_MP(var)) #define _REENT_CHECK_EMERGENCY(var) \ _REENT_CHECK(var, _emergency, char *, _REENT_EMERGENCY_SIZE, /* nothing */) #define _REENT_INIT_MISC(var) do { \ struct _reent *_r = (var); \ _r->_misc->_strtok_last = _NULL; \ _r->_misc->_mblen_state.__count = 0; \ _r->_misc->_mblen_state.__value.__wch = 0; \ _r->_misc->_wctomb_state.__count = 0; \ _r->_misc->_wctomb_state.__value.__wch = 0; \ _r->_misc->_mbtowc_state.__count = 0; \ _r->_misc->_mbtowc_state.__value.__wch = 0; \ _r->_misc->_mbrlen_state.__count = 0; \ _r->_misc->_mbrlen_state.__value.__wch = 0; \ _r->_misc->_mbrtowc_state.__count = 0; \ _r->_misc->_mbrtowc_state.__value.__wch = 0; \ _r->_misc->_mbsrtowcs_state.__count = 0; \ _r->_misc->_mbsrtowcs_state.__value.__wch = 0; \ _r->_misc->_wcrtomb_state.__count = 0; \ _r->_misc->_wcrtomb_state.__value.__wch = 0; \ _r->_misc->_wcsrtombs_state.__count = 0; \ _r->_misc->_wcsrtombs_state.__value.__wch = 0; \ _r->_misc->_l64a_buf[0] = '\0'; \ _r->_misc->_getdate_err = 0; \ } while (0) #define _REENT_CHECK_MISC(var) \ _REENT_CHECK(var, _misc, struct _misc_reent *, sizeof *((var)->_misc), _REENT_INIT_MISC(var)) #define _REENT_CHECK_SIGNAL_BUF(var) \ _REENT_CHECK(var, _signal_buf, char *, _REENT_SIGNAL_SIZE, /* nothing */) #define _REENT_SIGNGAM(ptr) ((ptr)->_gamma_signgam) #define _REENT_RAND_NEXT(ptr) ((ptr)->_r48->_rand_next) #define _REENT_RAND48_SEED(ptr) ((ptr)->_r48->_seed) #define _REENT_RAND48_MULT(ptr) ((ptr)->_r48->_mult) #define _REENT_RAND48_ADD(ptr) ((ptr)->_r48->_add) #define _REENT_MP_RESULT(ptr) ((ptr)->_mp->_result) #define _REENT_MP_RESULT_K(ptr) ((ptr)->_mp->_result_k) #define _REENT_MP_P5S(ptr) ((ptr)->_mp->_p5s) #define _REENT_MP_FREELIST(ptr) ((ptr)->_mp->_freelist) #define _REENT_ASCTIME_BUF(ptr) ((ptr)->_asctime_buf) #define _REENT_TM(ptr) ((ptr)->_localtime_buf) #define _REENT_EMERGENCY(ptr) ((ptr)->_emergency) #define _REENT_STRTOK_LAST(ptr) ((ptr)->_misc->_strtok_last) #define _REENT_MBLEN_STATE(ptr) ((ptr)->_misc->_mblen_state) #define _REENT_MBTOWC_STATE(ptr)((ptr)->_misc->_mbtowc_state) #define _REENT_WCTOMB_STATE(ptr)((ptr)->_misc->_wctomb_state) #define _REENT_MBRLEN_STATE(ptr) ((ptr)->_misc->_mbrlen_state) #define _REENT_MBRTOWC_STATE(ptr) ((ptr)->_misc->_mbrtowc_state) #define _REENT_MBSRTOWCS_STATE(ptr) ((ptr)->_misc->_mbsrtowcs_state) #define _REENT_WCRTOMB_STATE(ptr) ((ptr)->_misc->_wcrtomb_state) #define _REENT_WCSRTOMBS_STATE(ptr) ((ptr)->_misc->_wcsrtombs_state) #define _REENT_L64A_BUF(ptr) ((ptr)->_misc->_l64a_buf) #define _REENT_GETDATE_ERR_P(ptr) (&((ptr)->_misc->_getdate_err)) #define _REENT_SIGNAL_BUF(ptr) ((ptr)->_signal_buf) #else /* !_REENT_SMALL */ struct _reent { int _errno; /* local copy of errno */ /* FILE is a big struct and may change over time. To try to achieve binary compatibility with future versions, put stdin,stdout,stderr here. These are pointers into member __sf defined below. */ __FILE *_stdin, *_stdout, *_stderr; int _inc; /* used by tmpnam */ char _emergency[_REENT_EMERGENCY_SIZE]; int _current_category; /* used by setlocale */ _CONST char *_current_locale; int __sdidinit; /* 1 means stdio has been init'd */ void _EXFNPTR(__cleanup, (struct _reent *)); /* used by mprec routines */ struct _Bigint *_result; int _result_k; struct _Bigint *_p5s; struct _Bigint **_freelist; /* used by some fp conversion routines */ int _cvtlen; /* should be size_t */ char *_cvtbuf; union { struct { unsigned int _unused_rand; char * _strtok_last; char _asctime_buf[_REENT_ASCTIME_SIZE]; struct __tm _localtime_buf; int _gamma_signgam; __extension__ unsigned long long _rand_next; struct _rand48 _r48; _mbstate_t _mblen_state; _mbstate_t _mbtowc_state; _mbstate_t _wctomb_state; char _l64a_buf[8]; char _signal_buf[_REENT_SIGNAL_SIZE]; int _getdate_err; _mbstate_t _mbrlen_state; _mbstate_t _mbrtowc_state; _mbstate_t _mbsrtowcs_state; _mbstate_t _wcrtomb_state; _mbstate_t _wcsrtombs_state; int _h_errno; } _reent; /* Two next two fields were once used by malloc. They are no longer used. They are used to preserve the space used before so as to allow addition of new reent fields and keep binary compatibility. */ struct { #define _N_LISTS 30 unsigned char * _nextf[_N_LISTS]; unsigned int _nmalloc[_N_LISTS]; } _unused; } _new; # ifndef _REENT_GLOBAL_ATEXIT /* atexit stuff */ struct _atexit *_atexit; /* points to head of LIFO stack */ struct _atexit _atexit0; /* one guaranteed table, required by ANSI */ # endif /* signal info */ void (**(_sig_func))(int); /* These are here last so that __FILE can grow without changing the offsets of the above members (on the off chance that future binary compatibility would be broken otherwise). */ struct _glue __sglue; /* root of glue chain */ __FILE __sf[3]; /* first three file descriptors */ }; #define _REENT_INIT(var) \ { 0, \ _NULL, \ _NULL, \ _NULL, \ 0, \ "", \ 0, \ "C", \ 0, \ _NULL, \ _NULL, \ 0, \ _NULL, \ _NULL, \ 0, \ _NULL, \ { \ { \ 0, \ _NULL, \ "", \ {0, 0, 0, 0, 0, 0, 0, 0, 0}, \ 0, \ 1, \ { \ {_RAND48_SEED_0, _RAND48_SEED_1, _RAND48_SEED_2}, \ {_RAND48_MULT_0, _RAND48_MULT_1, _RAND48_MULT_2}, \ _RAND48_ADD \ }, \ {0, {0}}, \ {0, {0}}, \ {0, {0}}, \ "", \ "", \ 0, \ {0, {0}}, \ {0, {0}}, \ {0, {0}}, \ {0, {0}}, \ {0, {0}} \ } \ }, \ _REENT_INIT_ATEXIT \ _NULL, \ {_NULL, 0, _NULL} \ } #define _REENT_INIT_PTR(var) \ { memset((var), 0, sizeof(*(var))); \ (var)->_stdin = &(var)->__sf[0]; \ (var)->_stdout = &(var)->__sf[1]; \ (var)->_stderr = &(var)->__sf[2]; \ (var)->_current_locale = "C"; \ (var)->_new._reent._rand_next = 1; \ (var)->_new._reent._r48._seed[0] = _RAND48_SEED_0; \ (var)->_new._reent._r48._seed[1] = _RAND48_SEED_1; \ (var)->_new._reent._r48._seed[2] = _RAND48_SEED_2; \ (var)->_new._reent._r48._mult[0] = _RAND48_MULT_0; \ (var)->_new._reent._r48._mult[1] = _RAND48_MULT_1; \ (var)->_new._reent._r48._mult[2] = _RAND48_MULT_2; \ (var)->_new._reent._r48._add = _RAND48_ADD; \ } #define _REENT_CHECK_RAND48(ptr) /* nothing */ #define _REENT_CHECK_MP(ptr) /* nothing */ #define _REENT_CHECK_TM(ptr) /* nothing */ #define _REENT_CHECK_ASCTIME_BUF(ptr) /* nothing */ #define _REENT_CHECK_EMERGENCY(ptr) /* nothing */ #define _REENT_CHECK_MISC(ptr) /* nothing */ #define _REENT_CHECK_SIGNAL_BUF(ptr) /* nothing */ #define _REENT_SIGNGAM(ptr) ((ptr)->_new._reent._gamma_signgam) #define _REENT_RAND_NEXT(ptr) ((ptr)->_new._reent._rand_next) #define _REENT_RAND48_SEED(ptr) ((ptr)->_new._reent._r48._seed) #define _REENT_RAND48_MULT(ptr) ((ptr)->_new._reent._r48._mult) #define _REENT_RAND48_ADD(ptr) ((ptr)->_new._reent._r48._add) #define _REENT_MP_RESULT(ptr) ((ptr)->_result) #define _REENT_MP_RESULT_K(ptr) ((ptr)->_result_k) #define _REENT_MP_P5S(ptr) ((ptr)->_p5s) #define _REENT_MP_FREELIST(ptr) ((ptr)->_freelist) #define _REENT_ASCTIME_BUF(ptr) ((ptr)->_new._reent._asctime_buf) #define _REENT_TM(ptr) (&(ptr)->_new._reent._localtime_buf) #define _REENT_EMERGENCY(ptr) ((ptr)->_emergency) #define _REENT_STRTOK_LAST(ptr) ((ptr)->_new._reent._strtok_last) #define _REENT_MBLEN_STATE(ptr) ((ptr)->_new._reent._mblen_state) #define _REENT_MBTOWC_STATE(ptr)((ptr)->_new._reent._mbtowc_state) #define _REENT_WCTOMB_STATE(ptr)((ptr)->_new._reent._wctomb_state) #define _REENT_MBRLEN_STATE(ptr)((ptr)->_new._reent._mbrlen_state) #define _REENT_MBRTOWC_STATE(ptr)((ptr)->_new._reent._mbrtowc_state) #define _REENT_MBSRTOWCS_STATE(ptr)((ptr)->_new._reent._mbsrtowcs_state) #define _REENT_WCRTOMB_STATE(ptr)((ptr)->_new._reent._wcrtomb_state) #define _REENT_WCSRTOMBS_STATE(ptr)((ptr)->_new._reent._wcsrtombs_state) #define _REENT_L64A_BUF(ptr) ((ptr)->_new._reent._l64a_buf) #define _REENT_SIGNAL_BUF(ptr) ((ptr)->_new._reent._signal_buf) #define _REENT_GETDATE_ERR_P(ptr) (&((ptr)->_new._reent._getdate_err)) #endif /* !_REENT_SMALL */ /* This value is used in stdlib/misc.c. reent/reent.c has to know it as well to make sure the freelist is correctly free'd. Therefore we define it here, rather than in stdlib/misc.c, as before. */ #define _Kmax (sizeof (size_t) << 3) /* * All references to struct _reent are via this pointer. * Internally, newlib routines that need to reference it should use _REENT. */ #ifndef __ATTRIBUTE_IMPURE_PTR__ #define __ATTRIBUTE_IMPURE_PTR__ #endif extern struct _reent *_impure_ptr __ATTRIBUTE_IMPURE_PTR__; extern struct _reent *_CONST _global_impure_ptr __ATTRIBUTE_IMPURE_PTR__; void _reclaim_reent _PARAMS ((struct _reent *)); /* #define _REENT_ONLY define this to get only reentrant routines */ #if defined(__DYNAMIC_REENT__) && !defined(__SINGLE_THREAD__) #ifndef __getreent struct _reent * _EXFUN(__getreent, (void)); #endif # define _REENT (__getreent()) #else /* __SINGLE_THREAD__ || !__DYNAMIC_REENT__ */ # define _REENT _impure_ptr #endif /* __SINGLE_THREAD__ || !__DYNAMIC_REENT__ */ #define _GLOBAL_REENT _global_impure_ptr #ifdef _REENT_GLOBAL_ATEXIT extern struct _atexit *_global_atexit; /* points to head of LIFO stack */ # define _GLOBAL_ATEXIT _global_atexit #else # define _GLOBAL_ATEXIT (_GLOBAL_REENT->_atexit) #endif #ifdef __cplusplus } #endif #endif /* _SYS_REENT_H_ */ 07070100000053000081a40000000000000000000000016181423c00000133000000000000000000000000000000000000002800000000./usr/nvptx-none/include/sys/resource.h#ifndef _SYS_RESOURCE_H_ #define _SYS_RESOURCE_H_ #include #define RUSAGE_SELF 0 /* calling process */ #define RUSAGE_CHILDREN -1 /* terminated child processes */ struct rusage { struct timeval ru_utime; /* user time used */ struct timeval ru_stime; /* system time used */ }; #endif 07070100000054000081a40000000000000000000000016181423d00000734000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/sched.h/* * Written by Joel Sherrill . * * COPYRIGHT (c) 1989-2010. * On-Line Applications Research Corporation (OAR). * * Permission to use, copy, modify, and distribute this software for any * purpose without fee is hereby granted, provided that this entire notice * is included in all copies of any software which is or includes a copy * or modification of this software. * * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED * WARRANTY. IN PARTICULAR, THE AUTHOR MAKES NO REPRESENTATION * OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY OF THIS * SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE. * * $Id$ */ #ifndef _SYS_SCHED_H_ #define _SYS_SCHED_H_ #ifdef __cplusplus extern "C" { #endif /* Scheduling Policies */ /* Open Group Specifications Issue 6 */ #if defined(__CYGWIN__) #define SCHED_OTHER 3 #else #define SCHED_OTHER 0 #endif #define SCHED_FIFO 1 #define SCHED_RR 2 #if defined(_POSIX_SPORADIC_SERVER) #define SCHED_SPORADIC 4 #endif /* Scheduling Parameters */ /* Open Group Specifications Issue 6 */ struct sched_param { int sched_priority; /* Process execution scheduling priority */ #if defined(_POSIX_SPORADIC_SERVER) || defined(_POSIX_THREAD_SPORADIC_SERVER) int sched_ss_low_priority; /* Low scheduling priority for sporadic */ /* server */ struct timespec sched_ss_repl_period; /* Replenishment period for sporadic server */ struct timespec sched_ss_init_budget; /* Initial budget for sporadic server */ int sched_ss_max_repl; /* Maximum pending replenishments for */ /* sporadic server */ #endif }; #ifdef __cplusplus } #endif #endif /* end of include file */ 07070100000055000081a40000000000000000000000016181423d000029c3000000000000000000000000000000000000002600000000./usr/nvptx-none/include/sys/signal.h/* sys/signal.h */ #ifndef _SYS_SIGNAL_H #define _SYS_SIGNAL_H #ifdef __cplusplus extern "C" { #endif #include "_ansi.h" #include #include /* #ifndef __STRICT_ANSI__*/ /* Cygwin defines it's own sigset_t in include/cygwin/signal.h */ #ifndef __CYGWIN__ typedef unsigned long sigset_t; #endif #if defined(__rtems__) #if defined(_POSIX_REALTIME_SIGNALS) /* sigev_notify values NOTE: P1003.1c/D10, p. 34 adds SIGEV_THREAD. */ #define SIGEV_NONE 1 /* No asynchronous notification shall be delivered */ /* when the event of interest occurs. */ #define SIGEV_SIGNAL 2 /* A queued signal, with an application defined */ /* value, shall be delivered when the event of */ /* interest occurs. */ #define SIGEV_THREAD 3 /* A notification function shall be called to */ /* perform notification. */ /* Signal Generation and Delivery, P1003.1b-1993, p. 63 NOTE: P1003.1c/D10, p. 34 adds sigev_notify_function and sigev_notify_attributes to the sigevent structure. */ union sigval { int sival_int; /* Integer signal value */ void *sival_ptr; /* Pointer signal value */ }; struct sigevent { int sigev_notify; /* Notification type */ int sigev_signo; /* Signal number */ union sigval sigev_value; /* Signal value */ #if defined(_POSIX_THREADS) void (*sigev_notify_function)( union sigval ); /* Notification function */ pthread_attr_t *sigev_notify_attributes; /* Notification Attributes */ #endif }; /* Signal Actions, P1003.1b-1993, p. 64 */ /* si_code values, p. 66 */ #define SI_USER 1 /* Sent by a user. kill(), abort(), etc */ #define SI_QUEUE 2 /* Sent by sigqueue() */ #define SI_TIMER 3 /* Sent by expiration of a timer_settime() timer */ #define SI_ASYNCIO 4 /* Indicates completion of asycnhronous IO */ #define SI_MESGQ 5 /* Indicates arrival of a message at an empty queue */ typedef struct { int si_signo; /* Signal number */ int si_code; /* Cause of the signal */ union sigval si_value; /* Signal value */ } siginfo_t; #endif /* 3.3.8 Synchronously Accept a Signal, P1003.1b-1993, p. 76 */ #define SA_NOCLDSTOP 1 /* Do not generate SIGCHLD when children stop */ #define SA_SIGINFO 2 /* Invoke the signal catching function with */ /* three arguments instead of one. */ /* struct sigaction notes from POSIX: * * (1) Routines stored in sa_handler should take a single int as * their argument although the POSIX standard does not require this. * This is not longer true since at least POSIX.1-2008 * (2) The fields sa_handler and sa_sigaction may overlap, and a conforming * application should not use both simultaneously. */ typedef void (*_sig_func_ptr)(int); struct sigaction { int sa_flags; /* Special flags to affect behavior of signal */ sigset_t sa_mask; /* Additional set of signals to be blocked */ /* during execution of signal-catching */ /* function. */ union { _sig_func_ptr _handler; /* SIG_DFL, SIG_IGN, or pointer to a function */ #if defined(_POSIX_REALTIME_SIGNALS) void (*_sigaction)( int, siginfo_t *, void * ); #endif } _signal_handlers; }; #define sa_handler _signal_handlers._handler #if defined(_POSIX_REALTIME_SIGNALS) #define sa_sigaction _signal_handlers._sigaction #endif #elif defined(__CYGWIN__) #include #else #define SA_NOCLDSTOP 1 /* only value supported now for sa_flags */ typedef void (*_sig_func_ptr)(int); struct sigaction { _sig_func_ptr sa_handler; sigset_t sa_mask; int sa_flags; }; #endif /* defined(__rtems__) */ #define SIG_SETMASK 0 /* set mask with sigprocmask() */ #define SIG_BLOCK 1 /* set of signals to block */ #define SIG_UNBLOCK 2 /* set of signals to, well, unblock */ /* These depend upon the type of sigset_t, which right now is always a long.. They're in the POSIX namespace, but are not ANSI. */ #define sigaddset(what,sig) (*(what) |= (1<<(sig)), 0) #define sigdelset(what,sig) (*(what) &= ~(1<<(sig)), 0) #define sigemptyset(what) (*(what) = 0, 0) #define sigfillset(what) (*(what) = ~(0), 0) #define sigismember(what,sig) (((*(what)) & (1<<(sig))) != 0) int _EXFUN(sigprocmask, (int how, const sigset_t *set, sigset_t *oset)); #if defined(_POSIX_THREADS) int _EXFUN(pthread_sigmask, (int how, const sigset_t *set, sigset_t *oset)); #endif /* protos for functions found in winsup sources for CYGWIN */ #if defined(__CYGWIN__) || defined(__rtems__) #undef sigaddset #undef sigdelset #undef sigemptyset #undef sigfillset #undef sigismember #ifdef _COMPILING_NEWLIB int _EXFUN(_kill, (pid_t, int)); #endif int _EXFUN(kill, (pid_t, int)); int _EXFUN(killpg, (pid_t, int)); int _EXFUN(sigaction, (int, const struct sigaction *, struct sigaction *)); int _EXFUN(sigaddset, (sigset_t *, const int)); int _EXFUN(sigdelset, (sigset_t *, const int)); int _EXFUN(sigismember, (const sigset_t *, int)); int _EXFUN(sigfillset, (sigset_t *)); int _EXFUN(sigemptyset, (sigset_t *)); int _EXFUN(sigpending, (sigset_t *)); int _EXFUN(sigsuspend, (const sigset_t *)); int _EXFUN(sigpause, (int)); #if defined(_POSIX_THREADS) #ifdef __CYGWIN__ # ifndef _CYGWIN_TYPES_H # error You need the winsup sources or a cygwin installation to compile the cygwin version of newlib. # endif #endif int _EXFUN(pthread_kill, (pthread_t thread, int sig)); #endif #if defined(_POSIX_REALTIME_SIGNALS) /* 3.3.8 Synchronously Accept a Signal, P1003.1b-1993, p. 76 NOTE: P1003.1c/D10, p. 39 adds sigwait(). */ int _EXFUN(sigwaitinfo, (const sigset_t *set, siginfo_t *info)); int _EXFUN(sigtimedwait, (const sigset_t *set, siginfo_t *info, const struct timespec *timeout) ); int _EXFUN(sigwait, (const sigset_t *set, int *sig)); /* 3.3.9 Queue a Signal to a Process, P1003.1b-1993, p. 78 */ int _EXFUN(sigqueue, (pid_t pid, int signo, const union sigval value)); #endif /* defined(_POSIX_REALTIME_SIGNALS) */ #endif /* defined(__CYGWIN__) || defined(__rtems__) */ /* #endif __STRICT_ANSI__ */ #if defined(___AM29K__) /* These all need to be defined for ANSI C, but I don't think they are meaningful. */ #define SIGABRT 1 #define SIGFPE 1 #define SIGILL 1 #define SIGINT 1 #define SIGSEGV 1 #define SIGTERM 1 /* These need to be defined for POSIX, and some others do too. */ #define SIGHUP 1 #define SIGQUIT 1 #define NSIG 2 #elif defined(__GO32__) #define SIGINT 1 #define SIGKILL 2 #define SIGPIPE 3 #define SIGFPE 4 #define SIGHUP 5 #define SIGTERM 6 #define SIGSEGV 7 #define SIGTSTP 8 #define SIGQUIT 9 #define SIGTRAP 10 #define SIGILL 11 #define SIGEMT 12 #define SIGALRM 13 #define SIGBUS 14 #define SIGLOST 15 #define SIGSTOP 16 #define SIGABRT 17 #define SIGUSR1 18 #define SIGUSR2 19 #define NSIG 20 #elif !defined(SIGTRAP) #define SIGHUP 1 /* hangup */ #define SIGINT 2 /* interrupt */ #define SIGQUIT 3 /* quit */ #define SIGILL 4 /* illegal instruction (not reset when caught) */ #define SIGTRAP 5 /* trace trap (not reset when caught) */ #define SIGIOT 6 /* IOT instruction */ #define SIGABRT 6 /* used by abort, replace SIGIOT in the future */ #define SIGEMT 7 /* EMT instruction */ #define SIGFPE 8 /* floating point exception */ #define SIGKILL 9 /* kill (cannot be caught or ignored) */ #define SIGBUS 10 /* bus error */ #define SIGSEGV 11 /* segmentation violation */ #define SIGSYS 12 /* bad argument to system call */ #define SIGPIPE 13 /* write on a pipe with no one to read it */ #define SIGALRM 14 /* alarm clock */ #define SIGTERM 15 /* software termination signal from kill */ #if defined(__rtems__) #define SIGURG 16 /* urgent condition on IO channel */ #define SIGSTOP 17 /* sendable stop signal not from tty */ #define SIGTSTP 18 /* stop signal from tty */ #define SIGCONT 19 /* continue a stopped process */ #define SIGCHLD 20 /* to parent on child stop or exit */ #define SIGCLD 20 /* System V name for SIGCHLD */ #define SIGTTIN 21 /* to readers pgrp upon background tty read */ #define SIGTTOU 22 /* like TTIN for output if (tp->t_local<OSTOP) */ #define SIGIO 23 /* input/output possible signal */ #define SIGPOLL SIGIO /* System V name for SIGIO */ #define SIGWINCH 24 /* window changed */ #define SIGUSR1 25 /* user defined signal 1 */ #define SIGUSR2 26 /* user defined signal 2 */ /* Real-Time Signals Range, P1003.1b-1993, p. 61 NOTE: By P1003.1b-1993, this should be at least RTSIG_MAX (which is a minimum of 8) signals. */ #define SIGRTMIN 27 #define SIGRTMAX 31 #define __SIGFIRSTNOTRT SIGHUP #define __SIGLASTNOTRT SIGUSR2 #define NSIG 32 /* signal 0 implied */ #elif defined(__svr4__) /* svr4 specifics. different signals above 15, and sigaction. */ #define SIGUSR1 16 #define SIGUSR2 17 #define SIGCLD 18 #define SIGPWR 19 #define SIGWINCH 20 #define SIGPOLL 22 /* 20 for x.out binaries!!!! */ #define SIGSTOP 23 /* sendable stop signal not from tty */ #define SIGTSTP 24 /* stop signal from tty */ #define SIGCONT 25 /* continue a stopped process */ #define SIGTTIN 26 /* to readers pgrp upon background tty read */ #define SIGTTOU 27 /* like TTIN for output if (tp->t_local<OSTOP) */ #define NSIG 28 #else #define SIGURG 16 /* urgent condition on IO channel */ #define SIGSTOP 17 /* sendable stop signal not from tty */ #define SIGTSTP 18 /* stop signal from tty */ #define SIGCONT 19 /* continue a stopped process */ #define SIGCHLD 20 /* to parent on child stop or exit */ #define SIGCLD 20 /* System V name for SIGCHLD */ #define SIGTTIN 21 /* to readers pgrp upon background tty read */ #define SIGTTOU 22 /* like TTIN for output if (tp->t_local<OSTOP) */ #define SIGIO 23 /* input/output possible signal */ #define SIGPOLL SIGIO /* System V name for SIGIO */ #define SIGXCPU 24 /* exceeded CPU time limit */ #define SIGXFSZ 25 /* exceeded file size limit */ #define SIGVTALRM 26 /* virtual time alarm */ #define SIGPROF 27 /* profiling time alarm */ #define SIGWINCH 28 /* window changed */ #define SIGLOST 29 /* resource lost (eg, record-lock lost) */ #define SIGUSR1 30 /* user defined signal 1 */ #define SIGUSR2 31 /* user defined signal 2 */ #define NSIG 32 /* signal 0 implied */ #endif #endif #ifdef __cplusplus } #endif #ifndef _SIGNAL_H_ /* Some applications take advantage of the fact that * and are equivalent in glibc. Allow for that here. */ #include #endif #endif /* _SYS_SIGNAL_H */ 07070100000056000081a40000000000000000000000016181423d00001814000000000000000000000000000000000000002400000000./usr/nvptx-none/include/sys/stat.h#ifndef _SYS_STAT_H #define _SYS_STAT_H #ifdef __cplusplus extern "C" { #endif #include <_ansi.h> #include #include #include /* dj's stat defines _STAT_H_ */ #ifndef _STAT_H_ /* It is intended that the layout of this structure not change when the sizes of any of the basic types change (short, int, long) [via a compile time option]. */ #ifdef __CYGWIN__ #include #ifdef _COMPILING_NEWLIB #define stat64 stat #endif #else struct stat { dev_t st_dev; ino_t st_ino; mode_t st_mode; nlink_t st_nlink; uid_t st_uid; gid_t st_gid; dev_t st_rdev; off_t st_size; #if defined(__rtems__) struct timespec st_atim; struct timespec st_mtim; struct timespec st_ctim; blksize_t st_blksize; blkcnt_t st_blocks; #else /* SysV/sco doesn't have the rest... But Solaris, eabi does. */ #if defined(__svr4__) && !defined(__PPC__) && !defined(__sun__) time_t st_atime; time_t st_mtime; time_t st_ctime; #else time_t st_atime; long st_spare1; time_t st_mtime; long st_spare2; time_t st_ctime; long st_spare3; long st_blksize; long st_blocks; long st_spare4[2]; #endif #endif }; #if defined(__rtems__) #define st_atime st_atim.tv_sec #define st_ctime st_ctim.tv_sec #define st_mtime st_mtim.tv_sec #endif #endif #define _IFMT 0170000 /* type of file */ #define _IFDIR 0040000 /* directory */ #define _IFCHR 0020000 /* character special */ #define _IFBLK 0060000 /* block special */ #define _IFREG 0100000 /* regular */ #define _IFLNK 0120000 /* symbolic link */ #define _IFSOCK 0140000 /* socket */ #define _IFIFO 0010000 /* fifo */ #define S_BLKSIZE 1024 /* size of a block */ #define S_ISUID 0004000 /* set user id on execution */ #define S_ISGID 0002000 /* set group id on execution */ #define S_ISVTX 0001000 /* save swapped text even after use */ #ifndef _POSIX_SOURCE #define S_IREAD 0000400 /* read permission, owner */ #define S_IWRITE 0000200 /* write permission, owner */ #define S_IEXEC 0000100 /* execute/search permission, owner */ #define S_ENFMT 0002000 /* enforcement-mode locking */ #endif /* !_POSIX_SOURCE */ #define S_IFMT _IFMT #define S_IFDIR _IFDIR #define S_IFCHR _IFCHR #define S_IFBLK _IFBLK #define S_IFREG _IFREG #define S_IFLNK _IFLNK #define S_IFSOCK _IFSOCK #define S_IFIFO _IFIFO #ifdef _WIN32 /* The Windows header files define _S_ forms of these, so we do too for easier portability. */ #define _S_IFMT _IFMT #define _S_IFDIR _IFDIR #define _S_IFCHR _IFCHR #define _S_IFIFO _IFIFO #define _S_IFREG _IFREG #define _S_IREAD 0000400 #define _S_IWRITE 0000200 #define _S_IEXEC 0000100 #endif #define S_IRWXU (S_IRUSR | S_IWUSR | S_IXUSR) #define S_IRUSR 0000400 /* read permission, owner */ #define S_IWUSR 0000200 /* write permission, owner */ #define S_IXUSR 0000100/* execute/search permission, owner */ #define S_IRWXG (S_IRGRP | S_IWGRP | S_IXGRP) #define S_IRGRP 0000040 /* read permission, group */ #define S_IWGRP 0000020 /* write permission, grougroup */ #define S_IXGRP 0000010/* execute/search permission, group */ #define S_IRWXO (S_IROTH | S_IWOTH | S_IXOTH) #define S_IROTH 0000004 /* read permission, other */ #define S_IWOTH 0000002 /* write permission, other */ #define S_IXOTH 0000001/* execute/search permission, other */ #ifndef _POSIX_SOURCE #define ACCESSPERMS (S_IRWXU | S_IRWXG | S_IRWXO) /* 0777 */ #define ALLPERMS (S_ISUID | S_ISGID | S_ISVTX | S_IRWXU | S_IRWXG | S_IRWXO) /* 07777 */ #define DEFFILEMODE (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH) /* 0666 */ #endif #define S_ISBLK(m) (((m)&_IFMT) == _IFBLK) #define S_ISCHR(m) (((m)&_IFMT) == _IFCHR) #define S_ISDIR(m) (((m)&_IFMT) == _IFDIR) #define S_ISFIFO(m) (((m)&_IFMT) == _IFIFO) #define S_ISREG(m) (((m)&_IFMT) == _IFREG) #define S_ISLNK(m) (((m)&_IFMT) == _IFLNK) #define S_ISSOCK(m) (((m)&_IFMT) == _IFSOCK) #if defined(__CYGWIN__) /* Special tv_nsec values for futimens(2) and utimensat(2). */ #define UTIME_NOW -2L #define UTIME_OMIT -1L #endif int _EXFUN(chmod,( const char *__path, mode_t __mode )); int _EXFUN(fchmod,(int __fd, mode_t __mode)); int _EXFUN(fstat,( int __fd, struct stat *__sbuf )); int _EXFUN(mkdir,( const char *_path, mode_t __mode )); int _EXFUN(mkfifo,( const char *__path, mode_t __mode )); int _EXFUN(stat,( const char *__restrict __path, struct stat *__restrict __sbuf )); mode_t _EXFUN(umask,( mode_t __mask )); #if defined (__SPU__) || defined(__rtems__) || defined(__CYGWIN__) && !defined(__INSIDE_CYGWIN__) int _EXFUN(lstat,( const char *__restrict __path, struct stat *__restrict __buf )); int _EXFUN(mknod,( const char *__path, mode_t __mode, dev_t __dev )); #endif #if (__POSIX_VISIBLE >= 200809 || defined (__CYGWIN__)) && !defined(__INSIDE_CYGWIN__) int _EXFUN(fchmodat, (int, const char *, mode_t, int)); #endif #if (__BSD_VISIBLE || __POSIX_VISIBLE >= 200809 || defined (__CYGWIN__)) && !defined(__INSIDE_CYGWIN__) int _EXFUN(fstatat, (int, const char *__restrict , struct stat *__restrict, int)); int _EXFUN(mkdirat, (int, const char *, mode_t)); int _EXFUN(mkfifoat, (int, const char *, mode_t)); #endif #if (__BSD_VISIBLE || __XSI_VISIBLE >= 700 || defined (__CYGWIN__)) && !defined(__INSIDE_CYGWIN__) int _EXFUN(mknodat, (int, const char *, mode_t, dev_t)); #endif #if (__BSD_VISIBLE || __POSIX_VISIBLE >= 200809 || defined (__CYGWIN__)) && !defined(__INSIDE_CYGWIN__) int _EXFUN(utimensat, (int, const char *, const struct timespec *, int)); int _EXFUN(futimens, (int, const struct timespec *)); #endif /* Provide prototypes for most of the _ names that are provided in newlib for some compilers. */ #ifdef _COMPILING_NEWLIB int _EXFUN(_fstat,( int __fd, struct stat *__sbuf )); int _EXFUN(_stat,( const char *__restrict __path, struct stat *__restrict __sbuf )); int _EXFUN(_mkdir,( const char *_path, mode_t __mode )); #ifdef __LARGE64_FILES struct stat64; int _EXFUN(_stat64,( const char *__restrict __path, struct stat64 *__restrict __sbuf )); int _EXFUN(_fstat64,( int __fd, struct stat64 *__sbuf )); #endif #endif #endif /* !_STAT_H_ */ #ifdef __cplusplus } #endif #endif /* _SYS_STAT_H */ 07070100000057000081a40000000000000000000000016181423d00000327000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/stdio.h#ifndef _NEWLIB_STDIO_H #define _NEWLIB_STDIO_H #include #include /* Internal locking macros, used to protect stdio functions. In the general case, expand to nothing. Use __SSTR flag in FILE _flags to detect if FILE is private to sprintf/sscanf class of functions; if set then do nothing as lock is not initialised. */ #if !defined(_flockfile) #ifndef __SINGLE_THREAD__ # define _flockfile(fp) (((fp)->_flags & __SSTR) ? 0 : __lock_acquire_recursive((fp)->_lock)) #else # define _flockfile(fp) (_CAST_VOID 0) #endif #endif #if !defined(_funlockfile) #ifndef __SINGLE_THREAD__ # define _funlockfile(fp) (((fp)->_flags & __SSTR) ? 0 : __lock_release_recursive((fp)->_lock)) #else # define _funlockfile(fp) (_CAST_VOID 0) #endif #endif #endif /* _NEWLIB_STDIO_H */ 07070100000058000081a40000000000000000000000016181423d00000074000000000000000000000000000000000000002600000000./usr/nvptx-none/include/sys/string.h/* This is a dummy used as a placeholder for systems that need to have a special header file. */ 07070100000059000081a40000000000000000000000016181423d00000c8b000000000000000000000000000000000000002900000000./usr/nvptx-none/include/sys/syslimits.h/* * Copyright (c) 1988, 1993 * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. * * @(#)syslimits.h 8.1 (Berkeley) 6/2/93 * $FreeBSD: src/sys/sys/syslimits.h,v 1.10 2001/06/18 20:24:54 wollman Exp $ */ #ifndef _SYS_SYSLIMITS_H_ #define _SYS_SYSLIMITS_H_ #define ARG_MAX 65536 /* max bytes for an exec function */ #ifndef CHILD_MAX #define CHILD_MAX 40 /* max simultaneous processes */ #endif #define LINK_MAX 32767 /* max file link count */ #define MAX_CANON 255 /* max bytes in term canon input line */ #define MAX_INPUT 255 /* max bytes in terminal input */ #define NAME_MAX 255 /* max bytes in a file name */ #define NGROUPS_MAX 16 /* max supplemental group id's */ #ifndef OPEN_MAX #define OPEN_MAX 64 /* max open files per process */ #endif #define PATH_MAX 1024 /* max bytes in pathname */ #define PIPE_BUF 512 /* max bytes for atomic pipe writes */ #define IOV_MAX 1024 /* max elements in i/o vector */ #define BC_BASE_MAX 99 /* max ibase/obase values in bc(1) */ #define BC_DIM_MAX 2048 /* max array elements in bc(1) */ #define BC_SCALE_MAX 99 /* max scale value in bc(1) */ #define BC_STRING_MAX 1000 /* max const string length in bc(1) */ #define COLL_WEIGHTS_MAX 0 /* max weights for order keyword */ #define EXPR_NEST_MAX 32 /* max expressions nested in expr(1) */ #define LINE_MAX 2048 /* max bytes in an input line */ #define RE_DUP_MAX 255 /* max RE's in interval notation */ #endif 0707010000005a000081a40000000000000000000000016181423d00000a1a000000000000000000000000000000000000002400000000./usr/nvptx-none/include/sys/time.h/* time.h -- An implementation of the standard Unix file. Written by Geoffrey Noer Public domain; no rights reserved. */ #ifndef _SYS_TIME_H_ #define _SYS_TIME_H_ #include <_ansi.h> #include #ifdef __cplusplus extern "C" { #endif #ifndef _TIMEVAL_DEFINED #define _TIMEVAL_DEFINED struct timeval { time_t tv_sec; suseconds_t tv_usec; }; /* BSD time macros used by RTEMS code */ #if defined (__rtems__) || defined (__CYGWIN__) /* Convenience macros for operations on timevals. NOTE: `timercmp' does not work for >= or <=. */ #define timerisset(tvp) ((tvp)->tv_sec || (tvp)->tv_usec) #define timerclear(tvp) ((tvp)->tv_sec = (tvp)->tv_usec = 0) #define timercmp(a, b, CMP) \ (((a)->tv_sec == (b)->tv_sec) ? \ ((a)->tv_usec CMP (b)->tv_usec) : \ ((a)->tv_sec CMP (b)->tv_sec)) #define timeradd(a, b, result) \ do { \ (result)->tv_sec = (a)->tv_sec + (b)->tv_sec; \ (result)->tv_usec = (a)->tv_usec + (b)->tv_usec; \ if ((result)->tv_usec >= 1000000) \ { \ ++(result)->tv_sec; \ (result)->tv_usec -= 1000000; \ } \ } while (0) #define timersub(a, b, result) \ do { \ (result)->tv_sec = (a)->tv_sec - (b)->tv_sec; \ (result)->tv_usec = (a)->tv_usec - (b)->tv_usec; \ if ((result)->tv_usec < 0) { \ --(result)->tv_sec; \ (result)->tv_usec += 1000000; \ } \ } while (0) #endif /* defined (__rtems__) || defined (__CYGWIN__) */ #endif /* !_TIMEVAL_DEFINED */ struct timezone { int tz_minuteswest; int tz_dsttime; }; #ifdef __CYGWIN__ #include #endif /* __CYGWIN__ */ #define ITIMER_REAL 0 #define ITIMER_VIRTUAL 1 #define ITIMER_PROF 2 struct itimerval { struct timeval it_interval; struct timeval it_value; }; #ifdef _COMPILING_NEWLIB int _EXFUN(_gettimeofday, (struct timeval *__p, void *__tz)); #endif int _EXFUN(gettimeofday, (struct timeval *__restrict __p, void *__restrict __tz)); int _EXFUN(settimeofday, (const struct timeval *, const struct timezone *)); int _EXFUN(utimes, (const char *__path, const struct timeval *__tvp)); int _EXFUN(getitimer, (int __which, struct itimerval *__value)); int _EXFUN(setitimer, (int __which, const struct itimerval *__restrict __value, struct itimerval *__restrict __ovalue)); #ifdef __cplusplus } #endif #endif /* _SYS_TIME_H_ */ 0707010000005b000081a40000000000000000000000016181423d000002f0000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/timeb.h/* timeb.h -- An implementation of the standard Unix file. Written by Ian Lance Taylor Public domain; no rights reserved. declares the structure used by the ftime function, as well as the ftime function itself. Newlib does not provide an implementation of ftime. */ #ifndef _SYS_TIMEB_H #ifdef __cplusplus extern "C" { #endif #define _SYS_TIMEB_H #include <_ansi.h> #include #ifndef __time_t_defined typedef _TIME_T_ time_t; #define __time_t_defined #endif struct timeb { time_t time; unsigned short millitm; short timezone; short dstflag; }; extern int ftime _PARAMS ((struct timeb *)); #ifdef __cplusplus } #endif #endif /* ! defined (_SYS_TIMEB_H) */ 0707010000005c000081a40000000000000000000000016181423d0000026b000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/times.h#ifndef _SYS_TIMES_H #ifdef __cplusplus extern "C" { #endif #define _SYS_TIMES_H #include <_ansi.h> #include #ifndef __clock_t_defined typedef _CLOCK_T_ clock_t; #define __clock_t_defined #endif /* Get Process Times, P1003.1b-1993, p. 92 */ struct tms { clock_t tms_utime; /* user time */ clock_t tms_stime; /* system time */ clock_t tms_cutime; /* user time, children */ clock_t tms_cstime; /* system time, children */ }; clock_t _EXFUN(times,(struct tms *)); #ifdef _COMPILING_NEWLIB clock_t _EXFUN(_times,(struct tms *)); #endif #ifdef __cplusplus } #endif #endif /* !_SYS_TIMES_H */ 0707010000005d000081a40000000000000000000000016181423d0000383c000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/types.h/* unified sys/types.h: start with sef's sysvi386 version. merge go32 version -- a few ifdefs. h8300hms, h8300xray, and sysvnecv70 disagree on the following types: typedef int gid_t; typedef int uid_t; typedef int dev_t; typedef int ino_t; typedef int mode_t; typedef int caddr_t; however, these aren't "reasonable" values, the sysvi386 ones make far more sense, and should work sufficiently well (in particular, h8300 doesn't have a stat, and the necv70 doesn't matter.) -- eichin */ #ifndef _SYS_TYPES_H #include <_ansi.h> #ifndef __INTTYPES_DEFINED__ #define __INTTYPES_DEFINED__ #include #if defined(__rtems__) || defined(__XMK__) /* * The following section is RTEMS specific and is needed to more * closely match the types defined in the BSD sys/types.h. * This is needed to let the RTEMS/BSD TCP/IP stack compile. */ /* deprecated */ #if ___int8_t_defined typedef __uint8_t u_int8_t; #endif #if ___int16_t_defined typedef __uint16_t u_int16_t; #endif #if ___int32_t_defined typedef __uint32_t u_int32_t; #endif #if ___int64_t_defined typedef __uint64_t u_int64_t; /* deprecated */ typedef __uint64_t u_quad_t; typedef __int64_t quad_t; typedef quad_t * qaddr_t; #endif #endif #endif /* ! __INTTYPES_DEFINED */ #ifndef __need_inttypes #define _SYS_TYPES_H #include #ifdef __i386__ #if defined (GO32) || defined (__MSDOS__) #define __MS_types__ #endif #endif # include # include /* To ensure the stat struct's layout doesn't change when sizeof(int), etc. changes, we assume sizeof short and long never change and have all types used to define struct stat use them and not int where possible. Where not possible, _ST_INTxx are used. It would be preferable to not have such assumptions, but until the extra fluff is necessary, it's avoided. No 64 bit targets use stat yet. What to do about them is postponed until necessary. */ #ifdef __GNUC__ #define _ST_INT32 __attribute__ ((__mode__ (__SI__))) #else #define _ST_INT32 #endif # ifndef _POSIX_SOURCE # define physadr physadr_t # define quad quad_t #ifndef _BSDTYPES_DEFINED /* also defined in mingw/gmon.h and in w32api/winsock[2].h */ #ifndef __u_char_defined typedef unsigned char u_char; #define __u_char_defined #endif #ifndef __u_short_defined typedef unsigned short u_short; #define __u_short_defined #endif #ifndef __u_int_defined typedef unsigned int u_int; #define __u_int_defined #endif #ifndef __u_long_defined typedef unsigned long u_long; #define __u_long_defined #endif #define _BSDTYPES_DEFINED #endif typedef unsigned short ushort; /* System V compatibility */ typedef unsigned int uint; /* System V compatibility */ typedef unsigned long ulong; /* System V compatibility */ # endif /*!_POSIX_SOURCE */ #ifndef __clock_t_defined typedef _CLOCK_T_ clock_t; #define __clock_t_defined #endif #ifndef __time_t_defined typedef _TIME_T_ time_t; #define __time_t_defined #endif #ifndef __timespec_defined #define __timespec_defined /* Time Value Specification Structures, P1003.1b-1993, p. 261 */ struct timespec { time_t tv_sec; /* Seconds */ long tv_nsec; /* Nanoseconds */ }; #endif struct itimerspec { struct timespec it_interval; /* Timer period */ struct timespec it_value; /* Timer expiration */ }; #ifndef __daddr_t_defined typedef long daddr_t; #define __daddr_t_defined #endif #ifndef __caddr_t_defined typedef char * caddr_t; #define __caddr_t_defined #endif #ifndef __CYGWIN__ #if defined(__MS_types__) || defined(__rtems__) || \ defined(__sparc__) || defined(__SPU__) typedef unsigned long ino_t; #else typedef unsigned short ino_t; #endif #endif /*__CYGWIN__*/ #ifdef __MS_types__ typedef unsigned long vm_offset_t; typedef unsigned long vm_size_t; #define __BIT_TYPES_DEFINED__ typedef signed char int8_t; typedef unsigned char u_int8_t; typedef short int16_t; typedef unsigned short u_int16_t; typedef int int32_t; typedef unsigned int u_int32_t; typedef long long int64_t; typedef unsigned long long u_int64_t; typedef int32_t register_t; #endif /* __MS_types__ */ /* * All these should be machine specific - right now they are all broken. * However, for all of Cygnus' embedded targets, we want them to all be * the same. Otherwise things like sizeof (struct stat) might depend on * how the file was compiled (e.g. -mint16 vs -mint32, etc.). */ #ifndef __CYGWIN__ /* which defines these types in it's own types.h. */ typedef _off_t off_t; typedef __dev_t dev_t; typedef __uid_t uid_t; typedef __gid_t gid_t; #endif #if defined(__XMK__) typedef signed char pid_t; #else typedef int pid_t; #endif #if defined(__rtems__) typedef _mode_t mode_t; #endif #ifndef __CYGWIN__ typedef long key_t; #endif typedef _ssize_t ssize_t; #if !defined(__CYGWIN__) && !defined(__rtems__) #ifdef __MS_types__ typedef char * addr_t; typedef int mode_t; #else #if defined (__sparc__) && !defined (__sparc_v9__) #ifdef __svr4__ typedef unsigned long mode_t; #else typedef unsigned short mode_t; #endif #else typedef unsigned int mode_t _ST_INT32; #endif #endif /* ! __MS_types__ */ #endif /*__CYGWIN__*/ typedef unsigned short nlink_t; /* We don't define fd_set and friends if we are compiling POSIX source, or if we have included (or may include as indicated by __USE_W32_SOCKETS) the W32api winsock[2].h header which defines Windows versions of them. Note that a program which includes the W32api winsock[2].h header must know what it is doing; it must not call the cygwin32 select function. */ # if !(defined (_POSIX_SOURCE) || defined (_WINSOCK_H) || defined (_WINSOCKAPI_) || defined (__USE_W32_SOCKETS)) # define _SYS_TYPES_FD_SET # define NBBY 8 /* number of bits in a byte */ /* * Select uses bit masks of file descriptors in longs. * These macros manipulate such bit fields (the filesystem macros use chars). * FD_SETSIZE may be defined by the user, but the default here * should be >= NOFILE (param.h). */ # ifndef FD_SETSIZE # define FD_SETSIZE 64 # endif typedef long fd_mask; # define NFDBITS (sizeof (fd_mask) * NBBY) /* bits per mask */ # ifndef howmany # define howmany(x,y) (((x)+((y)-1))/(y)) # endif /* We use a macro for fd_set so that including Sockets.h afterwards can work. */ typedef struct _types_fd_set { fd_mask fds_bits[howmany(FD_SETSIZE, NFDBITS)]; } _types_fd_set; #define fd_set _types_fd_set # define FD_SET(n, p) ((p)->fds_bits[(n)/NFDBITS] |= (1L << ((n) % NFDBITS))) # define FD_CLR(n, p) ((p)->fds_bits[(n)/NFDBITS] &= ~(1L << ((n) % NFDBITS))) # define FD_ISSET(n, p) ((p)->fds_bits[(n)/NFDBITS] & (1L << ((n) % NFDBITS))) # define FD_ZERO(p) (__extension__ (void)({ \ size_t __i; \ char *__tmp = (char *)p; \ for (__i = 0; __i < sizeof (*(p)); ++__i) \ *__tmp++ = 0; \ })) # endif /* !(defined (_POSIX_SOURCE) || defined (_WINSOCK_H) || defined (_WINSOCKAPI_) || defined (__USE_W32_SOCKETS)) */ #undef __MS_types__ #undef _ST_INT32 #ifndef __clockid_t_defined typedef _CLOCKID_T_ clockid_t; #define __clockid_t_defined #endif #ifndef __timer_t_defined typedef _TIMER_T_ timer_t; #define __timer_t_defined #endif typedef unsigned long useconds_t; typedef long suseconds_t; #include /* Cygwin will probably never have full posix compliance due to little things * like an inability to set the stackaddress. Cygwin is also using void * * pointers rather than structs to ensure maximum binary compatability with * previous releases. * This means that we don't use the types defined here, but rather in * */ #if defined(_POSIX_THREADS) && !defined(__CYGWIN__) #include /* * 2.5 Primitive System Data Types, P1003.1c/D10, p. 19. */ #if defined(__XMK__) typedef unsigned int pthread_t; /* identify a thread */ #else typedef __uint32_t pthread_t; /* identify a thread */ #endif /* P1003.1c/D10, p. 118-119 */ #define PTHREAD_SCOPE_PROCESS 0 #define PTHREAD_SCOPE_SYSTEM 1 /* P1003.1c/D10, p. 111 */ #define PTHREAD_INHERIT_SCHED 1 /* scheduling policy and associated */ /* attributes are inherited from */ /* the calling thread. */ #define PTHREAD_EXPLICIT_SCHED 2 /* set from provided attribute object */ /* P1003.1c/D10, p. 141 */ #define PTHREAD_CREATE_DETACHED 0 #define PTHREAD_CREATE_JOINABLE 1 #if defined(__rtems__) #include #endif #if defined(__XMK__) typedef struct pthread_attr_s { int contentionscope; struct sched_param schedparam; int detachstate; void *stackaddr; size_t stacksize; } pthread_attr_t; #define PTHREAD_STACK_MIN 200 #else /* !defined(__XMK__) */ typedef struct { int is_initialized; void *stackaddr; int stacksize; int contentionscope; int inheritsched; int schedpolicy; struct sched_param schedparam; #if defined(__rtems__) size_t guardsize; #endif /* P1003.4b/D8, p. 54 adds cputime_clock_allowed attribute. */ #if defined(_POSIX_THREAD_CPUTIME) int cputime_clock_allowed; /* see time.h */ #endif int detachstate; #if defined(__rtems__) size_t affinitysetsize; cpu_set_t *affinityset; cpu_set_t affinitysetpreallocated; #endif } pthread_attr_t; #endif /* !defined(__XMK__) */ #if defined(_POSIX_THREAD_PROCESS_SHARED) /* NOTE: P1003.1c/D10, p. 81 defines following values for process_shared. */ #define PTHREAD_PROCESS_PRIVATE 0 /* visible within only the creating process */ #define PTHREAD_PROCESS_SHARED 1 /* visible too all processes with access to */ /* the memory where the resource is */ /* located */ #endif #if defined(_POSIX_THREAD_PRIO_PROTECT) /* Mutexes */ /* Values for blocking protocol. */ #define PTHREAD_PRIO_NONE 0 #define PTHREAD_PRIO_INHERIT 1 #define PTHREAD_PRIO_PROTECT 2 #endif #if defined(_UNIX98_THREAD_MUTEX_ATTRIBUTES) /* Values for mutex type */ /* The following defines are part of the X/Open System Interface (XSI). */ /* * This type of mutex does not detect deadlock. A thread attempting to * relock this mutex without first unlocking it shall deadlock. Attempting * to unlock a mutex locked by a different thread results in undefined * behavior. Attempting to unlock an unlocked mutex results in undefined * behavior. */ #define PTHREAD_MUTEX_NORMAL 0 /* * A thread attempting to relock this mutex without first unlocking * it shall succeed in locking the mutex. The relocking deadlock which * can occur with mutexes of type PTHREAD_MUTEX_NORMAL cannot occur with * this type of mutex. Multiple locks of this mutex shall require the * same number of unlocks to release the mutex before another thread can * acquire the mutex. A thread attempting to unlock a mutex which another * thread has locked shall return with an error. A thread attempting to * unlock an unlocked mutex shall return with an error. */ #define PTHREAD_MUTEX_RECURSIVE 1 /* * This type of mutex provides error checking. A thread attempting * to relock this mutex without first unlocking it shall return with an * error. A thread attempting to unlock a mutex which another thread has * locked shall return with an error. A thread attempting to unlock an * unlocked mutex shall return with an error. */ #define PTHREAD_MUTEX_ERRORCHECK 2 /* * Attempting to recursively lock a mutex of this type results * in undefined behavior. Attempting to unlock a mutex of this type * which was not locked by the calling thread results in undefined * behavior. Attempting to unlock a mutex of this type which is not locked * results in undefined behavior. An implementation may map this mutex to * one of the other mutex types. */ #define PTHREAD_MUTEX_DEFAULT 3 #endif /* !defined(_UNIX98_THREAD_MUTEX_ATTRIBUTES) */ #if defined(__XMK__) typedef unsigned int pthread_mutex_t; /* identify a mutex */ typedef struct { int type; } pthread_mutexattr_t; #else /* !defined(__XMK__) */ typedef __uint32_t pthread_mutex_t; /* identify a mutex */ typedef struct { int is_initialized; #if defined(_POSIX_THREAD_PROCESS_SHARED) int process_shared; /* allow mutex to be shared amongst processes */ #endif #if defined(_POSIX_THREAD_PRIO_PROTECT) int prio_ceiling; int protocol; #endif #if defined(_UNIX98_THREAD_MUTEX_ATTRIBUTES) int type; #endif int recursive; } pthread_mutexattr_t; #endif /* !defined(__XMK__) */ /* Condition Variables */ typedef __uint32_t pthread_cond_t; /* identify a condition variable */ typedef struct { int is_initialized; #if defined(_POSIX_THREAD_PROCESS_SHARED) int process_shared; /* allow this to be shared amongst processes */ #endif } pthread_condattr_t; /* a condition attribute object */ /* Keys */ typedef __uint32_t pthread_key_t; /* thread-specific data keys */ typedef struct { int is_initialized; /* is this structure initialized? */ int init_executed; /* has the initialization routine been run? */ } pthread_once_t; /* dynamic package initialization */ #else #if defined (__CYGWIN__) #include #endif #endif /* defined(_POSIX_THREADS) */ /* POSIX Barrier Types */ #if defined(_POSIX_BARRIERS) typedef __uint32_t pthread_barrier_t; /* POSIX Barrier Object */ typedef struct { int is_initialized; /* is this structure initialized? */ #if defined(_POSIX_THREAD_PROCESS_SHARED) int process_shared; /* allow this to be shared amongst processes */ #endif } pthread_barrierattr_t; #endif /* defined(_POSIX_BARRIERS) */ /* POSIX Spin Lock Types */ #if !defined (__CYGWIN__) #if defined(_POSIX_SPIN_LOCKS) typedef __uint32_t pthread_spinlock_t; /* POSIX Spin Lock Object */ #endif /* defined(_POSIX_SPIN_LOCKS) */ /* POSIX Reader/Writer Lock Types */ #if defined(_POSIX_READER_WRITER_LOCKS) typedef __uint32_t pthread_rwlock_t; /* POSIX RWLock Object */ typedef struct { int is_initialized; /* is this structure initialized? */ #if defined(_POSIX_THREAD_PROCESS_SHARED) int process_shared; /* allow this to be shared amongst processes */ #endif } pthread_rwlockattr_t; #endif /* defined(_POSIX_READER_WRITER_LOCKS) */ #endif /* __CYGWIN__ */ #endif /* !__need_inttypes */ #undef __need_inttypes #endif /* _SYS_TYPES_H */ 0707010000005e000081a40000000000000000000000016181423d000052ec000000000000000000000000000000000000002600000000./usr/nvptx-none/include/sys/unistd.h#ifndef _SYS_UNISTD_H #define _SYS_UNISTD_H #ifdef __cplusplus extern "C" { #endif #include <_ansi.h> #define __need_size_t #define __need_ptrdiff_t #include #include #include #include extern char **environ; void _EXFUN(_exit, (int __status ) _ATTRIBUTE ((noreturn))); int _EXFUN(access,(const char *__path, int __amode )); unsigned _EXFUN(alarm, (unsigned __secs )); int _EXFUN(chdir, (const char *__path )); int _EXFUN(chmod, (const char *__path, mode_t __mode )); #if !defined(__INSIDE_CYGWIN__) int _EXFUN(chown, (const char *__path, uid_t __owner, gid_t __group )); #endif #if defined(__CYGWIN__) || defined(__rtems__) int _EXFUN(chroot, (const char *__path )); #endif int _EXFUN(close, (int __fildes )); #if defined(__CYGWIN__) size_t _EXFUN(confstr, (int __name, char *__buf, size_t __len)); #endif char * _EXFUN(ctermid, (char *__s )); char * _EXFUN(cuserid, (char *__s )); #if defined(__CYGWIN__) int _EXFUN(daemon, (int nochdir, int noclose)); #endif int _EXFUN(dup, (int __fildes )); int _EXFUN(dup2, (int __fildes, int __fildes2 )); #if defined(__CYGWIN__) int _EXFUN(dup3, (int __fildes, int __fildes2, int flags)); int _EXFUN(eaccess, (const char *__path, int __mode)); void _EXFUN(endusershell, (void)); int _EXFUN(euidaccess, (const char *__path, int __mode)); #endif int _EXFUN(execl, (const char *__path, const char *, ... )); int _EXFUN(execle, (const char *__path, const char *, ... )); int _EXFUN(execlp, (const char *__file, const char *, ... )); #if defined(__CYGWIN__) int _EXFUN(execlpe, (const char *__file, const char *, ... )); #endif int _EXFUN(execv, (const char *__path, char * const __argv[] )); int _EXFUN(execve, (const char *__path, char * const __argv[], char * const __envp[] )); int _EXFUN(execvp, (const char *__file, char * const __argv[] )); #if defined(__CYGWIN__) int _EXFUN(execvpe, (const char *__file, char * const __argv[], char * const __envp[] )); #endif #if __POSIX_VISIBLE >= 200809 || __BSD_VISIBLE || defined(__CYGWIN__) int _EXFUN(faccessat, (int __dirfd, const char *__path, int __mode, int __flags)); #endif #if defined(__CYGWIN__) || defined(__rtems__) || defined(__SPU__) int _EXFUN(fchdir, (int __fildes)); #endif int _EXFUN(fchmod, (int __fildes, mode_t __mode )); #if !defined(__INSIDE_CYGWIN__) int _EXFUN(fchown, (int __fildes, uid_t __owner, gid_t __group )); #endif #if __POSIX_VISIBLE >= 200809 || __BSD_VISIBLE || defined(__CYGWIN__) int _EXFUN(fchownat, (int __dirfd, const char *__path, uid_t __owner, gid_t __group, int __flags)); #endif #if defined(__CYGWIN__) int _EXFUN(fexecve, (int __fd, char * const __argv[], char * const __envp[] )); #endif pid_t _EXFUN(fork, (void )); long _EXFUN(fpathconf, (int __fd, int __name )); int _EXFUN(fsync, (int __fd)); int _EXFUN(fdatasync, (int __fd)); #if defined(__CYGWIN__) char * _EXFUN(get_current_dir_name, (void)); #endif char * _EXFUN(getcwd, (char *__buf, size_t __size )); #if defined(__CYGWIN__) int _EXFUN(getdomainname ,(char *__name, size_t __len)); #endif #if !defined(__INSIDE_CYGWIN__) gid_t _EXFUN(getegid, (void )); uid_t _EXFUN(geteuid, (void )); gid_t _EXFUN(getgid, (void )); #endif int _EXFUN(getgroups, (int __gidsetsize, gid_t __grouplist[] )); #if defined(__CYGWIN__) long _EXFUN(gethostid, (void)); #endif char * _EXFUN(getlogin, (void )); #if defined(_POSIX_THREAD_SAFE_FUNCTIONS) int _EXFUN(getlogin_r, (char *name, size_t namesize) ); #endif char * _EXFUN(getpass, (const char *__prompt)); int _EXFUN(getpagesize, (void)); #if defined(__CYGWIN__) int _EXFUN(getpeereid, (int, uid_t *, gid_t *)); #endif pid_t _EXFUN(getpgid, (pid_t)); pid_t _EXFUN(getpgrp, (void )); pid_t _EXFUN(getpid, (void )); pid_t _EXFUN(getppid, (void )); #if defined(__CYGWIN__) || defined(__rtems__) pid_t _EXFUN(getsid, (pid_t)); #endif #if !defined(__INSIDE_CYGWIN__) uid_t _EXFUN(getuid, (void )); #endif #ifdef __CYGWIN__ char * _EXFUN(getusershell, (void)); char * _EXFUN(getwd, (char *__buf )); int _EXFUN(iruserok, (unsigned long raddr, int superuser, const char *ruser, const char *luser)); #endif int _EXFUN(isatty, (int __fildes )); #if !defined(__INSIDE_CYGWIN__) int _EXFUN(lchown, (const char *__path, uid_t __owner, gid_t __group )); #endif int _EXFUN(link, (const char *__path1, const char *__path2 )); #if __POSIX_VISIBLE >= 200809 || __BSD_VISIBLE || defined(__CYGWIN__) int _EXFUN(linkat, (int __dirfd1, const char *__path1, int __dirfd2, const char *__path2, int __flags )); #endif int _EXFUN(nice, (int __nice_value )); #if !defined(__INSIDE_CYGWIN__) off_t _EXFUN(lseek, (int __fildes, off_t __offset, int __whence )); #endif #if defined(__SPU__) || defined(__CYGWIN__) #define F_ULOCK 0 #define F_LOCK 1 #define F_TLOCK 2 #define F_TEST 3 int _EXFUN(lockf, (int __fd, int __cmd, off_t __len)); #endif long _EXFUN(pathconf, (const char *__path, int __name )); int _EXFUN(pause, (void )); #ifdef __CYGWIN__ int _EXFUN(pthread_atfork, (void (*)(void), void (*)(void), void (*)(void))); #endif int _EXFUN(pipe, (int __fildes[2] )); #ifdef __CYGWIN__ int _EXFUN(pipe2, (int __fildes[2], int flags)); #endif ssize_t _EXFUN(pread, (int __fd, void *__buf, size_t __nbytes, off_t __offset)); ssize_t _EXFUN(pwrite, (int __fd, const void *__buf, size_t __nbytes, off_t __offset)); _READ_WRITE_RETURN_TYPE _EXFUN(read, (int __fd, void *__buf, size_t __nbyte )); #if defined(__CYGWIN__) int _EXFUN(rresvport, (int *__alport)); int _EXFUN(revoke, (char *__path)); #endif int _EXFUN(rmdir, (const char *__path )); #if defined(__CYGWIN__) int _EXFUN(ruserok, (const char *rhost, int superuser, const char *ruser, const char *luser)); #endif void * _EXFUN(sbrk, (ptrdiff_t __incr)); #if !defined(__INSIDE_CYGWIN__) #if defined(__CYGWIN__) || defined(__rtems__) int _EXFUN(setegid, (gid_t __gid )); int _EXFUN(seteuid, (uid_t __uid )); #endif int _EXFUN(setgid, (gid_t __gid )); #endif #if defined(__CYGWIN__) int _EXFUN(setgroups, (int ngroups, const gid_t *grouplist )); #endif int _EXFUN(setpgid, (pid_t __pid, pid_t __pgid )); int _EXFUN(setpgrp, (void )); #if defined(__CYGWIN__) && !defined(__INSIDE_CYGWIN__) int _EXFUN(setregid, (gid_t __rgid, gid_t __egid)); int _EXFUN(setreuid, (uid_t __ruid, uid_t __euid)); #endif pid_t _EXFUN(setsid, (void )); #if !defined(__INSIDE_CYGWIN__) int _EXFUN(setuid, (uid_t __uid )); #endif #if defined(__CYGWIN__) void _EXFUN(setusershell, (void)); #endif unsigned _EXFUN(sleep, (unsigned int __seconds )); void _EXFUN(swab, (const void *__restrict, void *__restrict, ssize_t)); long _EXFUN(sysconf, (int __name )); pid_t _EXFUN(tcgetpgrp, (int __fildes )); int _EXFUN(tcsetpgrp, (int __fildes, pid_t __pgrp_id )); char * _EXFUN(ttyname, (int __fildes )); #if defined(__CYGWIN__) || defined(__rtems__) int _EXFUN(ttyname_r, (int, char *, size_t)); #endif int _EXFUN(unlink, (const char *__path )); int _EXFUN(usleep, (useconds_t __useconds)); int _EXFUN(vhangup, (void )); _READ_WRITE_RETURN_TYPE _EXFUN(write, (int __fd, const void *__buf, size_t __nbyte )); #ifdef __CYGWIN__ # define __UNISTD_GETOPT__ # include # undef __UNISTD_GETOPT__ #else extern char *optarg; /* getopt(3) external variables */ extern int optind, opterr, optopt; int getopt(int, char * const [], const char *); extern int optreset; /* getopt(3) external variable */ #endif #ifndef _POSIX_SOURCE pid_t _EXFUN(vfork, (void )); #endif /* _POSIX_SOURCE */ #ifdef _COMPILING_NEWLIB /* Provide prototypes for most of the _ names that are provided in newlib for some compilers. */ int _EXFUN(_close, (int __fildes )); pid_t _EXFUN(_fork, (void )); pid_t _EXFUN(_getpid, (void )); int _EXFUN(_isatty, (int __fildes )); int _EXFUN(_link, (const char *__path1, const char *__path2 )); _off_t _EXFUN(_lseek, (int __fildes, _off_t __offset, int __whence )); #ifdef __LARGE64_FILES _off64_t _EXFUN(_lseek64, (int __filedes, _off64_t __offset, int __whence )); #endif _READ_WRITE_RETURN_TYPE _EXFUN(_read, (int __fd, void *__buf, size_t __nbyte )); void * _EXFUN(_sbrk, (ptrdiff_t __incr)); int _EXFUN(_unlink, (const char *__path )); _READ_WRITE_RETURN_TYPE _EXFUN(_write, (int __fd, const void *__buf, size_t __nbyte )); int _EXFUN(_execve, (const char *__path, char * const __argv[], char * const __envp[] )); #endif #if defined(__CYGWIN__) || defined(__rtems__) || defined(__aarch64__) || defined (__arm__) || defined(__sh__) || defined(__SPU__) #if !defined(__INSIDE_CYGWIN__) int _EXFUN(ftruncate, (int __fd, off_t __length)); int _EXFUN(truncate, (const char *, off_t __length)); #endif #endif #if defined(__CYGWIN__) || defined(__rtems__) int _EXFUN(getdtablesize, (void)); int _EXFUN(setdtablesize, (int)); useconds_t _EXFUN(ualarm, (useconds_t __useconds, useconds_t __interval)); #if !(defined (_WINSOCK_H) || defined (_WINSOCKAPI_) || defined (__USE_W32_SOCKETS)) /* winsock[2].h defines as __stdcall, and with int as 2nd arg */ int _EXFUN(gethostname, (char *__name, size_t __len)); #endif char * _EXFUN(mktemp, (char *)); #endif #if defined(__CYGWIN__) || defined(__SPU__) || defined(__rtems__) void _EXFUN(sync, (void)); #endif ssize_t _EXFUN(readlink, (const char *__restrict __path, char *__restrict __buf, size_t __buflen)); #if __POSIX_VISIBLE >= 200809 || __BSD_VISIBLE || defined(__CYGWIN__) ssize_t _EXFUN(readlinkat, (int __dirfd1, const char *__restrict __path, char *__restrict __buf, size_t __buflen)); #endif int _EXFUN(symlink, (const char *__name1, const char *__name2)); #if __POSIX_VISIBLE >= 200809 || __BSD_VISIBLE || defined(__CYGWIN__) int _EXFUN(symlinkat, (const char *, int, const char *)); int _EXFUN(unlinkat, (int, const char *, int)); #endif #define F_OK 0 #define R_OK 4 #define W_OK 2 #define X_OK 1 # define SEEK_SET 0 # define SEEK_CUR 1 # define SEEK_END 2 #include #define STDIN_FILENO 0 /* standard input file descriptor */ #define STDOUT_FILENO 1 /* standard output file descriptor */ #define STDERR_FILENO 2 /* standard error file descriptor */ /* * sysconf values per IEEE Std 1003.1, 2008 Edition */ #define _SC_ARG_MAX 0 #define _SC_CHILD_MAX 1 #define _SC_CLK_TCK 2 #define _SC_NGROUPS_MAX 3 #define _SC_OPEN_MAX 4 #define _SC_JOB_CONTROL 5 #define _SC_SAVED_IDS 6 #define _SC_VERSION 7 #define _SC_PAGESIZE 8 #define _SC_PAGE_SIZE _SC_PAGESIZE /* These are non-POSIX values we accidentally introduced in 2000 without guarding them. Keeping them unguarded for backward compatibility. */ #define _SC_NPROCESSORS_CONF 9 #define _SC_NPROCESSORS_ONLN 10 #define _SC_PHYS_PAGES 11 #define _SC_AVPHYS_PAGES 12 /* End of non-POSIX values. */ #define _SC_MQ_OPEN_MAX 13 #define _SC_MQ_PRIO_MAX 14 #define _SC_RTSIG_MAX 15 #define _SC_SEM_NSEMS_MAX 16 #define _SC_SEM_VALUE_MAX 17 #define _SC_SIGQUEUE_MAX 18 #define _SC_TIMER_MAX 19 #define _SC_TZNAME_MAX 20 #define _SC_ASYNCHRONOUS_IO 21 #define _SC_FSYNC 22 #define _SC_MAPPED_FILES 23 #define _SC_MEMLOCK 24 #define _SC_MEMLOCK_RANGE 25 #define _SC_MEMORY_PROTECTION 26 #define _SC_MESSAGE_PASSING 27 #define _SC_PRIORITIZED_IO 28 #define _SC_REALTIME_SIGNALS 29 #define _SC_SEMAPHORES 30 #define _SC_SHARED_MEMORY_OBJECTS 31 #define _SC_SYNCHRONIZED_IO 32 #define _SC_TIMERS 33 #define _SC_AIO_LISTIO_MAX 34 #define _SC_AIO_MAX 35 #define _SC_AIO_PRIO_DELTA_MAX 36 #define _SC_DELAYTIMER_MAX 37 #define _SC_THREAD_KEYS_MAX 38 #define _SC_THREAD_STACK_MIN 39 #define _SC_THREAD_THREADS_MAX 40 #define _SC_TTY_NAME_MAX 41 #define _SC_THREADS 42 #define _SC_THREAD_ATTR_STACKADDR 43 #define _SC_THREAD_ATTR_STACKSIZE 44 #define _SC_THREAD_PRIORITY_SCHEDULING 45 #define _SC_THREAD_PRIO_INHERIT 46 /* _SC_THREAD_PRIO_PROTECT was _SC_THREAD_PRIO_CEILING in early drafts */ #define _SC_THREAD_PRIO_PROTECT 47 #define _SC_THREAD_PRIO_CEILING _SC_THREAD_PRIO_PROTECT #define _SC_THREAD_PROCESS_SHARED 48 #define _SC_THREAD_SAFE_FUNCTIONS 49 #define _SC_GETGR_R_SIZE_MAX 50 #define _SC_GETPW_R_SIZE_MAX 51 #define _SC_LOGIN_NAME_MAX 52 #define _SC_THREAD_DESTRUCTOR_ITERATIONS 53 #define _SC_ADVISORY_INFO 54 #define _SC_ATEXIT_MAX 55 #define _SC_BARRIERS 56 #define _SC_BC_BASE_MAX 57 #define _SC_BC_DIM_MAX 58 #define _SC_BC_SCALE_MAX 59 #define _SC_BC_STRING_MAX 60 #define _SC_CLOCK_SELECTION 61 #define _SC_COLL_WEIGHTS_MAX 62 #define _SC_CPUTIME 63 #define _SC_EXPR_NEST_MAX 64 #define _SC_HOST_NAME_MAX 65 #define _SC_IOV_MAX 66 #define _SC_IPV6 67 #define _SC_LINE_MAX 68 #define _SC_MONOTONIC_CLOCK 69 #define _SC_RAW_SOCKETS 70 #define _SC_READER_WRITER_LOCKS 71 #define _SC_REGEXP 72 #define _SC_RE_DUP_MAX 73 #define _SC_SHELL 74 #define _SC_SPAWN 75 #define _SC_SPIN_LOCKS 76 #define _SC_SPORADIC_SERVER 77 #define _SC_SS_REPL_MAX 78 #define _SC_SYMLOOP_MAX 79 #define _SC_THREAD_CPUTIME 80 #define _SC_THREAD_SPORADIC_SERVER 81 #define _SC_TIMEOUTS 82 #define _SC_TRACE 83 #define _SC_TRACE_EVENT_FILTER 84 #define _SC_TRACE_EVENT_NAME_MAX 85 #define _SC_TRACE_INHERIT 86 #define _SC_TRACE_LOG 87 #define _SC_TRACE_NAME_MAX 88 #define _SC_TRACE_SYS_MAX 89 #define _SC_TRACE_USER_EVENT_MAX 90 #define _SC_TYPED_MEMORY_OBJECTS 91 #define _SC_V7_ILP32_OFF32 92 #define _SC_V6_ILP32_OFF32 _SC_V7_ILP32_OFF32 #define _SC_XBS5_ILP32_OFF32 _SC_V7_ILP32_OFF32 #define _SC_V7_ILP32_OFFBIG 93 #define _SC_V6_ILP32_OFFBIG _SC_V7_ILP32_OFFBIG #define _SC_XBS5_ILP32_OFFBIG _SC_V7_ILP32_OFFBIG #define _SC_V7_LP64_OFF64 94 #define _SC_V6_LP64_OFF64 _SC_V7_LP64_OFF64 #define _SC_XBS5_LP64_OFF64 _SC_V7_LP64_OFF64 #define _SC_V7_LPBIG_OFFBIG 95 #define _SC_V6_LPBIG_OFFBIG _SC_V7_LPBIG_OFFBIG #define _SC_XBS5_LPBIG_OFFBIG _SC_V7_LPBIG_OFFBIG #define _SC_XOPEN_CRYPT 96 #define _SC_XOPEN_ENH_I18N 97 #define _SC_XOPEN_LEGACY 98 #define _SC_XOPEN_REALTIME 99 #define _SC_STREAM_MAX 100 #define _SC_PRIORITY_SCHEDULING 101 #define _SC_XOPEN_REALTIME_THREADS 102 #define _SC_XOPEN_SHM 103 #define _SC_XOPEN_STREAMS 104 #define _SC_XOPEN_UNIX 105 #define _SC_XOPEN_VERSION 106 #define _SC_2_CHAR_TERM 107 #define _SC_2_C_BIND 108 #define _SC_2_C_DEV 109 #define _SC_2_FORT_DEV 110 #define _SC_2_FORT_RUN 111 #define _SC_2_LOCALEDEF 112 #define _SC_2_PBS 113 #define _SC_2_PBS_ACCOUNTING 114 #define _SC_2_PBS_CHECKPOINT 115 #define _SC_2_PBS_LOCATE 116 #define _SC_2_PBS_MESSAGE 117 #define _SC_2_PBS_TRACK 118 #define _SC_2_SW_DEV 119 #define _SC_2_UPE 120 #define _SC_2_VERSION 121 #define _SC_THREAD_ROBUST_PRIO_INHERIT 122 #define _SC_THREAD_ROBUST_PRIO_PROTECT 123 #define _SC_XOPEN_UUCP 124 /* * pathconf values per IEEE Std 1003.1, 2008 Edition */ #define _PC_LINK_MAX 0 #define _PC_MAX_CANON 1 #define _PC_MAX_INPUT 2 #define _PC_NAME_MAX 3 #define _PC_PATH_MAX 4 #define _PC_PIPE_BUF 5 #define _PC_CHOWN_RESTRICTED 6 #define _PC_NO_TRUNC 7 #define _PC_VDISABLE 8 #define _PC_ASYNC_IO 9 #define _PC_PRIO_IO 10 #define _PC_SYNC_IO 11 #define _PC_FILESIZEBITS 12 #define _PC_2_SYMLINKS 13 #define _PC_SYMLINK_MAX 14 #define _PC_ALLOC_SIZE_MIN 15 #define _PC_REC_INCR_XFER_SIZE 16 #define _PC_REC_MAX_XFER_SIZE 17 #define _PC_REC_MIN_XFER_SIZE 18 #define _PC_REC_XFER_ALIGN 19 #define _PC_TIMESTAMP_RESOLUTION 20 #ifdef __CYGWIN__ /* Ask for POSIX permission bits support. */ #define _PC_POSIX_PERMISSIONS 90 /* Ask for full POSIX permission support including uid/gid settings. */ #define _PC_POSIX_SECURITY 91 #endif /* * confstr values per IEEE Std 1003.1, 2004 Edition */ #ifdef __CYGWIN__ /* Only defined on Cygwin for now. */ #define _CS_PATH 0 #define _CS_POSIX_V7_ILP32_OFF32_CFLAGS 1 #define _CS_POSIX_V6_ILP32_OFF32_CFLAGS _CS_POSIX_V7_ILP32_OFF32_CFLAGS #define _CS_XBS5_ILP32_OFF32_CFLAGS _CS_POSIX_V7_ILP32_OFF32_CFLAGS #define _CS_POSIX_V7_ILP32_OFF32_LDFLAGS 2 #define _CS_POSIX_V6_ILP32_OFF32_LDFLAGS _CS_POSIX_V7_ILP32_OFF32_LDFLAGS #define _CS_XBS5_ILP32_OFF32_LDFLAGS _CS_POSIX_V7_ILP32_OFF32_LDFLAGS #define _CS_POSIX_V7_ILP32_OFF32_LIBS 3 #define _CS_POSIX_V6_ILP32_OFF32_LIBS _CS_POSIX_V7_ILP32_OFF32_LIBS #define _CS_XBS5_ILP32_OFF32_LIBS _CS_POSIX_V7_ILP32_OFF32_LIBS #define _CS_XBS5_ILP32_OFF32_LINTFLAGS 4 #define _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS 5 #define _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS #define _CS_XBS5_ILP32_OFFBIG_CFLAGS _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS #define _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS 6 #define _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS #define _CS_XBS5_ILP32_OFFBIG_LDFLAGS _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS #define _CS_POSIX_V7_ILP32_OFFBIG_LIBS 7 #define _CS_POSIX_V6_ILP32_OFFBIG_LIBS _CS_POSIX_V7_ILP32_OFFBIG_LIBS #define _CS_XBS5_ILP32_OFFBIG_LIBS _CS_POSIX_V7_ILP32_OFFBIG_LIBS #define _CS_XBS5_ILP32_OFFBIG_LINTFLAGS 8 #define _CS_POSIX_V7_LP64_OFF64_CFLAGS 9 #define _CS_POSIX_V6_LP64_OFF64_CFLAGS _CS_POSIX_V7_LP64_OFF64_CFLAGS #define _CS_XBS5_LP64_OFF64_CFLAGS _CS_POSIX_V7_LP64_OFF64_CFLAGS #define _CS_POSIX_V7_LP64_OFF64_LDFLAGS 10 #define _CS_POSIX_V6_LP64_OFF64_LDFLAGS _CS_POSIX_V7_LP64_OFF64_LDFLAGS #define _CS_XBS5_LP64_OFF64_LDFLAGS _CS_POSIX_V7_LP64_OFF64_LDFLAGS #define _CS_POSIX_V7_LP64_OFF64_LIBS 11 #define _CS_POSIX_V6_LP64_OFF64_LIBS _CS_POSIX_V7_LP64_OFF64_LIBS #define _CS_XBS5_LP64_OFF64_LIBS _CS_POSIX_V7_LP64_OFF64_LIBS #define _CS_XBS5_LP64_OFF64_LINTFLAGS 12 #define _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS 13 #define _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS #define _CS_XBS5_LPBIG_OFFBIG_CFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS #define _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS 14 #define _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS #define _CS_XBS5_LPBIG_OFFBIG_LDFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS #define _CS_POSIX_V7_LPBIG_OFFBIG_LIBS 15 #define _CS_POSIX_V6_LPBIG_OFFBIG_LIBS _CS_POSIX_V7_LPBIG_OFFBIG_LIBS #define _CS_XBS5_LPBIG_OFFBIG_LIBS _CS_POSIX_V7_LPBIG_OFFBIG_LIBS #define _CS_XBS5_LPBIG_OFFBIG_LINTFLAGS 16 #define _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS 17 #define _CS_POSIX_V6_WIDTH_RESTRICTED_ENVS _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS #define _CS_XBS5_WIDTH_RESTRICTED_ENVS _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS #define _CS_POSIX_V7_THREADS_CFLAGS 18 #define _CS_POSIX_V7_THREADS_LDFLAGS 19 #define _CS_V7_ENV 20 #define _CS_V6_ENV _CS_V7_ENV #endif #ifdef __cplusplus } #endif #endif /* _SYS_UNISTD_H */ 0707010000005f000081a40000000000000000000000016181423d0000016b000000000000000000000000000000000000002500000000./usr/nvptx-none/include/sys/utime.h#ifndef _SYS_UTIME_H #define _SYS_UTIME_H /* This is a dummy file, not customized for any particular system. If there is a utime.h in libc/sys/SYSDIR/sys, it will override this one. */ #ifdef __cplusplus extern "C" { #endif struct utimbuf { time_t actime; time_t modtime; }; #ifdef __cplusplus }; #endif #endif /* _SYS_UTIME_H */ 07070100000060000081a40000000000000000000000016181423d000003df000000000000000000000000000000000000002400000000./usr/nvptx-none/include/sys/wait.h#ifndef _SYS_WAIT_H #define _SYS_WAIT_H #ifdef __cplusplus extern "C" { #endif #include #define WNOHANG 1 #define WUNTRACED 2 /* A status looks like: <2 bytes info> <2 bytes code> == 0, child has exited, info is the exit value == 1..7e, child has exited, info is the signal number. == 7f, child has stopped, info was the signal number. == 80, there was a core dump. */ #define WIFEXITED(w) (((w) & 0xff) == 0) #define WIFSIGNALED(w) (((w) & 0x7f) > 0 && (((w) & 0x7f) < 0x7f)) #define WIFSTOPPED(w) (((w) & 0xff) == 0x7f) #define WEXITSTATUS(w) (((w) >> 8) & 0xff) #define WTERMSIG(w) ((w) & 0x7f) #define WSTOPSIG WEXITSTATUS pid_t wait (int *); pid_t waitpid (pid_t, int *, int); #ifdef _COMPILING_NEWLIB pid_t _wait (int *); #endif /* Provide prototypes for most of the _ names that are provided in newlib for some compilers. */ pid_t _wait (int *); #ifdef __cplusplus }; #endif #endif 07070100000061000081a40000000000000000000000016181423c0000051d000000000000000000000000000000000000001f00000000./usr/nvptx-none/include/tar.h/* * tar.h */ #ifndef _TAR_H #define _TAR_H /* General definitions */ #define TMAGIC "ustar" /* ustar plus null byte. */ #define TMAGLEN 6 /* Length of the above. */ #define TVERSION "00" /* 00 without a null byte. */ #define TVERSLEN 2 /* Length of the above. */ /* Typeflag field definitions */ #define REGTYPE '0' /* Regular file. */ #define AREGTYPE '\0' /* Regular file. */ #define LNKTYPE '1' /* Link. */ #define SYMTYPE '2' /* Symbolic link. */ #define CHRTYPE '3' /* Character special. */ #define BLKTYPE '4' /* Block special. */ #define DIRTYPE '5' /* Directory. */ #define FIFOTYPE '6' /* FIFO special. */ #define CONTTYPE '7' /* Reserved. */ /* Mode field bit definitions (octal) */ #define TSUID 04000 /* Set UID on execution. */ #define TSGID 02000 /* Set GID on execution. */ #define TSVTX 01000 /* On directories, restricted deletion flag. */ #define TUREAD 00400 /* Read by owner. */ #define TUWRITE 00200 /* Write by owner. */ #define TUEXEC 00100 /* Execute/search by owner. */ #define TGREAD 00040 /* Read by group. */ #define TGWRITE 00020 /* Write by group. */ #define TGEXEC 00010 /* Execute/search by group. */ #define TOREAD 00004 /* Read by other. */ #define TOWRITE 00002 /* Write by other. */ #define TOEXEC 00001 /* Execute/search by other. */ #endif 07070100000062000081a40000000000000000000000016181423c0000005c000000000000000000000000000000000000002300000000./usr/nvptx-none/include/termios.h#ifdef __cplusplus extern "C" { #endif #include #ifdef __cplusplus } #endif 07070100000063000081a40000000000000000000000016181423c00001fa4000000000000000000000000000000000000002200000000./usr/nvptx-none/include/tgmath.h/* http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/tgmath.h.html */ /*- * Copyright (c) 2004 Stefan Farfeleder. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. * * $FreeBSD$ */ #ifndef _TGMATH_H_ #define _TGMATH_H_ #include #include #ifdef log2 #undef log2 #endif /* * This implementation of requires two implementation-dependent * macros to be defined: * __tg_impl_simple(x, y, z, fn, fnf, fnl, ...) * Invokes fnl() if the corresponding real type of x, y or z is long * double, fn() if it is double or any has an integer type, and fnf() * otherwise. * __tg_impl_full(x, y, z, fn, fnf, fnl, cfn, cfnf, cfnl, ...) * Invokes [c]fnl() if the corresponding real type of x, y or z is long * double, [c]fn() if it is double or any has an integer type, and * [c]fnf() otherwise. The function with the 'c' prefix is called if * any of x, y or z is a complex number. * Both macros call the chosen function with all additional arguments passed * to them, as given by __VA_ARGS__. * * Note that these macros cannot be implemented with C's ?: operator, * because the return type of the whole expression would incorrectly be long * double complex regardless of the argument types. */ /* requires GCC >= 3.1 */ #if !__GNUC_PREREQ (3, 1) #error " not implemented for this compiler" #endif #define __tg_type(__e, __t) \ __builtin_types_compatible_p(__typeof__(__e), __t) #define __tg_type3(__e1, __e2, __e3, __t) \ (__tg_type(__e1, __t) || __tg_type(__e2, __t) || \ __tg_type(__e3, __t)) #define __tg_type_corr(__e1, __e2, __e3, __t) \ (__tg_type3(__e1, __e2, __e3, __t) || \ __tg_type3(__e1, __e2, __e3, __t _Complex)) #define __tg_integer(__e1, __e2, __e3) \ (((__typeof__(__e1))1.5 == 1) || ((__typeof__(__e2))1.5 == 1) || \ ((__typeof__(__e3))1.5 == 1)) #define __tg_is_complex(__e1, __e2, __e3) \ (__tg_type3(__e1, __e2, __e3, float _Complex) || \ __tg_type3(__e1, __e2, __e3, double _Complex) || \ __tg_type3(__e1, __e2, __e3, long double _Complex) || \ __tg_type3(__e1, __e2, __e3, __typeof__(_Complex_I))) #ifdef _LDBL_EQ_DBL #define __tg_impl_simple(x, y, z, fn, fnf, fnl, ...) \ __builtin_choose_expr(__tg_type_corr(x, y, z, long double), \ fnl(__VA_ARGS__), __builtin_choose_expr( \ __tg_type_corr(x, y, z, double) || __tg_integer(x, y, z),\ fn(__VA_ARGS__), fnf(__VA_ARGS__))) #else #define __tg_impl_simple(__x, __y, __z, __fn, __fnf, __fnl, ...) \ (__tg_type_corr(__x, __y, __z, double) || __tg_integer(__x, __y, __z)) \ ? __fn(__VA_ARGS__) : __fnf(__VA_ARGS__) #endif #define __tg_impl_full(__x, __y, __z, __fn, __fnf, __fnl, __cfn, __cfnf, __cfnl, ...) \ __builtin_choose_expr(__tg_is_complex(__x, __y, __z), \ __tg_impl_simple(__x, __y, __z, __cfn, __cfnf, __cfnl, __VA_ARGS__), \ __tg_impl_simple(__x, __y, __z, __fn, __fnf, __fnl, __VA_ARGS__)) /* Macros to save lots of repetition below */ #define __tg_simple(__x, __fn) \ __tg_impl_simple(__x, __x, __x, __fn, __fn##f, __fn##l, __x) #define __tg_simple2(__x, __y, __fn) \ __tg_impl_simple(__x, __x, __y, __fn, __fn##f, __fn##l, __x, __y) #define __tg_simplev(__x, __fn, ...) \ __tg_impl_simple(__x, __x, __x, __fn, __fn##f, __fn##l, __VA_ARGS__) #define __tg_full(__x, __fn) \ __tg_impl_full(__x, __x, __x, __fn, __fn##f, __fn##l, c##__fn, c##__fn##f, c##__fn##l, __x) /* 7.22#4 -- These macros expand to real or complex functions, depending on * the type of their arguments. */ #define acos(__x) __tg_full(__x, acos) #define asin(__x) __tg_full(__x, asin) #define atan(__x) __tg_full(__x, atan) #define acosh(__x) __tg_full(__x, acosh) #define asinh(__x) __tg_full(__x, asinh) #define atanh(__x) __tg_full(__x, atanh) #define cos(__x) __tg_full(__x, cos) #define sin(__x) __tg_full(__x, sin) #define tan(__x) __tg_full(__x, tan) #define cosh(__x) __tg_full(__x, cosh) #define sinh(__x) __tg_full(__x, sinh) #define tanh(__x) __tg_full(__x, tanh) #define exp(__x) __tg_full(__x, exp) #define log(__x) __tg_full(__x, log) #define pow(__x, __y) __tg_impl_full(__x, __x, __y, pow, powf, powl, \ cpow, cpowf, cpowl, __x, __y) #define sqrt(__x) __tg_full(__x, sqrt) /* "The corresponding type-generic macro for fabs and cabs is fabs." */ #define fabs(__x) __tg_impl_full(__x, __x, __x, fabs, fabsf, fabsl, \ cabs, cabsf, cabsl, __x) /* 7.22#5 -- These macros are only defined for arguments with real type. */ #define atan2(__x, __y) __tg_simple2(__x, __y, atan2) #define cbrt(__x) __tg_simple(__x, cbrt) #define ceil(__x) __tg_simple(__x, ceil) #define copysign(__x, __y) __tg_simple2(__x, __y, copysign) #define erf(__x) __tg_simple(__x, erf) #define erfc(__x) __tg_simple(__x, erfc) #define exp2(__x) __tg_simple(__x, exp2) #define expm1(__x) __tg_simple(__x, expm1) #define fdim(__x, __y) __tg_simple2(__x, __y, fdim) #define floor(__x) __tg_simple(__x, floor) #define fma(__x, __y, __z) __tg_impl_simple(__x, __y, __z, fma, fmaf, fmal, \ __x, __y, __z) #define fmax(__x, __y) __tg_simple2(__x, __y, fmax) #define fmin(__x, __y) __tg_simple2(__x, __y, fmin) #define fmod(__x, __y) __tg_simple2(__x, __y, fmod) #define frexp(__x, __y) __tg_simplev(__x, frexp, __x, __y) #define hypot(__x, __y) __tg_simple2(__x, __y, hypot) #define ilogb(__x) __tg_simple(__x, ilogb) #define ldexp(__x, __y) __tg_simplev(__x, ldexp, __x, __y) #define lgamma(__x) __tg_simple(__x, lgamma) #define llrint(__x) __tg_simple(__x, llrint) #define llround(__x) __tg_simple(__x, llround) #define log10(__x) __tg_simple(__x, log10) #define log1p(__x) __tg_simple(__x, log1p) #define log2(__x) __tg_simple(__x, log2) #define logb(__x) __tg_simple(__x, logb) #define lrint(__x) __tg_simple(__x, lrint) #define lround(__x) __tg_simple(__x, lround) #define nearbyint(__x) __tg_simple(__x, nearbyint) #define nextafter(__x, __y) __tg_simple2(__x, __y, nextafter) /* not yet implemented even for _LDBL_EQ_DBL platforms #define nexttoward(__x, __y) __tg_simplev(__x, nexttoward, __x, __y) */ #define remainder(__x, __y) __tg_simple2(__x, __y, remainder) #define remquo(__x, __y, __z) __tg_impl_simple(__x, __x, __y, remquo, remquof, \ remquol, __x, __y, __z) #define rint(__x) __tg_simple(__x, rint) #define round(__x) __tg_simple(__x, round) #define scalbn(__x, __y) __tg_simplev(__x, scalbn, __x, __y) #define scalbln(__x, __y) __tg_simplev(__x, scalbln, __x, __y) #define tgamma(__x) __tg_simple(__x, tgamma) #define trunc(__x) __tg_simple(__x, trunc) /* 7.22#6 -- These macros always expand to complex functions. */ #define carg(__x) __tg_simple(__x, carg) #define cimag(__x) __tg_simple(__x, cimag) #define conj(__x) __tg_simple(__x, conj) #define cproj(__x) __tg_simple(__x, cproj) #define creal(__x) __tg_simple(__x, creal) #endif /* !_TGMATH_H_ */ 07070100000064000081a40000000000000000000000016181423c00001c23000000000000000000000000000000000000002000000000./usr/nvptx-none/include/time.h/* * time.h * * Struct and function declarations for dealing with time. */ #ifndef _TIME_H_ #define _TIME_H_ #include "_ansi.h" #include #define __need_size_t #define __need_NULL #include /* Get _CLOCKS_PER_SEC_ */ #include #ifndef _CLOCKS_PER_SEC_ #define _CLOCKS_PER_SEC_ 1000 #endif #define CLOCKS_PER_SEC _CLOCKS_PER_SEC_ #define CLK_TCK CLOCKS_PER_SEC #include _BEGIN_STD_C struct tm { int tm_sec; int tm_min; int tm_hour; int tm_mday; int tm_mon; int tm_year; int tm_wday; int tm_yday; int tm_isdst; #ifdef __TM_GMTOFF long __TM_GMTOFF; #endif #ifdef __TM_ZONE const char *__TM_ZONE; #endif }; clock_t _EXFUN(clock, (void)); double _EXFUN(difftime, (time_t _time2, time_t _time1)); time_t _EXFUN(mktime, (struct tm *_timeptr)); time_t _EXFUN(time, (time_t *_timer)); #ifndef _REENT_ONLY char *_EXFUN(asctime, (const struct tm *_tblock)); char *_EXFUN(ctime, (const time_t *_time)); struct tm *_EXFUN(gmtime, (const time_t *_timer)); struct tm *_EXFUN(localtime,(const time_t *_timer)); #endif size_t _EXFUN(strftime, (char *__restrict _s, size_t _maxsize, const char *__restrict _fmt, const struct tm *__restrict _t)); char *_EXFUN(asctime_r, (const struct tm *__restrict, char *__restrict)); char *_EXFUN(ctime_r, (const time_t *, char *)); struct tm *_EXFUN(gmtime_r, (const time_t *__restrict, struct tm *__restrict)); struct tm *_EXFUN(localtime_r, (const time_t *__restrict, struct tm *__restrict)); _END_STD_C #ifdef __cplusplus extern "C" { #endif #ifndef __STRICT_ANSI__ char *_EXFUN(strptime, (const char *__restrict, const char *__restrict, struct tm *__restrict)); _VOID _EXFUN(tzset, (_VOID)); _VOID _EXFUN(_tzset_r, (struct _reent *)); typedef struct __tzrule_struct { char ch; int m; int n; int d; int s; time_t change; long offset; /* Match type of _timezone. */ } __tzrule_type; typedef struct __tzinfo_struct { int __tznorth; int __tzyear; __tzrule_type __tzrule[2]; } __tzinfo_type; __tzinfo_type *_EXFUN (__gettzinfo, (_VOID)); /* getdate functions */ #ifdef HAVE_GETDATE #ifndef _REENT_ONLY #define getdate_err (*__getdate_err()) int *_EXFUN(__getdate_err,(_VOID)); struct tm * _EXFUN(getdate, (const char *)); /* getdate_err is set to one of the following values to indicate the error. 1 the DATEMSK environment variable is null or undefined, 2 the template file cannot be opened for reading, 3 failed to get file status information, 4 the template file is not a regular file, 5 an error is encountered while reading the template file, 6 memory allication failed (not enough memory available), 7 there is no line in the template that matches the input, 8 invalid input specification */ #endif /* !_REENT_ONLY */ /* getdate_r returns the error code as above */ int _EXFUN(getdate_r, (const char *, struct tm *)); #endif /* HAVE_GETDATE */ /* defines for the opengroup specifications Derived from Issue 1 of the SVID. */ extern __IMPORT long _timezone; extern __IMPORT int _daylight; extern __IMPORT char *_tzname[2]; /* POSIX defines the external tzname being defined in time.h */ #ifndef tzname #define tzname _tzname #endif #endif /* !__STRICT_ANSI__ */ #ifdef __cplusplus } #endif #include #ifdef __CYGWIN__ #include #endif /*__CYGWIN__*/ #if defined(_POSIX_TIMERS) #include #ifdef __cplusplus extern "C" { #endif /* Clocks, P1003.1b-1993, p. 263 */ int _EXFUN(clock_settime, (clockid_t clock_id, const struct timespec *tp)); int _EXFUN(clock_gettime, (clockid_t clock_id, struct timespec *tp)); int _EXFUN(clock_getres, (clockid_t clock_id, struct timespec *res)); /* Create a Per-Process Timer, P1003.1b-1993, p. 264 */ int _EXFUN(timer_create, (clockid_t clock_id, struct sigevent *__restrict evp, timer_t *__restrict timerid)); /* Delete a Per_process Timer, P1003.1b-1993, p. 266 */ int _EXFUN(timer_delete, (timer_t timerid)); /* Per-Process Timers, P1003.1b-1993, p. 267 */ int _EXFUN(timer_settime, (timer_t timerid, int flags, const struct itimerspec *__restrict value, struct itimerspec *__restrict ovalue)); int _EXFUN(timer_gettime, (timer_t timerid, struct itimerspec *value)); int _EXFUN(timer_getoverrun, (timer_t timerid)); /* High Resolution Sleep, P1003.1b-1993, p. 269 */ int _EXFUN(nanosleep, (const struct timespec *rqtp, struct timespec *rmtp)); #ifdef __cplusplus } #endif #endif /* _POSIX_TIMERS */ #if defined(_POSIX_CLOCK_SELECTION) #ifdef __cplusplus extern "C" { #endif int _EXFUN(clock_nanosleep, (clockid_t clock_id, int flags, const struct timespec *rqtp, struct timespec *rmtp)); #ifdef __cplusplus } #endif #endif /* _POSIX_CLOCK_SELECTION */ #ifdef __cplusplus extern "C" { #endif /* CPU-time Clock Attributes, P1003.4b/D8, p. 54 */ /* values for the clock enable attribute */ #define CLOCK_ENABLED 1 /* clock is enabled, i.e. counting execution time */ #define CLOCK_DISABLED 0 /* clock is disabled */ /* values for the pthread cputime_clock_allowed attribute */ #define CLOCK_ALLOWED 1 /* If a thread is created with this value a */ /* CPU-time clock attached to that thread */ /* shall be accessible. */ #define CLOCK_DISALLOWED 0 /* If a thread is created with this value, the */ /* thread shall not have a CPU-time clock */ /* accessible. */ /* Manifest Constants, P1003.1b-1993, p. 262 */ #define CLOCK_REALTIME (clockid_t)1 /* Flag indicating time is "absolute" with respect to the clock associated with a time. */ #define TIMER_ABSTIME 4 /* Manifest Constants, P1003.4b/D8, p. 55 */ #if defined(_POSIX_CPUTIME) /* When used in a clock or timer function call, this is interpreted as the identifier of the CPU_time clock associated with the PROCESS making the function call. */ #define CLOCK_PROCESS_CPUTIME_ID (clockid_t)2 #endif #if defined(_POSIX_THREAD_CPUTIME) /* When used in a clock or timer function call, this is interpreted as the identifier of the CPU_time clock associated with the THREAD making the function call. */ #define CLOCK_THREAD_CPUTIME_ID (clockid_t)3 #endif #if defined(_POSIX_MONOTONIC_CLOCK) /* The identifier for the system-wide monotonic clock, which is defined * as a clock whose value cannot be set via clock_settime() and which * cannot have backward clock jumps. */ #define CLOCK_MONOTONIC (clockid_t)4 #endif #if defined(_POSIX_CPUTIME) /* Accessing a Process CPU-time CLock, P1003.4b/D8, p. 55 */ int _EXFUN(clock_getcpuclockid, (pid_t pid, clockid_t *clock_id)); #endif /* _POSIX_CPUTIME */ #if defined(_POSIX_CPUTIME) || defined(_POSIX_THREAD_CPUTIME) /* CPU-time Clock Attribute Access, P1003.4b/D8, p. 56 */ int _EXFUN(clock_setenable_attr, (clockid_t clock_id, int attr)); int _EXFUN(clock_getenable_attr, (clockid_t clock_id, int *attr)); #endif /* _POSIX_CPUTIME or _POSIX_THREAD_CPUTIME */ #ifdef __cplusplus } #endif #endif /* _TIME_H_ */ 07070100000065000081a40000000000000000000000016181423c00000882000000000000000000000000000000000000002200000000./usr/nvptx-none/include/unctrl.h/* From curses.h. */ /* * Copyright (c) 1981, 1993 * The Regents of the University of California. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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. */ #ifndef _UNCTRL_H_ #define _UNCTRL_H_ #include <_ansi.h> #define unctrl(c) __unctrl[(c) & 0xff] #define unctrllen(ch) __unctrllen[(ch) & 0xff] extern __IMPORT _CONST char * _CONST __unctrl[256]; /* Control strings. */ extern __IMPORT _CONST char __unctrllen[256]; /* Control strings length. */ #endif /* _UNCTRL_H_ */ 07070100000066000081a40000000000000000000000016181423c00000059000000000000000000000000000000000000002200000000./usr/nvptx-none/include/unistd.h#ifndef _UNISTD_H_ #define _UNISTD_H_ # include #endif /* _UNISTD_H_ */ 07070100000067000081a40000000000000000000000016181423c000000b9000000000000000000000000000000000000002100000000./usr/nvptx-none/include/utime.h#ifdef __cplusplus extern "C" { #endif #include <_ansi.h> /* The utime function is defined in libc/sys//sys if it exists. */ #include #ifdef __cplusplus } #endif 07070100000068000081a40000000000000000000000016181423c0000005a000000000000000000000000000000000000002000000000./usr/nvptx-none/include/utmp.h#ifdef __cplusplus extern "C" { #endif #include #ifdef __cplusplus } #endif 07070100000069000081a40000000000000000000000016181423c000024ae000000000000000000000000000000000000002100000000./usr/nvptx-none/include/wchar.h#ifndef _WCHAR_H_ #define _WCHAR_H_ #include <_ansi.h> #include #define __need_size_t #define __need_wchar_t #define __need_wint_t #define __need_NULL #include #define __need___va_list #include /* For _mbstate_t definition. */ #include /* For __STDC_ISO_10646__ */ #include #ifndef WEOF # define WEOF ((wint_t)-1) #endif /* This must match definition in */ #ifndef WCHAR_MIN #ifdef __WCHAR_MIN__ #define WCHAR_MIN __WCHAR_MIN__ #elif defined(__WCHAR_UNSIGNED__) || (L'\0' - 1 > 0) #define WCHAR_MIN (0 + L'\0') #else #define WCHAR_MIN (-0x7fffffff - 1 + L'\0') #endif #endif /* This must match definition in */ #ifndef WCHAR_MAX #ifdef __WCHAR_MAX__ #define WCHAR_MAX __WCHAR_MAX__ #elif defined(__WCHAR_UNSIGNED__) || (L'\0' - 1 > 0) #define WCHAR_MAX (0xffffffffu + L'\0') #else #define WCHAR_MAX (0x7fffffff + L'\0') #endif #endif _BEGIN_STD_C /* As in stdio.h, defines __FILE. */ typedef __FILE FILE; /* As required by POSIX.1-2008, declare tm as incomplete type. The actual definition is in time.h. */ struct tm; #ifndef _MBSTATE_T #define _MBSTATE_T typedef _mbstate_t mbstate_t; #endif /* _MBSTATE_T */ wint_t _EXFUN(btowc, (int)); int _EXFUN(wctob, (wint_t)); size_t _EXFUN(mbrlen, (const char *__restrict, size_t, mbstate_t *__restrict)); size_t _EXFUN(mbrtowc, (wchar_t *__restrict, const char *__restrict, size_t, mbstate_t *__restrict)); size_t _EXFUN(_mbrtowc_r, (struct _reent *, wchar_t * , const char * , size_t, mbstate_t *)); int _EXFUN(mbsinit, (const mbstate_t *)); size_t _EXFUN(mbsnrtowcs, (wchar_t *__restrict, const char **__restrict, size_t, size_t, mbstate_t *__restrict)); size_t _EXFUN(_mbsnrtowcs_r, (struct _reent *, wchar_t * , const char ** , size_t, size_t, mbstate_t *)); size_t _EXFUN(mbsrtowcs, (wchar_t *__restrict, const char **__restrict, size_t, mbstate_t *__restrict)); size_t _EXFUN(_mbsrtowcs_r, (struct _reent *, wchar_t * , const char ** , size_t, mbstate_t *)); size_t _EXFUN(wcrtomb, (char *__restrict, wchar_t, mbstate_t *__restrict)); size_t _EXFUN(_wcrtomb_r, (struct _reent *, char * , wchar_t, mbstate_t *)); size_t _EXFUN(wcsnrtombs, (char *__restrict, const wchar_t **__restrict, size_t, size_t, mbstate_t *__restrict)); size_t _EXFUN(_wcsnrtombs_r, (struct _reent *, char * , const wchar_t ** , size_t, size_t, mbstate_t *)); size_t _EXFUN(wcsrtombs, (char *__restrict, const wchar_t **__restrict, size_t, mbstate_t *__restrict)); size_t _EXFUN(_wcsrtombs_r, (struct _reent *, char * , const wchar_t ** , size_t, mbstate_t *)); int _EXFUN(wcscasecmp, (const wchar_t *, const wchar_t *)); wchar_t *_EXFUN(wcscat, (wchar_t *__restrict, const wchar_t *__restrict)); wchar_t *_EXFUN(wcschr, (const wchar_t *, wchar_t)); int _EXFUN(wcscmp, (const wchar_t *, const wchar_t *)); int _EXFUN(wcscoll, (const wchar_t *, const wchar_t *)); wchar_t *_EXFUN(wcscpy, (wchar_t *__restrict, const wchar_t *__restrict)); wchar_t *_EXFUN(wcpcpy, (wchar_t *__restrict, const wchar_t *__restrict)); wchar_t *_EXFUN(wcsdup, (const wchar_t *)); wchar_t *_EXFUN(_wcsdup_r, (struct _reent *, const wchar_t * )); size_t _EXFUN(wcscspn, (const wchar_t *, const wchar_t *)); size_t _EXFUN(wcsftime, (wchar_t *__restrict, size_t, const wchar_t *__restrict, const struct tm *__restrict)); size_t _EXFUN(wcslcat, (wchar_t *, const wchar_t *, size_t)); size_t _EXFUN(wcslcpy, (wchar_t *, const wchar_t *, size_t)); size_t _EXFUN(wcslen, (const wchar_t *)); int _EXFUN(wcsncasecmp, (const wchar_t *, const wchar_t *, size_t)); wchar_t *_EXFUN(wcsncat, (wchar_t *__restrict, const wchar_t *__restrict, size_t)); int _EXFUN(wcsncmp, (const wchar_t *, const wchar_t *, size_t)); wchar_t *_EXFUN(wcsncpy, (wchar_t *__restrict, const wchar_t *__restrict, size_t)); wchar_t *_EXFUN(wcpncpy, (wchar_t *__restrict, const wchar_t *__restrict, size_t)); size_t _EXFUN(wcsnlen, (const wchar_t *, size_t)); wchar_t *_EXFUN(wcspbrk, (const wchar_t *, const wchar_t *)); wchar_t *_EXFUN(wcsrchr, (const wchar_t *, wchar_t)); size_t _EXFUN(wcsspn, (const wchar_t *, const wchar_t *)); wchar_t *_EXFUN(wcsstr, (const wchar_t *__restrict, const wchar_t *__restrict)); wchar_t *_EXFUN(wcstok, (wchar_t *__restrict, const wchar_t *__restrict, wchar_t **__restrict)); double _EXFUN(wcstod, (const wchar_t *__restrict, wchar_t **__restrict)); double _EXFUN(_wcstod_r, (struct _reent *, const wchar_t *, wchar_t **)); float _EXFUN(wcstof, (const wchar_t *__restrict, wchar_t **__restrict)); float _EXFUN(_wcstof_r, (struct _reent *, const wchar_t *, wchar_t **)); int _EXFUN(wcswidth, (const wchar_t *, size_t)); size_t _EXFUN(wcsxfrm, (wchar_t *__restrict, const wchar_t *__restrict, size_t)); int _EXFUN(wcwidth, (const wchar_t)); wchar_t *_EXFUN(wmemchr, (const wchar_t *, wchar_t, size_t)); int _EXFUN(wmemcmp, (const wchar_t *, const wchar_t *, size_t)); wchar_t *_EXFUN(wmemcpy, (wchar_t *__restrict, const wchar_t *__restrict, size_t)); wchar_t *_EXFUN(wmemmove, (wchar_t *, const wchar_t *, size_t)); wchar_t *_EXFUN(wmemset, (wchar_t *, wchar_t, size_t)); long _EXFUN(wcstol, (const wchar_t *__restrict, wchar_t **__restrict, int)); long long _EXFUN(wcstoll, (const wchar_t *__restrict, wchar_t **__restrict, int)); unsigned long _EXFUN(wcstoul, (const wchar_t *__restrict, wchar_t **__restrict, int)); unsigned long long _EXFUN(wcstoull, (const wchar_t *__restrict, wchar_t **__restrict, int)); long _EXFUN(_wcstol_r, (struct _reent *, const wchar_t *, wchar_t **, int)); long long _EXFUN(_wcstoll_r, (struct _reent *, const wchar_t *, wchar_t **, int)); unsigned long _EXFUN(_wcstoul_r, (struct _reent *, const wchar_t *, wchar_t **, int)); unsigned long long _EXFUN(_wcstoull_r, (struct _reent *, const wchar_t *, wchar_t **, int)); /* On platforms where long double equals double. */ #ifdef _LDBL_EQ_DBL long double _EXFUN(wcstold, (const wchar_t *, wchar_t **)); #endif /* _LDBL_EQ_DBL */ wint_t _EXFUN(fgetwc, (__FILE *)); wchar_t *_EXFUN(fgetws, (wchar_t *__restrict, int, __FILE *__restrict)); wint_t _EXFUN(fputwc, (wchar_t, __FILE *)); int _EXFUN(fputws, (const wchar_t *__restrict, __FILE *__restrict)); int _EXFUN (fwide, (__FILE *, int)); wint_t _EXFUN (getwc, (__FILE *)); wint_t _EXFUN (getwchar, (void)); wint_t _EXFUN(putwc, (wchar_t, __FILE *)); wint_t _EXFUN(putwchar, (wchar_t)); wint_t _EXFUN (ungetwc, (wint_t wc, __FILE *)); wint_t _EXFUN(_fgetwc_r, (struct _reent *, __FILE *)); wchar_t *_EXFUN(_fgetws_r, (struct _reent *, wchar_t *, int, __FILE *)); wint_t _EXFUN(_fputwc_r, (struct _reent *, wchar_t, __FILE *)); int _EXFUN(_fputws_r, (struct _reent *, const wchar_t *, __FILE *)); int _EXFUN (_fwide_r, (struct _reent *, __FILE *, int)); wint_t _EXFUN (_getwc_r, (struct _reent *, __FILE *)); wint_t _EXFUN (_getwchar_r, (struct _reent *ptr)); wint_t _EXFUN(_putwc_r, (struct _reent *, wchar_t, __FILE *)); wint_t _EXFUN(_putwchar_r, (struct _reent *, wchar_t)); wint_t _EXFUN (_ungetwc_r, (struct _reent *, wint_t wc, __FILE *)); __FILE *_EXFUN (open_wmemstream, (wchar_t **, size_t *)); __FILE *_EXFUN (_open_wmemstream_r, (struct _reent *, wchar_t **, size_t *)); #ifndef __VALIST #ifdef __GNUC__ #define __VALIST __gnuc_va_list #else #define __VALIST char* #endif #endif int _EXFUN(fwprintf, (__FILE *__restrict, const wchar_t *__restrict, ...)); int _EXFUN(swprintf, (wchar_t *__restrict, size_t, const wchar_t *__restrict, ...)); int _EXFUN(vfwprintf, (__FILE *__restrict, const wchar_t *__restrict, __VALIST)); int _EXFUN(vswprintf, (wchar_t *__restrict, size_t, const wchar_t *__restrict, __VALIST)); int _EXFUN(vwprintf, (const wchar_t *__restrict, __VALIST)); int _EXFUN(wprintf, (const wchar_t *__restrict, ...)); int _EXFUN(_fwprintf_r, (struct _reent *, __FILE *, const wchar_t *, ...)); int _EXFUN(_swprintf_r, (struct _reent *, wchar_t *, size_t, const wchar_t *, ...)); int _EXFUN(_vfwprintf_r, (struct _reent *, __FILE *, const wchar_t *, __VALIST)); int _EXFUN(_vswprintf_r, (struct _reent *, wchar_t *, size_t, const wchar_t *, __VALIST)); int _EXFUN(_vwprintf_r, (struct _reent *, const wchar_t *, __VALIST)); int _EXFUN(_wprintf_r, (struct _reent *, const wchar_t *, ...)); int _EXFUN(fwscanf, (__FILE *__restrict, const wchar_t *__restrict, ...)); int _EXFUN(swscanf, (const wchar_t *__restrict, const wchar_t *__restrict, ...)); int _EXFUN(vfwscanf, (__FILE *__restrict, const wchar_t *__restrict, __VALIST)); int _EXFUN(vswscanf, (const wchar_t *__restrict, const wchar_t *__restrict, __VALIST)); int _EXFUN(vwscanf, (const wchar_t *__restrict, __VALIST)); int _EXFUN(wscanf, (const wchar_t *__restrict, ...)); int _EXFUN(_fwscanf_r, (struct _reent *, __FILE *, const wchar_t *, ...)); int _EXFUN(_swscanf_r, (struct _reent *, const wchar_t *, const wchar_t *, ...)); int _EXFUN(_vfwscanf_r, (struct _reent *, __FILE *, const wchar_t *, __VALIST)); int _EXFUN(_vswscanf_r, (struct _reent *, const wchar_t *, const wchar_t *, __VALIST)); int _EXFUN(_vwscanf_r, (struct _reent *, const wchar_t *, __VALIST)); int _EXFUN(_wscanf_r, (struct _reent *, const wchar_t *, ...)); #define getwc(fp) fgetwc(fp) #define putwc(wc,fp) fputwc((wc), (fp)) #define getwchar() fgetwc(_REENT->_stdin) #define putwchar(wc) fputwc((wc), _REENT->_stdout) _END_STD_C #endif /* _WCHAR_H_ */ 0707010000006a000081a40000000000000000000000016181423c000003dc000000000000000000000000000000000000002200000000./usr/nvptx-none/include/wctype.h#ifndef _WCTYPE_H_ #define _WCTYPE_H_ #include <_ansi.h> #include #define __need_wint_t #include #ifndef WEOF # define WEOF ((wint_t)-1) #endif _BEGIN_STD_C #ifndef _WCTYPE_T #define _WCTYPE_T typedef int wctype_t; #endif #ifndef _WCTRANS_T #define _WCTRANS_T typedef int wctrans_t; #endif int _EXFUN(iswalpha, (wint_t)); int _EXFUN(iswalnum, (wint_t)); int _EXFUN(iswblank, (wint_t)); int _EXFUN(iswcntrl, (wint_t)); int _EXFUN(iswctype, (wint_t, wctype_t)); int _EXFUN(iswdigit, (wint_t)); int _EXFUN(iswgraph, (wint_t)); int _EXFUN(iswlower, (wint_t)); int _EXFUN(iswprint, (wint_t)); int _EXFUN(iswpunct, (wint_t)); int _EXFUN(iswspace, (wint_t)); int _EXFUN(iswupper, (wint_t)); int _EXFUN(iswxdigit, (wint_t)); wint_t _EXFUN(towctrans, (wint_t, wctrans_t)); wint_t _EXFUN(towupper, (wint_t)); wint_t _EXFUN(towlower, (wint_t)); wctrans_t _EXFUN(wctrans, (const char *)); wctype_t _EXFUN(wctype, (const char *)); _END_STD_C #endif /* _WCTYPE_H_ */ 0707010000006b000081a40000000000000000000000016181423c000005f6000000000000000000000000000000000000002300000000./usr/nvptx-none/include/wordexp.h/* Copyright (C) 2002, 2010 by Red Hat, Incorporated. All rights reserved. * * Permission to use, copy, modify, and distribute this software * is freely granted, provided that this notice is preserved. */ #ifndef _WORDEXP_H_ #define _WORDEXP_H_ #include #ifdef __cplusplus extern "C" { #endif struct _wordexp_t { size_t we_wordc; /* Count of words matched by words. */ char **we_wordv; /* Pointer to list of expanded words. */ size_t we_offs; /* Slots to reserve at the beginning of we_wordv. */ }; typedef struct _wordexp_t wordexp_t; #define WRDE_DOOFFS 0x0001 /* Use we_offs. */ #define WRDE_APPEND 0x0002 /* Append to output from previous call. */ #define WRDE_NOCMD 0x0004 /* Don't perform command substitution. */ #define WRDE_REUSE 0x0008 /* pwordexp points to a wordexp_t struct returned from a previous successful call to wordexp. */ #define WRDE_SHOWERR 0x0010 /* Print error messages to stderr. */ #define WRDE_UNDEF 0x0020 /* Report attempt to expand undefined shell variable. */ enum { WRDE_SUCCESS, WRDE_NOSPACE, WRDE_BADCHAR, WRDE_BADVAL, WRDE_CMDSUB, WRDE_SYNTAX, WRDE_NOSYS }; /* Note: This implementation of wordexp requires a version of bash that supports the --wordexp and --protected arguments to be present on the system. It does not support the WRDE_UNDEF flag. */ int wordexp(const char *__restrict, wordexp_t *__restrict, int); void wordfree(wordexp_t *); #ifdef __cplusplus } #endif #endif /* _WORDEXP_H_ */ 0707010000006c000041ed0000000000000000000000016181424300000000000000000000000000000000000000000000001500000000./usr/nvptx-none/lib0707010000006f000081a400000000000000000000000161814242001215c6000000000000000000000000000000000000001c00000000./usr/nvptx-none/lib/libm.a! // 1760 ` lib_a-cephes_subr.o/ lib_a-cephes_subrf.o/ lib_a-copysignl.o/ lib_a-e_rem_pio2.o/ lib_a-e_remainder.o/ lib_a-ef_acosh.o/ lib_a-ef_atan2.o/ lib_a-ef_atanh.o/ lib_a-ef_hypot.o/ lib_a-ef_log10.o/ lib_a-ef_rem_pio2.o/ lib_a-ef_remainder.o/ lib_a-ef_scalb.o/ lib_a-er_gamma.o/ lib_a-er_lgamma.o/ lib_a-erf_gamma.o/ lib_a-erf_lgamma.o/ lib_a-k_rem_pio2.o/ lib_a-k_standard.o/ lib_a-kf_rem_pio2.o/ lib_a-llroundl.o/ lib_a-nearbyintl.o/ lib_a-nextafterl.o/ lib_a-remainderl.o/ lib_a-s_copysign.o/ lib_a-s_finite.o/ lib_a-s_fpclassify.o/ lib_a-s_infconst.o/ lib_a-s_infinity.o/ lib_a-s_isinfd.o/ lib_a-s_isnand.o/ lib_a-s_lib_ver.o/ lib_a-s_llrint.o/ lib_a-s_llround.o/ lib_a-s_lround.o/ lib_a-s_matherr.o/ lib_a-s_nearbyint.o/ lib_a-s_nextafter.o/ lib_a-s_remquo.o/ lib_a-s_scalbln.o/ lib_a-s_scalbn.o/ lib_a-s_signbit.o/ lib_a-s_signif.o/ lib_a-scalblnl.o/ lib_a-sf_asinh.o/ lib_a-sf_copysign.o/ lib_a-sf_exp10.o/ lib_a-sf_expm1.o/ lib_a-sf_finite.o/ lib_a-sf_floor.o/ lib_a-sf_fpclassify.o/ lib_a-sf_frexp.o/ lib_a-sf_ilogb.o/ lib_a-sf_infinity.o/ lib_a-sf_isinf.o/ lib_a-sf_isinff.o/ lib_a-sf_isnan.o/ lib_a-sf_isnanf.o/ lib_a-sf_ldexp.o/ lib_a-sf_llrint.o/ lib_a-sf_llround.o/ lib_a-sf_log1p.o/ lib_a-sf_lrint.o/ lib_a-sf_lround.o/ lib_a-sf_nearbyint.o/ lib_a-sf_nextafter.o/ lib_a-sf_pow10.o/ lib_a-sf_remquo.o/ lib_a-sf_round.o/ lib_a-sf_scalbln.o/ lib_a-sf_scalbn.o/ lib_a-sf_signif.o/ lib_a-sf_trunc.o/ lib_a-w_lgamma.o/ lib_a-w_remainder.o/ lib_a-w_sincos.o/ lib_a-w_tgamma.o/ lib_a-wf_acosh.o/ lib_a-wf_atan2.o/ lib_a-wf_atanh.o/ lib_a-wf_gamma.o/ lib_a-wf_hypot.o/ lib_a-wf_lgamma.o/ lib_a-wf_log10.o/ lib_a-wf_remainder.o/ lib_a-wf_scalb.o/ lib_a-wf_sincos.o/ lib_a-wf_tgamma.o/ lib_a-wr_gamma.o/ lib_a-wr_lgamma.o/ lib_a-wrf_gamma.o/ lib_a-wrf_lgamma.o/ lib_a-acoshl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: acoshl .visible .func (.param .f64 %value_out) acoshl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/acoshl.c" // BEGIN GLOBAL FUNCTION DECL: acosh .extern .func (.param .f64 %value_out) acosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: acoshl .visible .func (.param .f64 %value_out) acoshl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),acosh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-acosl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: acosl .visible .func (.param .f64 %value_out) acosl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/acosl.c" // BEGIN GLOBAL FUNCTION DECL: acos .extern .func (.param .f64 %value_out) acos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: acosl .visible .func (.param .f64 %value_out) acosl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),acos,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-asinhl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinhl .visible .func (.param .f64 %value_out) asinhl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/asinhl.c" // BEGIN GLOBAL FUNCTION DECL: asinh .extern .func (.param .f64 %value_out) asinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinhl .visible .func (.param .f64 %value_out) asinhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),asinh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-asinl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinl .visible .func (.param .f64 %value_out) asinl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/asinl.c" // BEGIN GLOBAL FUNCTION DECL: asin .extern .func (.param .f64 %value_out) asin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinl .visible .func (.param .f64 %value_out) asinl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),asin,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-atan2l.o/ 0 0 0 644 1007 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan2l .visible .func (.param .f64 %value_out) atan2l (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/atan2l.c" // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atan2l .visible .func (.param .f64 %value_out) atan2l (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-atanhl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atanhl .visible .func (.param .f64 %value_out) atanhl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/atanhl.c" // BEGIN GLOBAL FUNCTION DECL: atanh .extern .func (.param .f64 %value_out) atanh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: atanhl .visible .func (.param .f64 %value_out) atanhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),atanh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-atanl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atanl .visible .func (.param .f64 %value_out) atanl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/atanl.c" // BEGIN GLOBAL FUNCTION DECL: atan .extern .func (.param .f64 %value_out) atan (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: atanl .visible .func (.param .f64 %value_out) atanl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),atan,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-cabs.o/ 0 0 0 644 1706 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cabs .visible .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/complex/cabs.c" // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: hypot .extern .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cabs .visible .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r29; .reg .f64 %r32; .reg .f64 %r35; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 52 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r29,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r32,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; call (%value_in),hypot,(%out_arg1,%out_arg2); ld.param.f64 %r35,[%value_in]; } .loc 1 53 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-cabsf.o/ 0 0 0 644 1720 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cabsf .visible .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/complex/cabsf.c" // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: hypotf .extern .func (.param .f32 %value_out) hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cabsf .visible .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r29; .reg .f32 %r32; .reg .f32 %r35; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 18 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r29,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r32,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r29; call (%value_in),hypotf,(%out_arg1,%out_arg2); ld.param.f32 %r35,[%value_in]; } .loc 1 19 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } lib_a-cacos.o/ 0 0 0 644 2220 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacos .visible .func cacos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cacos.c" // BEGIN GLOBAL FUNCTION DECL: casin .extern .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cacos .visible .func cacos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .f64 %r25; .reg .u64 %r30; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r38; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; mov.u64 %r30,%ar0; mov.f64 %r31,%ar1; mov.f64 %r32,%ar2; .loc 1 94 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r31; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r32; call casin,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r24,[%frame]; ld.f64 %r25,[%frame+8]; .loc 1 95 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r25; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r25; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } .loc 1 95 0 mov.f64 %r44,0d3ff921fb54442d18; sub.f64 %r43,%r44,%r38; .loc 1 96 0 fma.rn.f64 %r45,%r41,0d8000000000000000,%r43; .loc 1 98 0 st.f64 [%r30],%r45; .loc 1 96 0 mov.f64 %r47,0d0000000000000000; sub.f64 %r46,%r47,%r41; .loc 1 98 0 st.f64 [%r30+8],%r46; .loc 1 99 0 ret; } lib_a-cacosf.o/ 0 0 0 644 2103 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacosf .visible .func cacosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cacosf.c" // BEGIN GLOBAL FUNCTION DECL: casinf .extern .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cacosf .visible .func cacosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r26; .reg .f32 %r27; .reg .u64 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r38; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; mov.u64 %r30,%ar0; mov.f32 %r31,%ar1; mov.f32 %r32,%ar2; .loc 1 43 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r31; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r32; call casinf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r26,[%frame]; ld.f32 %r27,[%frame+4]; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r27; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r38,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r27; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r41,[%value_in]; } neg.f32 %r42,%r38; mov.f32 %r44,0f3fc90fdb; sub.f32 %r43,%r44,%r41; fma.rn.f32 %r45,%r42,0f00000000,%r43; .loc 1 45 0 st.f32 [%r30],%r45; st.f32 [%r30+4],%r42; .loc 1 46 0 ret; } lib_a-cacosh.o/ 0 0 0 644 2718 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacosh .visible .func cacosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cacosh.c" // BEGIN GLOBAL FUNCTION DECL: csqrt .extern .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: clog .extern .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: cacosh .visible .func cacosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r30; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r36; .reg .f64 %r37; .reg .u64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .f64 %r59; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r82; .reg .f64 %r85; mov.u64 %r50,%ar0; mov.f64 %r51,%ar1; mov.f64 %r52,%ar2; .loc 1 90 0 add.f64 %r59,%r51,0d3ff0000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r59; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r52; call csqrt,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r25,[%frame]; ld.f64 %r26,[%frame+8]; mov.f64 %r70,0d3ff0000000000000; sub.f64 %r69,%r51,%r70; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r69; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r52; call csqrt,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r30,[%frame]; ld.f64 %r31,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r25; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r26; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r30; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r31; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r32,[%frame]; ld.f64 %r33,[%frame+8]; add.f64 %r82,%r33,%r52; add.f64 %r85,%r32,%r51; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r85; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r82; call clog,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r36,[%frame]; ld.f64 %r37,[%frame+8]; .loc 1 92 0 st.f64 [%r50],%r36; st.f64 [%r50+8],%r37; .loc 1 93 0 ret; } lib_a-cacoshf.o/0 0 0 644 2713 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacoshf .visible .func cacoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cacoshf.c" // BEGIN GLOBAL FUNCTION DECL: csqrtf .extern .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: clogf .extern .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: cacoshf .visible .func cacoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .f32 %r36; .reg .f32 %r37; .reg .u64 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r59; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r82; .reg .f32 %r85; mov.u64 %r50,%ar0; mov.f32 %r51,%ar1; mov.f32 %r52,%ar2; .loc 1 45 0 add.f32 %r59,%r51,0f3f800000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r59; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r52; call csqrtf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r25,[%frame]; ld.f32 %r26,[%frame+4]; mov.f32 %r70,0f3f800000; sub.f32 %r69,%r51,%r70; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r69; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r52; call csqrtf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r30,[%frame]; ld.f32 %r31,[%frame+4]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r25; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r26; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r30; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r31; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r32,[%frame]; ld.f32 %r33,[%frame+4]; add.f32 %r82,%r33,%r52; add.f32 %r85,%r32,%r51; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r85; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r82; call clogf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r36,[%frame]; ld.f32 %r37,[%frame+4]; .loc 1 47 0 st.f32 [%r50],%r36; st.f32 [%r50+4],%r37; .loc 1 48 0 ret; } lib_a-carg.o/ 0 0 0 644 1706 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: carg .visible .func (.param .f64 %value_out) carg (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/complex/carg.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: carg .visible .func (.param .f64 %value_out) carg (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r29; .reg .f64 %r32; .reg .f64 %r35; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 58 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r29,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r32,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r35,[%value_in]; } .loc 1 59 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-cargf.o/ 0 0 0 644 1720 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cargf .visible .func (.param .f32 %value_out) cargf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/complex/cargf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2f .extern .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cargf .visible .func (.param .f32 %value_out) cargf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r29; .reg .f32 %r32; .reg .f32 %r35; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 18 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r29,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r32,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r29; call (%value_in),atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r35,[%value_in]; } .loc 1 19 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } lib_a-casin.o/ 0 0 0 644 4655 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casin .visible .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/casin.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: csqrt .extern .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: clog .extern .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: casin .visible .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r66; .reg .f64 %r69; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .f64 %r79; .reg .f64 %r80; .reg .f64 %r83; .reg .f64 %r86; .reg .f64 %r94; .reg .f64 %r98; .reg .f64 %r100; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r112; .reg .f64 %r113; mov.u64 %r61,%ar0; mov.f64 %r62,%ar1; mov.f64 %r63,%ar2; .loc 1 92 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r63; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r66,[%value_in]; } .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r63; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r69,[%value_in]; } .loc 1 150 0 fma.rn.f64 %r75,%r69,0d0000000000000000,%r66; .loc 1 151 0 mov.f64 %r74,0d3ff0000000000000; mov.f64 %r73,0d0000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r75; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r69; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r73; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r74; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r34,[%frame]; ld.f64 %r35,[%frame+8]; .loc 1 155 0 add.f64 %r76,%r66,%r66; mul.f64 %r36,%r76,%r69; sub.f64 %r77,%r66,%r69; mul.f64 %r78,%r36,0d0000000000000000; add.f64 %r79,%r66,%r69; fma.rn.f64 %r80,%r77,%r79,%r78; .loc 1 157 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r80; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r83,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r80; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r86,[%value_in]; } neg.f64 %r94,%r83; sub.f64 %r98,%r74,%r86; fma.rn.f64 %r100,%r94,0d0000000000000000,%r98; .loc 1 158 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r100; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r94; call csqrt,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r42,[%frame]; ld.f64 %r43,[%frame+8]; .loc 1 160 0 add.f64 %r104,%r34,%r42; add.f64 %r105,%r35,%r43; .loc 1 161 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r104; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r105; call clog,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r46,[%frame]; ld.f64 %r47,[%frame+8]; .loc 1 163 0 mov.f64 %r113,0dbff0000000000000; mov.f64 %r112,0d8000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r46; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r47; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r112; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r113; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r48,[%frame]; ld.f64 %r49,[%frame+8]; .loc 1 164 0 st.f64 [%r61],%r48; st.f64 [%r61+8],%r49; .loc 1 165 0 ret; } lib_a-casinf.o/ 0 0 0 644 4617 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casinf .visible .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/casinf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: csqrtf .extern .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: clogf .extern .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: casinf .visible .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .u64 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r66; .reg .f32 %r69; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r83; .reg .f32 %r86; .reg .f32 %r94; .reg .f32 %r98; .reg .f32 %r100; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r112; .reg .f32 %r113; mov.u64 %r61,%ar0; mov.f32 %r62,%ar1; mov.f32 %r63,%ar2; .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r63; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r66,[%value_in]; } .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r63; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r69,[%value_in]; } .loc 1 107 0 fma.rn.f32 %r75,%r69,0f00000000,%r66; .loc 1 108 0 mov.f32 %r74,0f3f800000; mov.f32 %r73,0f00000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r75; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r69; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r73; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r74; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r34,[%frame]; ld.f32 %r35,[%frame+4]; .loc 1 112 0 add.f32 %r76,%r66,%r66; mul.f32 %r36,%r76,%r69; sub.f32 %r77,%r66,%r69; mul.f32 %r78,%r36,0f00000000; add.f32 %r79,%r66,%r69; fma.rn.f32 %r80,%r77,%r79,%r78; .loc 1 114 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r80; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r83,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r80; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r86,[%value_in]; } neg.f32 %r94,%r83; sub.f32 %r98,%r74,%r86; fma.rn.f32 %r100,%r94,0f00000000,%r98; .loc 1 115 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r100; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r94; call csqrtf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r42,[%frame]; ld.f32 %r43,[%frame+4]; .loc 1 117 0 add.f32 %r104,%r34,%r42; add.f32 %r105,%r35,%r43; .loc 1 118 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r104; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r105; call clogf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r46,[%frame]; ld.f32 %r47,[%frame+4]; .loc 1 120 0 mov.f32 %r113,0fbf800000; mov.f32 %r112,0f80000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r46; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r47; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r112; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r113; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r48,[%frame]; ld.f32 %r49,[%frame+4]; .loc 1 121 0 st.f32 [%r61],%r48; st.f32 [%r61+4],%r49; .loc 1 122 0 ret; } lib_a-casinh.o/ 0 0 0 644 2413 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casinh .visible .func casinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/casinh.c" // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: casin .extern .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: casinh .visible .func casinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r22; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 95 0 mov.f64 %r41,0d3ff0000000000000; mov.f64 %r40,0d0000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r36; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r40; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r41; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r22,[%frame]; ld.f64 %r23,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r22; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r23; call casin,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r24,[%frame]; ld.f64 %r25,[%frame+8]; mov.f64 %r49,0dbff0000000000000; mov.f64 %r48,0d8000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r25; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r48; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r49; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r26,[%frame]; ld.f64 %r27,[%frame+8]; .loc 1 96 0 st.f64 [%r34],%r26; st.f64 [%r34+8],%r27; .loc 1 97 0 ret; } lib_a-casinhf.o/0 0 0 644 2388 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casinhf .visible .func casinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/casinhf.c" // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: casinf .extern .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: casinhf .visible .func casinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r22; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r27; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 42 0 mov.f32 %r41,0f3f800000; mov.f32 %r40,0f00000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r35; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r36; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r40; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r41; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r22,[%frame]; ld.f32 %r23,[%frame+4]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r22; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r23; call casinf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r24,[%frame]; ld.f32 %r25,[%frame+4]; mov.f32 %r49,0fbf800000; mov.f32 %r48,0f80000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r25; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r48; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r49; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r26,[%frame]; ld.f32 %r27,[%frame+4]; .loc 1 43 0 st.f32 [%r34],%r26; st.f32 [%r34+4],%r27; .loc 1 44 0 ret; } lib_a-catan.o/ 0 0 0 644 3773 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: catan .visible .func catan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/catan.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _redupi .extern .func (.param .f64 %value_out) _redupi (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 8 .u64 $LC0[2] = {9221120237041090560,9218868437227405312 }; // BEGIN GLOBAL FUNCTION DEF: catan .visible .func catan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r38; .reg .u64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r46; .reg .f64 %r49; .reg .pred %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .pred %r55; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .pred %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; mov.u64 %r41,%ar0; mov.f64 %r42,%ar1; mov.f64 %r43,%ar2; .loc 1 100 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r49,[%value_in]; } .loc 1 103 0 setp.neu.f64 %r50,%r46,0d0000000000000000; @ %r50 bra $L2; setp.gt.f64 %r51,%r49,0d3ff0000000000000; @ %r51 bra $L3; $L2: .loc 1 106 0 mul.f64 %r31,%r46,%r46; .loc 1 107 0 neg.f64 %r52,%r49; mov.f64 %r54,0d3ff0000000000000; sub.f64 %r53,%r54,%r31; fma.rn.f64 %r32,%r52,%r49,%r53; .loc 1 108 0 setp.eq.f64 %r55,%r32,0d0000000000000000; @ %r55 bra $L3; .loc 1 111 0 add.f64 %r58,%r46,%r46; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r58; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r59,[%value_in]; } mul.f64 %r61,%r59,0d3fe0000000000000; .loc 1 112 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r61; call (%value_in),_redupi,(%out_arg1); ld.param.f64 %r62,[%value_in]; } .loc 1 114 0 sub.f64 %r34,%r49,%r54; .loc 1 115 0 fma.rn.f64 %r35,%r34,%r34,%r31; .loc 1 116 0 setp.eq.f64 %r64,%r35,0d0000000000000000; @ %r64 bra $L3; .loc 1 119 0 add.f64 %r36,%r49,0d3ff0000000000000; .loc 1 120 0 fma.rn.f64 %r66,%r36,%r36,%r31; div.rn.f64 %r67,%r66,%r35; .loc 1 121 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r67; call (%value_in),log,(%out_arg1); ld.param.f64 %r68,[%value_in]; } mul.f64 %r38,%r68,0d3fd0000000000000; fma.rn.f64 %r69,%r38,0d0000000000000000,%r62; .loc 1 122 0 st.f64 [%r41],%r69; .loc 1 121 0 add.f64 %r70,%r38,0d0000000000000000; .loc 1 122 0 st.f64 [%r41+8],%r70; bra $L1; $L3: .loc 1 129 0 ld.const.f64 %r71,[$LC0]; st.f64 [%r41],%r71; ld.const.f64 %r72,[$LC0+8]; st.f64 [%r41+8],%r72; $L1: .loc 1 130 0 ret; } lib_a-catanf.o/ 0 0 0 644 3676 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: catanf .visible .func catanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/catanf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2f .extern .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _redupif .extern .func (.param .f32 %value_out) _redupif (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 4 .u32 $LC0[2] = {2143289344,2139095040 }; // BEGIN GLOBAL FUNCTION DEF: catanf .visible .func catanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r38; .reg .u64 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r46; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .pred %r55; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r61; .reg .f32 %r62; .reg .pred %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; mov.u64 %r41,%ar0; mov.f32 %r42,%ar1; mov.f32 %r43,%ar2; .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r43; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r43; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r49,[%value_in]; } .loc 1 52 0 setp.neu.f32 %r50,%r46,0f00000000; @ %r50 bra $L2; setp.gt.f32 %r51,%r49,0f3f800000; @ %r51 bra $L3; $L2: .loc 1 55 0 mul.f32 %r31,%r46,%r46; .loc 1 56 0 neg.f32 %r52,%r49; mov.f32 %r54,0f3f800000; sub.f32 %r53,%r54,%r31; fma.rn.f32 %r32,%r52,%r49,%r53; .loc 1 57 0 setp.eq.f32 %r55,%r32,0f00000000; @ %r55 bra $L3; .loc 1 60 0 add.f32 %r58,%r46,%r46; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r59,[%value_in]; } mul.f32 %r61,%r59,0f3f000000; .loc 1 61 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),_redupif,(%out_arg1); ld.param.f32 %r62,[%value_in]; } .loc 1 63 0 sub.f32 %r34,%r49,%r54; .loc 1 64 0 fma.rn.f32 %r35,%r34,%r34,%r31; .loc 1 65 0 setp.eq.f32 %r64,%r35,0f00000000; @ %r64 bra $L3; .loc 1 68 0 add.f32 %r36,%r49,0f3f800000; .loc 1 69 0 fma.rn.f32 %r66,%r36,%r36,%r31; div.rn.f32 %r67,%r66,%r35; .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),logf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } mul.f32 %r38,%r68,0f3e800000; fma.rn.f32 %r69,%r38,0f00000000,%r62; .loc 1 71 0 st.f32 [%r41],%r69; .loc 1 70 0 add.f32 %r70,%r38,0f00000000; .loc 1 71 0 st.f32 [%r41+4],%r70; bra $L1; $L3: .loc 1 78 0 ld.const.f32 %r71,[$LC0]; st.f32 [%r41],%r71; ld.const.f32 %r72,[$LC0+4]; st.f32 [%r41+4],%r72; $L1: .loc 1 79 0 ret; } lib_a-catanh.o/ 0 0 0 644 2413 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: catanh .visible .func catanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/catanh.c" // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: catan .extern .func catan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: catanh .visible .func catanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r22; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 88 0 mov.f64 %r41,0d3ff0000000000000; mov.f64 %r40,0d0000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r36; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r40; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r41; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r22,[%frame]; ld.f64 %r23,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r22; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r23; call catan,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r24,[%frame]; ld.f64 %r25,[%frame+8]; mov.f64 %r49,0dbff0000000000000; mov.f64 %r48,0d8000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r25; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r48; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r49; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r26,[%frame]; ld.f64 %r27,[%frame+8]; .loc 1 89 0 st.f64 [%r34],%r26; st.f64 [%r34+8],%r27; .loc 1 90 0 ret; } lib_a-catanhf.o/0 0 0 644 2388 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: catanhf .visible .func catanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/catanhf.c" // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: catanf .extern .func catanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: catanhf .visible .func catanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r22; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r27; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 42 0 mov.f32 %r41,0f3f800000; mov.f32 %r40,0f00000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r35; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r36; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r40; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r41; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r22,[%frame]; ld.f32 %r23,[%frame+4]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r22; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r23; call catanf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r24,[%frame]; ld.f32 %r25,[%frame+4]; mov.f32 %r49,0fbf800000; mov.f32 %r48,0f80000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r25; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r48; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r49; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r26,[%frame]; ld.f32 %r27,[%frame+4]; .loc 1 43 0 st.f32 [%r34],%r26; st.f32 [%r34+4],%r27; .loc 1 44 0 ret; } lib_a-cbrtl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cbrtl .visible .func (.param .f64 %value_out) cbrtl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/cbrtl.c" // BEGIN GLOBAL FUNCTION DECL: cbrt .extern .func (.param .f64 %value_out) cbrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cbrtl .visible .func (.param .f64 %value_out) cbrtl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),cbrt,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-ccos.o/ 0 0 0 644 2912 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccos .visible .func ccos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ccos.c" // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchsh .extern .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ccos .visible .func ccos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r32; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r39; .reg .u64 %r43; .reg .f64 %r46; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r52; .reg .f64 %r54; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } add.u64 %r43,%frame,8; { .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchsh,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r46; call (%value_in),sin,(%out_arg1); ld.param.f64 %r48,[%value_in]; } ld.f64 %r49,[%frame]; mul.f64 %r32,%r48,%r49; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r52,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),cos,(%out_arg1); ld.param.f64 %r54,[%value_in]; } mul.f64 %r56,%r32,0d8000000000000000; ld.f64 %r58,[%frame+8]; fma.rn.f64 %r57,%r54,%r58,%r56; .loc 1 80 0 st.f64 [%r34],%r57; .loc 1 79 0 neg.f64 %r59,%r32; .loc 1 80 0 st.f64 [%r34+8],%r59; .loc 1 81 0 ret; } lib_a-ccosf.o/ 0 0 0 644 2924 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccosf .visible .func ccosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ccosf.c" // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchshf .extern .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ccosf .visible .func ccosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r32; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r39; .reg .u64 %r43; .reg .f32 %r46; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r52; .reg .f32 %r54; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } add.u64 %r43,%frame,4; { .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchshf,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r48,[%value_in]; } ld.f32 %r49,[%frame]; mul.f32 %r32,%r48,%r49; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r52,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r52; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r54,[%value_in]; } mul.f32 %r56,%r32,0f80000000; ld.f32 %r58,[%frame+4]; fma.rn.f32 %r57,%r54,%r58,%r56; .loc 1 47 0 st.f32 [%r34],%r57; .loc 1 46 0 neg.f32 %r59,%r32; .loc 1 47 0 st.f32 [%r34+4],%r59; .loc 1 48 0 ret; } lib_a-ccosh.o/ 0 0 0 644 2634 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccosh .visible .func ccosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ccosh.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ccosh .visible .func ccosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r30; .reg .u64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r36; .reg .f64 %r39; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r45; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r31,%ar0; mov.f64 %r32,%ar1; mov.f64 %r33,%ar2; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r36,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r41,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),sin,(%out_arg1); ld.param.f64 %r43,[%value_in]; } mul.f64 %r30,%r41,%r43; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r45,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),cos,(%out_arg1); ld.param.f64 %r47,[%value_in]; } mul.f64 %r48,%r30,0d0000000000000000; fma.rn.f64 %r49,%r45,%r47,%r48; .loc 1 80 0 st.f64 [%r31],%r49; st.f64 [%r31+8],%r30; .loc 1 81 0 ret; } lib_a-ccoshf.o/ 0 0 0 644 2649 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccoshf .visible .func ccoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ccoshf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ccoshf .visible .func ccoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r30; .reg .u64 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .f32 %r36; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r43; .reg .f32 %r45; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r31,%ar0; mov.f32 %r32,%ar1; mov.f32 %r33,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r36,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r41,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r43,[%value_in]; } mul.f32 %r30,%r41,%r43; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } mul.f32 %r48,%r30,0f00000000; fma.rn.f32 %r49,%r45,%r47,%r48; .loc 1 47 0 st.f32 [%r31],%r49; st.f32 [%r31+4],%r30; .loc 1 48 0 ret; } lib_a-ceill.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ceill .visible .func (.param .f64 %value_out) ceill (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/ceill.c" // BEGIN GLOBAL FUNCTION DECL: ceil .extern .func (.param .f64 %value_out) ceil (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ceill .visible .func (.param .f64 %value_out) ceill (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),ceil,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /0 0 0 0 644 7180 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _cchsh .visible .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cephes_subr.c" // BEGIN GLOBAL FUNCTION DECL: _redupi .visible .func (.param .f64 %value_out) _redupi (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctans .visible .func (.param .f64 %value_out) _ctans (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _cchsh .visible .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f64 %r28; .reg .f64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .f64 %r34; .reg .pred %r35; .reg .f64 %r37; .reg .f64 %r39; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; mov.f64 %r30,%ar0; mov.u64 %r31,%ar1; mov.u64 %r32,%ar2; .loc 1 46 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r34,[%value_in]; } setp.le.f64 %r35,%r34,0d3fe0000000000000; @ ! %r35 bra $L6; .loc 1 47 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r37,[%value_in]; } st.f64 [%r31],%r37; .loc 1 48 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r39,[%value_in]; } st.f64 [%r32],%r39; bra $L1; $L6: .loc 1 50 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),exp,(%out_arg1); ld.param.f64 %r41,[%value_in]; } .loc 1 51 0 mov.f64 %r42,0d3fe0000000000000; div.rn.f64 %r28,%r42,%r41; .loc 1 53 0 neg.f64 %r43,%r28; fma.rn.f64 %r44,%r41,0d3fe0000000000000,%r43; st.f64 [%r32],%r44; .loc 1 54 0 fma.rn.f64 %r45,%r41,0d3fe0000000000000,%r28; st.f64 [%r31],%r45; $L1: .loc 1 56 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _redupi .visible .func (.param .f64 %value_out) _redupi (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .u64 %r26; .reg .f64 %r27; .reg .f64 %r32; .reg .pred %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r37; mov.f64 %r32,%ar0; .loc 1 72 0 div.rn.f64 %r25,%r32,0d400921fb54442d18; .loc 1 73 0 setp.ge.f64 %r33,%r25,0d0000000000000000; @ ! %r33 bra $L12; .loc 1 74 0 add.f64 %r24,%r25,0d3fe0000000000000; bra $L10; $L12: .loc 1 76 0 mov.f64 %r34,0d3fe0000000000000; sub.f64 %r24,%r25,%r34; $L10: .loc 1 78 0 cvt.rzi.s64.f64 %r26,%r24; .loc 1 79 0 cvt.rn.f64.s64 %r27,%r26; .loc 1 80 0 neg.f64 %r35,%r27; fma.rn.f64 %r37,%r35,0d400921fb54000000,%r32; fma.rn.f64 %r23,%r35,0d3e210b4610000000,%r37; fma.rn.f64 %value,%r35,0d3c6a62633145c06e,%r23; .loc 1 82 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _ctans .visible .func (.param .f64 %value_out) _ctans (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r31; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .u64 %r51; .reg .f64 %r52; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r70; .reg .f64 %r72; .reg .f64 %r73; .reg .pred %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r78; .reg .f64 %r79; .reg .f64 %r81; .reg .f64 %r82; .reg .pred %r83; mov.f64 %r60,%ar0; mov.f64 %r61,%ar1; .loc 1 92 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r60; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r61; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r64,[%value_in]; } add.f64 %r66,%r64,%r64; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r67,[%value_in]; } .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r60; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r61; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r70,[%value_in]; } add.f64 %r72,%r70,%r70; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r73,[%value_in]; } .loc 1 72 0 div.rn.f64 %r34,%r67,0d400921fb54442d18; .loc 1 73 0 setp.ge.f64 %r74,%r34,0d0000000000000000; @ ! %r74 bra $L20; .loc 1 74 0 add.f64 %r50,%r34,0d3fe0000000000000; bra $L16; $L20: .loc 1 76 0 mov.f64 %r75,0d3fe0000000000000; sub.f64 %r50,%r34,%r75; $L16: .loc 1 78 0 cvt.rzi.s64.f64 %r51,%r50; .loc 1 79 0 cvt.rn.f64.s64 %r52,%r51; .loc 1 80 0 neg.f64 %r76,%r52; fma.rn.f64 %r78,%r76,0d400921fb54000000,%r67; fma.rn.f64 %r54,%r76,0d3e210b4610000000,%r78; fma.rn.f64 %r55,%r76,0d3c6a62633145c06e,%r54; .loc 1 97 0 mul.f64 %r35,%r55,%r55; .loc 1 98 0 mul.f64 %r36,%r73,%r73; .loc 1 103 0 mov.f64 %r59,0d0000000000000000; .loc 1 102 0 mov.f64 %r31,%r59; .loc 1 100 0 mov.f64 %r30,0d3ff0000000000000; .loc 1 99 0 mov.f64 %r29,%r30; .loc 1 101 0 mov.f64 %r28,%r30; $L17: .loc 1 105 0 add.f64 %r37,%r31,0d3ff0000000000000; .loc 1 106 0 mul.f64 %r38,%r28,%r37; .loc 1 107 0 add.f64 %r39,%r37,0d3ff0000000000000; .loc 1 108 0 mul.f64 %r40,%r38,%r39; .loc 1 109 0 mul.f64 %r41,%r29,%r35; .loc 1 110 0 mul.f64 %r42,%r30,%r36; .loc 1 111 0 add.f64 %r43,%r41,%r42; .loc 1 112 0 div.rn.f64 %r79,%r43,%r40; .loc 1 113 0 add.f64 %r45,%r79,%r59; .loc 1 115 0 add.f64 %r46,%r39,0d3ff0000000000000; .loc 1 116 0 mul.f64 %r47,%r40,%r46; .loc 1 117 0 add.f64 %r31,%r46,0d3ff0000000000000; .loc 1 118 0 mul.f64 %r28,%r47,%r31; .loc 1 119 0 mul.f64 %r29,%r35,%r41; .loc 1 120 0 mul.f64 %r30,%r36,%r42; .loc 1 121 0 sub.f64 %r48,%r30,%r29; .loc 1 122 0 div.rn.f64 %r49,%r48,%r28; .loc 1 123 0 add.f64 %r59,%r45,%r49; .loc 1 124 0 div.rn.f64 %r81,%r49,%r59; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r82,[%value_in]; } setp.gt.f64 %r83,%r82,0d3c9fb49140a1644f; @ %r83 bra $L17; .loc 1 126 0 mov.f64 %value,%r59; st.param.f64 [%value_out],%value; ret; } /21 0 0 0 644 7348 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _cchshf .visible .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cephes_subrf.c" // BEGIN GLOBAL FUNCTION DECL: _redupif .visible .func (.param .f32 %value_out) _redupif (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctansf .visible .func (.param .f32 %value_out) _ctansf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expf .extern .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _cchshf .visible .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f32 %r28; .reg .f32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .f32 %r34; .reg .pred %r35; .reg .f32 %r37; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; mov.f32 %r30,%ar0; mov.u64 %r31,%ar1; mov.u64 %r32,%ar2; .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r34,[%value_in]; } setp.le.f32 %r35,%r34,0f3f000000; @ ! %r35 bra $L6; .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } st.f32 [%r31],%r37; .loc 1 48 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r39,[%value_in]; } st.f32 [%r32],%r39; bra $L1; $L6: .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),expf,(%out_arg1); ld.param.f32 %r41,[%value_in]; } .loc 1 51 0 mov.f32 %r42,0f3f000000; div.rn.f32 %r28,%r42,%r41; .loc 1 53 0 neg.f32 %r43,%r28; fma.rn.f32 %r44,%r41,0f3f000000,%r43; st.f32 [%r32],%r44; .loc 1 54 0 fma.rn.f32 %r45,%r41,0f3f000000,%r28; st.f32 [%r31],%r45; $L1: .loc 1 56 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _redupif .visible .func (.param .f32 %value_out) _redupif (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f32 %r27; .reg .f32 %r28; .reg .u64 %r29; .reg .f32 %r35; .reg .pred %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .f64 %r40; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; mov.f32 %r35,%ar0; .loc 1 72 0 div.rn.f32 %r28,%r35,0f40490fdb; .loc 1 73 0 setp.ge.f32 %r36,%r28,0f00000000; @ ! %r36 bra $L12; .loc 1 74 0 add.f32 %r27,%r28,0f3f000000; bra $L10; $L12: .loc 1 76 0 mov.f32 %r37,0f3f000000; sub.f32 %r27,%r28,%r37; $L10: .loc 1 78 0 cvt.rzi.s64.f32 %r29,%r27; .loc 1 79 0 cvt.rn.f32.s64 %r38,%r29; .loc 1 80 0 cvt.f64.f32 %r23,%r38; neg.f64 %r40,%r23; cvt.f64.f32 %r43,%r35; fma.rn.f64 %r44,%r40,0d4009200000000000,%r43; fma.rn.f64 %r45,%r40,0d3f4fb40000000000,%r44; fma.rn.f64 %r46,%r40,0d3e84442d18469899,%r45; cvt.rn.f32.f64 %value,%r46; .loc 1 82 0 st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _ctansf .visible .func (.param .f32 %value_out) _ctansf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .u64 %r52; .reg .f64 %r55; .reg .f32 %r59; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r74; .reg .f32 %r76; .reg .f32 %r77; .reg .pred %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f64 %r81; .reg .f64 %r84; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r87; .reg .f32 %r88; .reg .f32 %r90; .reg .f32 %r91; .reg .f64 %r92; .reg .pred %r93; mov.f32 %r64,%ar0; mov.f32 %r65,%ar1; .loc 1 91 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r64; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r65; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r68,[%value_in]; } add.f32 %r70,%r68,%r68; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 92 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r64; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r65; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r74,[%value_in]; } add.f32 %r76,%r74,%r74; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r76; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r77,[%value_in]; } .loc 1 72 0 div.rn.f32 %r35,%r71,0f40490fdb; .loc 1 73 0 setp.ge.f32 %r78,%r35,0f00000000; @ ! %r78 bra $L20; .loc 1 74 0 add.f32 %r51,%r35,0f3f000000; bra $L16; $L20: .loc 1 76 0 mov.f32 %r79,0f3f000000; sub.f32 %r51,%r35,%r79; $L16: .loc 1 78 0 cvt.rzi.s64.f32 %r52,%r51; .loc 1 79 0 cvt.rn.f32.s64 %r80,%r52; .loc 1 80 0 cvt.f64.f32 %r55,%r80; neg.f64 %r81,%r55; cvt.f64.f32 %r84,%r71; fma.rn.f64 %r85,%r81,0d4009200000000000,%r84; fma.rn.f64 %r86,%r81,0d3f4fb40000000000,%r85; fma.rn.f64 %r87,%r81,0d3e84442d18469899,%r86; cvt.rn.f32.f64 %r59,%r87; .loc 1 96 0 mul.f32 %r36,%r59,%r59; .loc 1 97 0 mul.f32 %r37,%r77,%r77; .loc 1 102 0 mov.f32 %r63,0f00000000; .loc 1 101 0 mov.f32 %r32,%r63; .loc 1 99 0 mov.f32 %r31,0f3f800000; .loc 1 98 0 mov.f32 %r30,%r31; .loc 1 100 0 mov.f32 %r29,%r31; $L17: .loc 1 104 0 add.f32 %r38,%r32,0f3f800000; .loc 1 105 0 mul.f32 %r39,%r29,%r38; .loc 1 106 0 add.f32 %r40,%r38,0f3f800000; .loc 1 107 0 mul.f32 %r41,%r39,%r40; .loc 1 108 0 mul.f32 %r42,%r30,%r36; .loc 1 109 0 mul.f32 %r43,%r31,%r37; .loc 1 110 0 add.f32 %r44,%r42,%r43; .loc 1 111 0 div.rn.f32 %r88,%r44,%r41; .loc 1 112 0 add.f32 %r46,%r88,%r63; .loc 1 114 0 add.f32 %r47,%r40,0f3f800000; .loc 1 115 0 mul.f32 %r48,%r41,%r47; .loc 1 116 0 add.f32 %r32,%r47,0f3f800000; .loc 1 117 0 mul.f32 %r29,%r48,%r32; .loc 1 118 0 mul.f32 %r30,%r36,%r42; .loc 1 119 0 mul.f32 %r31,%r37,%r43; .loc 1 120 0 sub.f32 %r49,%r31,%r30; .loc 1 121 0 div.rn.f32 %r50,%r49,%r29; .loc 1 122 0 add.f32 %r63,%r46,%r50; .loc 1 123 0 div.rn.f32 %r90,%r50,%r63; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r90; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } cvt.f64.f32 %r92,%r91; setp.gt.f64 %r93,%r92,0d3e601b2b29a4692b; @ %r93 bra $L17; .loc 1 125 0 mov.f32 %value,%r63; st.param.f32 [%value_out],%value; ret; } lib_a-cexp.o/ 0 0 0 644 2372 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cexp .visible .func cexp (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cexp.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cexp .visible .func cexp (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r29; .reg .u64 %r30; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r35; .reg .f64 %r38; .reg .f64 %r40; .reg .f64 %r42; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; mov.u64 %r30,%ar0; mov.f64 %r31,%ar1; mov.f64 %r32,%ar2; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r35,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),exp,(%out_arg1); ld.param.f64 %r40,[%value_in]; } .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),sin,(%out_arg1); ld.param.f64 %r42,[%value_in]; } mul.f64 %r29,%r42,%r40; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),cos,(%out_arg1); ld.param.f64 %r44,[%value_in]; } mul.f64 %r45,%r29,0d0000000000000000; fma.rn.f64 %r46,%r44,%r40,%r45; .loc 1 81 0 st.f64 [%r30],%r46; st.f64 [%r30+8],%r29; .loc 1 82 0 ret; } lib_a-cexpf.o/ 0 0 0 644 2384 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cexpf .visible .func cexpf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cexpf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: expf .extern .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cexpf .visible .func cexpf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r29; .reg .u64 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r35; .reg .f32 %r38; .reg .f32 %r40; .reg .f32 %r42; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; mov.u64 %r30,%ar0; mov.f32 %r31,%ar1; mov.f32 %r32,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r35,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r38,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),expf,(%out_arg1); ld.param.f32 %r40,[%value_in]; } .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r42,[%value_in]; } mul.f32 %r29,%r42,%r40; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } mul.f32 %r45,%r29,0f00000000; fma.rn.f32 %r46,%r44,%r40,%r45; .loc 1 48 0 st.f32 [%r30],%r46; st.f32 [%r30+4],%r29; .loc 1 49 0 ret; } lib_a-cimag.o/ 0 0 0 644 567 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cimag .visible .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/complex/cimag.c" // BEGIN GLOBAL FUNCTION DEF: cimag .visible .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; mov.f64 %value,%ar1; .loc 1 53 0 st.param.f64 [%value_out],%value; ret; } lib_a-cimagf.o/ 0 0 0 644 572 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cimagf .visible .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/complex/cimagf.c" // BEGIN GLOBAL FUNCTION DEF: cimagf .visible .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; mov.f32 %value,%ar1; .loc 1 20 0 st.param.f32 [%value_out],%value; ret; } lib_a-clog.o/ 0 0 0 644 2471 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: clog .visible .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/clog.c" // BEGIN GLOBAL FUNCTION DECL: cabs .extern .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: clog .visible .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r33; .reg .f64 %r35; .reg .f64 %r38; .reg .f64 %r41; .reg .f64 %r44; .reg .f64 %r45; mov.u64 %r28,%ar0; mov.f64 %r29,%ar1; mov.f64 %r30,%ar2; .loc 1 86 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cabs,(%out_arg1,%out_arg2); ld.param.f64 %r33,[%value_in]; } .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),log,(%out_arg1); ld.param.f64 %r35,[%value_in]; } .loc 1 88 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r41; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r38; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } .loc 1 89 0 fma.rn.f64 %r45,%r44,0d0000000000000000,%r35; .loc 1 90 0 st.f64 [%r28],%r45; st.f64 [%r28+8],%r44; .loc 1 91 0 ret; } lib_a-clogf.o/ 0 0 0 644 2483 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: clogf .visible .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/clogf.c" // BEGIN GLOBAL FUNCTION DECL: cabsf .extern .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2f .extern .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: clogf .visible .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %r28; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r33; .reg .f32 %r35; .reg .f32 %r38; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r45; mov.u64 %r28,%ar0; mov.f32 %r29,%ar1; mov.f32 %r30,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cabsf,(%out_arg1,%out_arg2); ld.param.f32 %r33,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; call (%value_in),logf,(%out_arg1); ld.param.f32 %r35,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r38,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r41,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r38; call (%value_in),atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } .loc 1 47 0 fma.rn.f32 %r45,%r44,0f00000000,%r35; .loc 1 48 0 st.f32 [%r28],%r45; st.f32 [%r28+4],%r44; .loc 1 49 0 ret; } lib_a-conj.o/ 0 0 0 644 818 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: conj .visible .func conj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/conj.c" // BEGIN GLOBAL FUNCTION DEF: conj .visible .func conj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r26; .reg .f64 %r27; .reg .f64 %r28; .reg .f64 %r29; mov.u64 %r26,%ar0; mov.f64 %r27,%ar1; mov.f64 %r28,%ar2; .loc 1 52 0 neg.f64 %r29,%r28; .loc 1 54 0 st.f64 [%r26],%r27; st.f64 [%r26+8],%r29; .loc 1 55 0 ret; } lib_a-conjf.o/ 0 0 0 644 822 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: conjf .visible .func conjf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/conjf.c" // BEGIN GLOBAL FUNCTION DEF: conjf .visible .func conjf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r26; .reg .f32 %r27; .reg .f32 %r28; .reg .f32 %r29; mov.u64 %r26,%ar0; mov.f32 %r27,%ar1; mov.f32 %r28,%ar2; .loc 1 19 0 neg.f32 %r29,%r28; .loc 1 21 0 st.f32 [%r26],%r27; st.f32 [%r26+4],%r29; .loc 1 22 0 ret; } /43 0 0 0 644 1031 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysignl .visible .func (.param .f64 %value_out) copysignl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/copysignl.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: copysignl .visible .func (.param .f64 %value_out) copysignl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-coshl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: coshl .visible .func (.param .f64 %value_out) coshl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/coshl.c" // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: coshl .visible .func (.param .f64 %value_out) coshl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-cosl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cosl .visible .func (.param .f64 %value_out) cosl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/cosl.c" // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cosl .visible .func (.param .f64 %value_out) cosl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),cos,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-cpow.o/ 0 0 0 644 4598 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: cpow .visible .func cpow (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); .file 1 "../../../../../newlib/libm/complex/cpow.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cabs .extern .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: carg .extern .func (.param .f64 %value_out) carg (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 8 .u64 $LC0[2] = {0,0 }; // BEGIN GLOBAL FUNCTION DEF: cpow .visible .func cpow (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %ar3; ld.param.f64 %ar3,[%in_ar3]; .reg .f64 %ar4; ld.param.f64 %ar4,[%in_ar4]; .reg .f64 %r30; .reg .f64 %r31; .reg .f64 %r36; .reg .u64 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r44; .reg .f64 %r47; .reg .f64 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r56; .reg .f64 %r59; .reg .pred %r60; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r66; .reg .f64 %r68; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; mov.u64 %r37,%ar0; mov.f64 %r38,%ar1; mov.f64 %r39,%ar2; mov.f64 %r40,%ar3; mov.f64 %r41,%ar4; .loc 1 86 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r47,[%value_in]; } .loc 1 88 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r39; call (%value_in),cabs,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } .loc 1 89 0 setp.neu.f64 %r51,%r50,0d0000000000000000; @ %r51 bra $L2; .loc 1 90 0 ld.const.f64 %r52,[$LC0]; st.f64 [%r37],%r52; ld.const.f64 %r53,[$LC0+8]; st.f64 [%r37+8],%r53; bra $L1; $L2: .loc 1 92 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r39; call (%value_in),carg,(%out_arg1,%out_arg2); ld.param.f64 %r56,[%value_in]; } .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r44; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r59,[%value_in]; } mov.f64 %r30,%r59; .loc 1 94 0 mul.f64 %r31,%r44,%r56; .loc 1 95 0 setp.eq.f64 %r60,%r47,0d0000000000000000; @ %r60 bra $L4; .loc 1 96 0 neg.f64 %r62,%r47; mul.f64 %r63,%r62,%r56; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r63; call (%value_in),exp,(%out_arg1); ld.param.f64 %r64,[%value_in]; } mul.f64 %r30,%r30,%r64; .loc 1 97 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; call (%value_in),log,(%out_arg1); ld.param.f64 %r66,[%value_in]; } fma.rn.f64 %r31,%r66,%r47,%r31; $L4: .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),sin,(%out_arg1); ld.param.f64 %r68,[%value_in]; } mul.f64 %r36,%r68,%r30; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),cos,(%out_arg1); ld.param.f64 %r70,[%value_in]; } mul.f64 %r71,%r36,0d0000000000000000; fma.rn.f64 %r72,%r70,%r30,%r71; .loc 1 100 0 st.f64 [%r37],%r72; st.f64 [%r37+8],%r36; $L1: .loc 1 101 0 ret; } lib_a-cpowf.o/ 0 0 0 644 4604 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: cpowf .visible .func cpowf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); .file 1 "../../../../../newlib/libm/complex/cpowf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cabsf .extern .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cargf .extern .func (.param .f32 %value_out) cargf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: expf .extern .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 4 .u32 $LC0[2] = {0,0 }; // BEGIN GLOBAL FUNCTION DEF: cpowf .visible .func cpowf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %ar3; ld.param.f32 %ar3,[%in_ar3]; .reg .f32 %ar4; ld.param.f32 %ar4,[%in_ar4]; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r36; .reg .u64 %r37; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r47; .reg .f32 %r50; .reg .pred %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r56; .reg .f32 %r59; .reg .pred %r60; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r66; .reg .f32 %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; mov.u64 %r37,%ar0; mov.f32 %r38,%ar1; mov.f32 %r39,%ar2; mov.f32 %r40,%ar3; mov.f32 %r41,%ar4; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r47,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r39; call (%value_in),cabsf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } .loc 1 47 0 setp.neu.f32 %r51,%r50,0f00000000; @ %r51 bra $L2; .loc 1 48 0 ld.const.f32 %r52,[$LC0]; st.f32 [%r37],%r52; ld.const.f32 %r53,[$LC0+4]; st.f32 [%r37+4],%r53; bra $L1; $L2: .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r39; call (%value_in),cargf,(%out_arg1,%out_arg2); ld.param.f32 %r56,[%value_in]; } .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r44; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r59,[%value_in]; } mov.f32 %r30,%r59; .loc 1 52 0 mul.f32 %r31,%r44,%r56; .loc 1 53 0 setp.eq.f32 %r60,%r47,0f00000000; @ %r60 bra $L4; .loc 1 54 0 neg.f32 %r62,%r47; mul.f32 %r63,%r62,%r56; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r63; call (%value_in),expf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } mul.f32 %r30,%r30,%r64; .loc 1 55 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; call (%value_in),logf,(%out_arg1); ld.param.f32 %r66,[%value_in]; } fma.rn.f32 %r31,%r66,%r47,%r31; $L4: .loc 1 57 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } mul.f32 %r36,%r68,%r30; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r70,[%value_in]; } mul.f32 %r71,%r36,0f00000000; fma.rn.f32 %r72,%r70,%r30,%r71; .loc 1 58 0 st.f32 [%r37],%r72; st.f32 [%r37+4],%r36; $L1: .loc 1 59 0 ret; } lib_a-cproj.o/ 0 0 0 644 2893 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cproj .visible .func cproj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cproj.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cproj .visible .func cproj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r33; .reg .u32 %r35; .reg .pred %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r46; .reg .u32 %r48; .reg .pred %r49; mov.u64 %r28,%ar0; mov.f64 %r29,%ar1; mov.f64 %r30,%ar2; .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r33,[%value_in]; } { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r35,[%value_in]; } setp.ne.u32 %r36,%r35,1; @ %r36 bra $L2; $L4: .loc 1 100 0 mov.f64 %r37,0d7ff0000000000000; st.f64 [%frame],%r37; .loc 1 102 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r40,[%value_in]; } mov.f64 %r41,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r41; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r40; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r43,[%value_in]; } ld.f64 %r29,[%frame]; mov.f64 %r30,%r43; bra $L3; $L2: .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r46; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,1; @ %r49 bra $L4; $L3: .loc 1 105 0 st.f64 [%r28],%r29; st.f64 [%r28+8],%r30; .loc 1 106 0 ret; } lib_a-cprojf.o/ 0 0 0 644 2887 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cprojf .visible .func cprojf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/cprojf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cprojf .visible .func cprojf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r28; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r33; .reg .u32 %r35; .reg .pred %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r43; .reg .f32 %r46; .reg .u32 %r48; .reg .pred %r49; mov.u64 %r28,%ar0; mov.f32 %r29,%ar1; mov.f32 %r30,%ar2; .loc 1 58 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r33,[%value_in]; } { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r35,[%value_in]; } setp.ne.u32 %r36,%r35,1; @ %r36 bra $L2; $L4: .loc 1 62 0 mov.f32 %r37,0f7f800000; st.f32 [%frame],%r37; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r40,[%value_in]; } mov.f32 %r41,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r40; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r43,[%value_in]; } ld.f32 %r29,[%frame]; mov.f32 %r30,%r43; bra $L3; $L2: .loc 1 58 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,1; @ %r49 bra $L4; $L3: .loc 1 67 0 st.f32 [%r28],%r29; st.f32 [%r28+4],%r30; .loc 1 68 0 ret; } lib_a-creal.o/ 0 0 0 644 567 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: creal .visible .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/complex/creal.c" // BEGIN GLOBAL FUNCTION DEF: creal .visible .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; mov.f64 %value,%ar0; .loc 1 53 0 st.param.f64 [%value_out],%value; ret; } lib_a-crealf.o/ 0 0 0 644 572 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: crealf .visible .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/complex/crealf.c" // BEGIN GLOBAL FUNCTION DEF: crealf .visible .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; mov.f32 %value,%ar0; .loc 1 20 0 st.param.f32 [%value_out],%value; ret; } lib_a-csin.o/ 0 0 0 644 2853 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csin .visible .func csin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/csin.c" // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchsh .extern .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: csin .visible .func csin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r31; .reg .u64 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r37; .reg .u64 %r41; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r50; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .f64 %r55; mov.u64 %r32,%ar0; mov.f64 %r33,%ar1; mov.f64 %r34,%ar2; .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r34; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r37,[%value_in]; } add.u64 %r41,%frame,8; { .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchsh,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r34; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),cos,(%out_arg1); ld.param.f64 %r46,[%value_in]; } ld.f64 %r47,[%frame]; mul.f64 %r31,%r46,%r47; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r34; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; call (%value_in),sin,(%out_arg1); ld.param.f64 %r52,[%value_in]; } mul.f64 %r53,%r31,0d0000000000000000; ld.f64 %r55,[%frame+8]; fma.rn.f64 %r54,%r52,%r55,%r53; .loc 1 80 0 st.f64 [%r32],%r54; st.f64 [%r32+8],%r31; .loc 1 81 0 ret; } lib_a-csinf.o/ 0 0 0 644 2865 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csinf .visible .func csinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/csinf.c" // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchshf .extern .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: csinf .visible .func csinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f32 %r31; .reg .u64 %r32; .reg .f32 %r33; .reg .f32 %r34; .reg .f32 %r37; .reg .u64 %r41; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r50; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; mov.u64 %r32,%ar0; mov.f32 %r33,%ar1; mov.f32 %r34,%ar2; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r34; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r37,[%value_in]; } add.u64 %r41,%frame,4; { .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchshf,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r34; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r46,[%value_in]; } ld.f32 %r47,[%frame]; mul.f32 %r31,%r46,%r47; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r34; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r52,[%value_in]; } mul.f32 %r53,%r31,0f00000000; ld.f32 %r55,[%frame+4]; fma.rn.f32 %r54,%r52,%r55,%r53; .loc 1 47 0 st.f32 [%r32],%r54; st.f32 [%r32+4],%r31; .loc 1 48 0 ret; } lib_a-csinh.o/ 0 0 0 644 2634 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csinh .visible .func csinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/csinh.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: csinh .visible .func csinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r30; .reg .u64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r36; .reg .f64 %r39; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r45; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r31,%ar0; mov.f64 %r32,%ar1; mov.f64 %r33,%ar2; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r36,[%value_in]; } .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r41,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),sin,(%out_arg1); ld.param.f64 %r43,[%value_in]; } mul.f64 %r30,%r41,%r43; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r45,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),cos,(%out_arg1); ld.param.f64 %r47,[%value_in]; } mul.f64 %r48,%r30,0d0000000000000000; fma.rn.f64 %r49,%r45,%r47,%r48; .loc 1 79 0 st.f64 [%r31],%r49; st.f64 [%r31+8],%r30; .loc 1 80 0 ret; } lib_a-csinhf.o/ 0 0 0 644 2649 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csinhf .visible .func csinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/csinhf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: csinhf .visible .func csinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r30; .reg .u64 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .f32 %r36; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r43; .reg .f32 %r45; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r31,%ar0; mov.f32 %r32,%ar1; mov.f32 %r33,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r36,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r41,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r43,[%value_in]; } mul.f32 %r30,%r41,%r43; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } mul.f32 %r48,%r30,0f00000000; fma.rn.f32 %r49,%r45,%r47,%r48; .loc 1 47 0 st.f32 [%r31],%r49; st.f32 [%r31+4],%r30; .loc 1 48 0 ret; } lib_a-csqrt.o/ 0 0 0 644 6625 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csqrt .visible .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/csqrt.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sqrt .extern .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cabs .extern .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: csqrt .visible .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r25; .reg .f64 %r38; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r69; .reg .u64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r75; .reg .f64 %r78; .reg .pred %r79; .reg .pred %r80; .reg .f64 %r83; .reg .f64 %r85; .reg .pred %r86; .reg .pred %r89; .reg .f64 %r91; .reg .f64 %r93; .reg .pred %r94; .reg .f64 %r96; .reg .f64 %r100; .reg .pred %r101; .reg .f64 %r103; .reg .pred %r104; .reg .f64 %r110; .reg .f64 %r113; .reg .pred %r114; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r124; .reg .f64 %r126; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .pred %r131; mov.u64 %r70,%ar0; mov.f64 %r71,%ar1; mov.f64 %r72,%ar2; .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r71; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r72; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r75,[%value_in]; } .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r71; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r72; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r78,[%value_in]; } .loc 1 82 0 setp.neu.f64 %r79,%r78,0d0000000000000000; @ %r79 bra $L2; .loc 1 83 0 setp.neu.f64 %r80,%r75,0d0000000000000000; @ %r80 bra $L3; .loc 1 84 0 fma.rn.f64 %r45,%r78,0d0000000000000000,0d0000000000000000; mov.f64 %r46,%r78; bra $L4; $L3: .loc 1 86 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r75; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r83,[%value_in]; } .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r83; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r85,[%value_in]; } .loc 1 88 0 setp.lt.f64 %r86,%r75,0d0000000000000000; @ ! %r86 bra $L26; .loc 1 89 0 fma.rn.f64 %r45,%r85,0d0000000000000000,0d0000000000000000; mov.f64 %r46,%r85; bra $L4; $L26: .loc 1 91 0 fma.rn.f64 %r45,%r78,0d0000000000000000,%r85; mov.f64 %r46,%r78; $L4: .loc 1 94 0 st.f64 [%r70],%r45; st.f64 [%r70+8],%r46; bra $L1; $L2: .loc 1 96 0 setp.neu.f64 %r89,%r75,0d0000000000000000; @ %r89 bra $L8; .loc 1 97 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r78; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r91,[%value_in]; } .loc 1 98 0 mul.f64 %r25,%r91,0d3fe0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r93,[%value_in]; } .loc 1 99 0 setp.gt.f64 %r94,%r78,0d0000000000000000; @ ! %r94 bra $L27; .loc 1 100 0 fma.rn.f64 %r47,%r93,0d0000000000000000,%r93; mov.f64 %r48,%r93; bra $L11; $L27: .loc 1 102 0 neg.f64 %r96,%r93; fma.rn.f64 %r47,%r96,0d0000000000000000,%r93; mov.f64 %r48,%r96; $L11: .loc 1 103 0 st.f64 [%r70],%r47; st.f64 [%r70+8],%r48; bra $L1; $L8: .loc 1 106 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r75; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r100,[%value_in]; } setp.gt.f64 %r101,%r100,0d4010000000000000; @ ! %r101 bra $L28; $L15: .loc 1 107 0 mul.f64 %r51,%r75,0d3fd0000000000000; .loc 1 108 0 mul.f64 %r52,%r78,0d3fd0000000000000; .loc 1 109 0 mov.f64 %r55,0d4000000000000000; bra $L14; $L28: .loc 1 106 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r78; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r103,[%value_in]; } setp.gt.f64 %r104,%r103,0d4010000000000000; @ %r104 bra $L15; .loc 1 112 0 mul.f64 %r51,%r75,0d4350000000000000; .loc 1 113 0 mul.f64 %r52,%r78,0d4350000000000000; .loc 1 114 0 mov.f64 %r55,0d3e40000000000000; $L14: .loc 1 121 0 fma.rn.f64 %r110,%r52,0d0000000000000000,%r51; .loc 1 122 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r110; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),cabs,(%out_arg1,%out_arg2); ld.param.f64 %r113,[%value_in]; } .loc 1 123 0 setp.gt.f64 %r114,%r51,0d0000000000000000; @ ! %r114 bra $L29; .loc 1 124 0 mul.f64 %r116,%r51,0d3fe0000000000000; fma.rn.f64 %r117,%r113,0d3fe0000000000000,%r116; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r117; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r118,[%value_in]; } .loc 1 125 0 mul.f64 %r120,%r52,0d3fe0000000000000; div.rn.f64 %r121,%r120,%r118; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r121; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r122,[%value_in]; } mul.f64 %r53,%r122,%r55; .loc 1 126 0 mul.f64 %r54,%r55,%r118; bra $L18; $L29: .loc 1 128 0 mul.f64 %r124,%r51,0dbfe0000000000000; fma.rn.f64 %r38,%r113,0d3fe0000000000000,%r124; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r126,[%value_in]; } .loc 1 129 0 mul.f64 %r128,%r52,0d3fe0000000000000; div.rn.f64 %r129,%r128,%r126; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r129; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r130,[%value_in]; } mul.f64 %r54,%r130,%r55; .loc 1 130 0 mul.f64 %r53,%r55,%r126; $L18: mul.f64 %r69,%r53,0d0000000000000000; .loc 1 132 0 setp.lt.f64 %r131,%r52,0d0000000000000000; @ ! %r131 bra $L30; .loc 1 133 0 sub.f64 %r49,%r54,%r69; neg.f64 %r50,%r53; bra $L21; $L30: .loc 1 135 0 add.f64 %r49,%r54,%r69; mov.f64 %r50,%r53; $L21: .loc 1 136 0 st.f64 [%r70],%r49; st.f64 [%r70+8],%r50; $L1: .loc 1 137 0 ret; } lib_a-csqrtf.o/ 0 0 0 644 6444 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csqrtf .visible .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/csqrtf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sqrtf .extern .func (.param .f32 %value_out) sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cabsf .extern .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: csqrtf .visible .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r27; .reg .f32 %r40; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r68; .reg .u64 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r74; .reg .f32 %r77; .reg .pred %r78; .reg .pred %r79; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r83; .reg .pred %r84; .reg .f32 %r85; .reg .f32 %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r91; .reg .f32 %r93; .reg .pred %r94; .reg .f32 %r96; .reg .f32 %r100; .reg .pred %r101; .reg .f32 %r103; .reg .pred %r104; .reg .f32 %r110; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r124; .reg .f32 %r126; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .pred %r131; mov.u64 %r69,%ar0; mov.f32 %r70,%ar1; mov.f32 %r71,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r71; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r74,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r71; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r77,[%value_in]; } .loc 1 47 0 setp.neu.f32 %r78,%r77,0f00000000; @ %r78 bra $L2; .loc 1 48 0 setp.lt.f32 %r79,%r74,0f00000000; @ ! %r79 bra $L25; .loc 1 49 0 neg.f32 %r81,%r74; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r81; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r82,[%value_in]; } fma.rn.f32 %r83,%r82,0f00000000,0f00000000; .loc 1 50 0 st.f32 [%r69],%r83; st.f32 [%r69+4],%r82; bra $L1; $L25: .loc 1 51 0 setp.neu.f32 %r84,%r74,0f00000000; @ %r84 bra $L6; .loc 1 52 0 fma.rn.f32 %r85,%r77,0f00000000,0f00000000; st.f32 [%r69],%r85; st.f32 [%r69+4],%r77; bra $L1; $L6: .loc 1 54 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r74; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r87,[%value_in]; } fma.rn.f32 %r88,%r77,0f00000000,%r87; .loc 1 55 0 st.f32 [%r69],%r88; st.f32 [%r69+4],%r77; bra $L1; $L2: .loc 1 59 0 setp.neu.f32 %r89,%r74,0f00000000; @ %r89 bra $L7; .loc 1 60 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r77; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } .loc 1 61 0 mul.f32 %r27,%r91,0f3f000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r27; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r93,[%value_in]; } .loc 1 62 0 setp.gt.f32 %r94,%r77,0f00000000; @ ! %r94 bra $L26; .loc 1 63 0 fma.rn.f32 %r47,%r93,0f00000000,%r93; mov.f32 %r48,%r93; bra $L10; $L26: .loc 1 65 0 neg.f32 %r96,%r93; fma.rn.f32 %r47,%r96,0f00000000,%r93; mov.f32 %r48,%r96; $L10: .loc 1 66 0 st.f32 [%r69],%r47; st.f32 [%r69+4],%r48; bra $L1; $L7: .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r74; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r100,[%value_in]; } setp.gt.f32 %r101,%r100,0f40800000; @ ! %r101 bra $L27; $L14: .loc 1 71 0 mul.f32 %r51,%r74,0f3e800000; .loc 1 72 0 mul.f32 %r52,%r77,0f3e800000; .loc 1 73 0 mov.f32 %r55,0f40000000; bra $L13; $L27: .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r77; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r103,[%value_in]; } setp.gt.f32 %r104,%r103,0f40800000; @ %r104 bra $L14; .loc 1 76 0 mul.f32 %r51,%r74,0f4c800000; .loc 1 77 0 mul.f32 %r52,%r77,0f4c800000; .loc 1 78 0 mov.f32 %r55,0f39000000; $L13: .loc 1 85 0 fma.rn.f32 %r110,%r52,0f00000000,%r51; .loc 1 86 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r110; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r52; call (%value_in),cabsf,(%out_arg1,%out_arg2); ld.param.f32 %r113,[%value_in]; } .loc 1 87 0 setp.gt.f32 %r114,%r51,0f00000000; @ ! %r114 bra $L28; .loc 1 88 0 mul.f32 %r116,%r51,0f3f000000; fma.rn.f32 %r117,%r113,0f3f000000,%r116; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r117; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r118,[%value_in]; } .loc 1 89 0 mul.f32 %r120,%r52,0f3f000000; div.rn.f32 %r121,%r120,%r118; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r121; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r122,[%value_in]; } mul.f32 %r53,%r122,%r55; .loc 1 90 0 mul.f32 %r54,%r55,%r118; bra $L17; $L28: .loc 1 92 0 mul.f32 %r124,%r51,0fbf000000; fma.rn.f32 %r40,%r113,0f3f000000,%r124; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r126,[%value_in]; } .loc 1 93 0 mul.f32 %r128,%r52,0f3f000000; div.rn.f32 %r129,%r128,%r126; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r129; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r130,[%value_in]; } mul.f32 %r54,%r130,%r55; .loc 1 94 0 mul.f32 %r53,%r55,%r126; $L17: mul.f32 %r68,%r53,0f00000000; .loc 1 97 0 setp.lt.f32 %r131,%r52,0f00000000; @ ! %r131 bra $L29; .loc 1 98 0 sub.f32 %r49,%r54,%r68; neg.f32 %r50,%r53; bra $L20; $L29: .loc 1 100 0 add.f32 %r49,%r54,%r68; mov.f32 %r50,%r53; $L20: .loc 1 101 0 st.f32 [%r69],%r49; st.f32 [%r69+4],%r50; $L1: .loc 1 102 0 ret; } lib_a-ctan.o/ 0 0 0 644 4372 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: ctan .visible .func ctan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ctan.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctans .extern .func (.param .f64 %value_out) _ctans (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 8 .u64 $LC0[2] = {9221120237041090560,9218868437227405312 }; // BEGIN GLOBAL FUNCTION DEF: ctan .visible .func ctan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r50; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r55; .reg .pred %r56; .reg .f64 %r59; .reg .pred %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r65; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r71; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; mov.u64 %r39,%ar0; mov.f64 %r40,%ar1; mov.f64 %r41,%ar2; .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } add.f64 %r46,%r44,%r44; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r46; call (%value_in),cos,(%out_arg1); ld.param.f64 %r47,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } add.f64 %r52,%r50,%r50; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r53,[%value_in]; } add.f64 %r37,%r47,%r53; .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r55,[%value_in]; } setp.lt.f64 %r56,%r55,0d3fd0000000000000; @ ! %r56 bra $L2; .loc 1 81 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),_ctans,(%out_arg1,%out_arg2); ld.param.f64 %r59,[%value_in]; } mov.f64 %r37,%r59; $L2: .loc 1 83 0 setp.neu.f64 %r60,%r37,0d0000000000000000; @ %r60 bra $L4; .loc 1 86 0 ld.const.f64 %r61,[$LC0]; st.f64 [%r39],%r61; ld.const.f64 %r62,[$LC0+8]; st.f64 [%r39+8],%r62; bra $L1; $L4: .loc 1 89 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r65,[%value_in]; } add.f64 %r67,%r65,%r65; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r67; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r68,[%value_in]; } div.rn.f64 %r38,%r68,%r37; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r71,[%value_in]; } add.f64 %r73,%r71,%r71; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r74,[%value_in]; } div.rn.f64 %r75,%r74,%r37; fma.rn.f64 %r76,%r38,0d0000000000000000,%r75; .loc 1 90 0 st.f64 [%r39],%r76; st.f64 [%r39+8],%r38; $L1: .loc 1 91 0 ret; } lib_a-ctanf.o/ 0 0 0 644 4361 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: ctanf .visible .func ctanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ctanf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctansf .extern .func (.param .f32 %value_out) _ctansf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 4 .u32 $LC0[2] = {2143289344,2139095040 }; // BEGIN GLOBAL FUNCTION DEF: ctanf .visible .func ctanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r50; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r55; .reg .pred %r56; .reg .f32 %r59; .reg .pred %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r71; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; mov.u64 %r39,%ar0; mov.f32 %r40,%ar1; mov.f32 %r41,%ar2; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } add.f32 %r46,%r44,%r44; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } add.f32 %r52,%r50,%r50; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r52; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r53,[%value_in]; } add.f32 %r37,%r47,%r53; .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r55,[%value_in]; } setp.lt.f32 %r56,%r55,0f3e800000; @ ! %r56 bra $L2; .loc 1 48 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),_ctansf,(%out_arg1,%out_arg2); ld.param.f32 %r59,[%value_in]; } mov.f32 %r37,%r59; $L2: .loc 1 50 0 setp.neu.f32 %r60,%r37,0f00000000; @ %r60 bra $L4; .loc 1 53 0 ld.const.f32 %r61,[$LC0]; st.f32 [%r39],%r61; ld.const.f32 %r62,[$LC0+4]; st.f32 [%r39+4],%r62; bra $L1; $L4: .loc 1 56 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r65,[%value_in]; } add.f32 %r67,%r65,%r65; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } div.rn.f32 %r38,%r68,%r37; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r71,[%value_in]; } add.f32 %r73,%r71,%r71; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r73; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r74,[%value_in]; } div.rn.f32 %r75,%r74,%r37; fma.rn.f32 %r76,%r38,0f00000000,%r75; .loc 1 57 0 st.f32 [%r39],%r76; st.f32 [%r39+4],%r38; $L1: .loc 1 58 0 ret; } lib_a-ctanh.o/ 0 0 0 644 2772 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ctanh .visible .func ctanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ctanh.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ctanh .visible .func ctanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r22; .reg .f64 %r24; .reg .f64 %r32; .reg .f64 %r33; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r48; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r52; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r42,[%value_in]; } .loc 1 79 0 add.f64 %r22,%r39,%r39; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r22; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r44,[%value_in]; } add.f64 %r24,%r42,%r42; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),cos,(%out_arg1); ld.param.f64 %r46,[%value_in]; } add.f64 %r32,%r44,%r46; .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),sin,(%out_arg1); ld.param.f64 %r48,[%value_in]; } div.rn.f64 %r33,%r48,%r32; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r22; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r50,[%value_in]; } div.rn.f64 %r51,%r50,%r32; fma.rn.f64 %r52,%r33,0d0000000000000000,%r51; .loc 1 82 0 st.f64 [%r34],%r52; st.f64 [%r34+8],%r33; .loc 1 83 0 ret; } lib_a-ctanhf.o/ 0 0 0 644 2787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ctanhf .visible .func ctanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/complex/ctanhf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ctanhf .visible .func ctanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r22; .reg .f32 %r24; .reg .f32 %r32; .reg .f32 %r33; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r39; .reg .f32 %r42; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r48; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r42,[%value_in]; } .loc 1 46 0 add.f32 %r22,%r39,%r39; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r22; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } add.f32 %r24,%r42,%r42; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r46,[%value_in]; } add.f32 %r32,%r44,%r46; .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r48,[%value_in]; } div.rn.f32 %r33,%r48,%r32; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r22; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r50,[%value_in]; } div.rn.f32 %r51,%r50,%r32; fma.rn.f32 %r52,%r33,0f00000000,%r51; .loc 1 49 0 st.f32 [%r34],%r52; st.f32 [%r34+4],%r33; .loc 1 50 0 ret; } lib_a-e_acos.o/ 0 0 0 644 5559 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acos .visible .func (.param .f64 %value_out) __ieee754_acos (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_acos.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acos .visible .func (.param .f64 %value_out) __ieee754_acos (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r25; .reg .u32 %r58; .reg .u32 %r59; .reg .f64 %r60; .reg .f64 %r62; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r74; .reg .u64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .pred %r101; .reg .u32 %r102; .reg .u32 %r104; .reg .u32 %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .pred %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r123; .reg .f64 %r124; .reg .pred %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r144; .reg .u64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .f64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .f64 %r158; .reg .f64 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; mov.f64 %r98,%ar0; .loc 1 71 0 mov.b64 %r99,%r98; shr.u64 %r100,%r99,32; cvt.u32.u64 %r58,%r100; .loc 1 72 0 and.b32 %r59,%r58,2147483647; .loc 1 73 0 setp.le.s32 %r101,%r59,1072693247; @ %r101 bra $L2; .loc 1 76 0 add.u32 %r102,%r59,-1072693248; cvt.u32.u64 %r105,%r99; or.b32 %r104,%r102,%r105; setp.ne.u32 %r106,%r104,0; @ %r106 bra $L3; .loc 1 77 0 setp.gt.s32 %r107,%r58,0; .loc 1 78 0 selp.f64 %r97,0d0000000000000000,0d400921fb54442d18,%r107; bra $L1; $L3: .loc 1 80 0 sub.f64 %r25,%r98,%r98; div.rn.f64 %r97,%r25,%r25; bra $L1; $L2: .loc 1 82 0 setp.gt.s32 %r108,%r59,1071644671; @ %r108 bra $L5; .loc 1 83 0 setp.le.s32 %r109,%r59,1012924416; @ %r109 bra $L8; .loc 1 84 0 mul.f64 %r74,%r98,%r98; .loc 1 88 0 neg.f64 %r110,%r98; .loc 1 85 0 fma.rn.f64 %r111,%r74,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r112,%r111,%r74,0dbfa48228b5688f3b; fma.rn.f64 %r113,%r112,%r74,0d3fc9c1550e884455; fma.rn.f64 %r114,%r113,%r74,0dbfd4d61203eb6f7d; fma.rn.f64 %r115,%r114,%r74,0d3fc5555555555555; mul.f64 %r116,%r115,%r74; .loc 1 86 0 fma.rn.f64 %r117,%r74,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r118,%r117,%r74,0d40002ae59c598ac8; fma.rn.f64 %r119,%r118,%r74,0dc0033a271c8a2d4b; fma.rn.f64 %r120,%r119,%r74,0d3ff0000000000000; .loc 1 87 0 div.rn.f64 %r121,%r116,%r120; .loc 1 88 0 fma.rn.f64 %r122,%r110,%r121,0d3c91a62633145c07; sub.f64 %r123,%r98,%r122; mov.f64 %r124,0d3ff921fb54442d18; sub.f64 %r97,%r124,%r123; bra $L1; $L5: .loc 1 89 0 setp.ge.s32 %r125,%r58,0; @ %r125 bra $L6; .loc 1 90 0 add.f64 %r126,%r98,0d3ff0000000000000; mul.f64 %r68,%r126,0d3fe0000000000000; .loc 1 91 0 fma.rn.f64 %r127,%r68,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r128,%r127,%r68,0dbfa48228b5688f3b; fma.rn.f64 %r129,%r128,%r68,0d3fc9c1550e884455; fma.rn.f64 %r130,%r129,%r68,0dbfd4d61203eb6f7d; fma.rn.f64 %r131,%r130,%r68,0d3fc5555555555555; mul.f64 %r69,%r131,%r68; .loc 1 92 0 fma.rn.f64 %r132,%r68,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r133,%r132,%r68,0d40002ae59c598ac8; fma.rn.f64 %r134,%r133,%r68,0dc0033a271c8a2d4b; fma.rn.f64 %r70,%r134,%r68,0d3ff0000000000000; .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r68; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r136,[%value_in]; } .loc 1 94 0 div.rn.f64 %r137,%r69,%r70; .loc 1 95 0 fma.rn.f64 %r138,%r136,%r137,0dbc91a62633145c07; .loc 1 96 0 add.f64 %r139,%r138,%r136; fma.rn.f64 %r97,%r139,0dc000000000000000,0d400921fb54442d18; bra $L1; $L6: .loc 1 98 0 mov.f64 %r142,0d3ff0000000000000; sub.f64 %r141,%r142,%r98; mul.f64 %r60,%r141,0d3fe0000000000000; .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r60; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r144,[%value_in]; } .loc 1 101 0 mov.b64 %r96,%r144; and.b64 %r145,%r96,-4294967296; mov.b64 %r62,%r145; .loc 1 102 0 neg.f64 %r146,%r62; fma.rn.f64 %r147,%r146,%r62,%r60; add.f64 %r148,%r144,%r62; div.rn.f64 %r149,%r147,%r148; .loc 1 103 0 fma.rn.f64 %r150,%r60,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r151,%r150,%r60,0dbfa48228b5688f3b; fma.rn.f64 %r152,%r151,%r60,0d3fc9c1550e884455; fma.rn.f64 %r153,%r152,%r60,0dbfd4d61203eb6f7d; fma.rn.f64 %r154,%r153,%r60,0d3fc5555555555555; mul.f64 %r155,%r154,%r60; .loc 1 104 0 fma.rn.f64 %r156,%r60,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r157,%r156,%r60,0d40002ae59c598ac8; fma.rn.f64 %r158,%r157,%r60,0dc0033a271c8a2d4b; fma.rn.f64 %r159,%r158,%r60,0d3ff0000000000000; .loc 1 105 0 div.rn.f64 %r160,%r155,%r159; .loc 1 106 0 fma.rn.f64 %r161,%r144,%r160,%r149; .loc 1 107 0 add.f64 %r162,%r161,%r62; add.f64 %r97,%r162,%r162; bra $L1; $L8: .loc 1 83 0 mov.f64 %r97,0d3ff921fb54442d18; $L1: .loc 1 109 0 mov.f64 %value,%r97; st.param.f64 [%value_out],%value; ret; } lib_a-e_acosh.o/0 0 0 644 3289 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosh .visible .func (.param .f64 %value_out) __ieee754_acosh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_acosh.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acosh .visible .func (.param .f64 %value_out) __ieee754_acosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r22; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r42; .reg .f64 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .f64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .pred %r56; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r73; .reg .f64 %r74; mov.f64 %r43,%ar0; .loc 1 51 0 mov.b64 %r44,%r43; shr.u64 %r45,%r44,32; cvt.u32.u64 %r36,%r45; .loc 1 52 0 setp.gt.s32 %r46,%r36,1072693247; @ %r46 bra $L2; .loc 1 53 0 sub.f64 %r22,%r43,%r43; div.rn.f64 %r42,%r22,%r22; bra $L1; $L2: .loc 1 54 0 setp.le.s32 %r47,%r36,1102053375; @ %r47 bra $L4; .loc 1 55 0 setp.le.s32 %r48,%r36,2146435071; @ %r48 bra $L5; .loc 1 56 0 add.f64 %r42,%r43,%r43; bra $L1; $L5: .loc 1 58 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r43; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r50,[%value_in]; } add.f64 %r42,%r50,0d3fe62e42fefa39ef; bra $L1; $L4: .loc 1 59 0 add.u32 %r51,%r36,-1072693248; cvt.u32.u64 %r54,%r44; or.b32 %r53,%r51,%r54; setp.eq.u32 %r55,%r53,0; @ %r55 bra $L7; .loc 1 61 0 setp.le.s32 %r56,%r36,1073741824; @ %r56 bra $L6; .loc 1 63 0 fma.rn.f64 %r58,%r43,%r43,0dbff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r58; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r59,[%value_in]; } add.f64 %r61,%r59,%r43; mov.f64 %r63,0d3ff0000000000000; div.rn.f64 %r62,%r63,%r61; neg.f64 %r64,%r62; fma.rn.f64 %r65,%r43,0d4000000000000000,%r64; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r66,[%value_in]; } mov.f64 %r42,%r66; bra $L1; $L6: .loc 1 65 0 mov.f64 %r67,0d3ff0000000000000; sub.f64 %r37,%r43,%r67; .loc 1 66 0 mul.f64 %r69,%r37,%r37; fma.rn.f64 %r70,%r37,0d4000000000000000,%r69; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r70; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r71,[%value_in]; } add.f64 %r73,%r71,%r37; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r74,[%value_in]; } mov.f64 %r42,%r74; bra $L1; $L7: .loc 1 60 0 mov.f64 %r42,0d0000000000000000; $L1: .loc 1 68 0 mov.f64 %value,%r42; st.param.f64 [%value_out],%value; ret; } lib_a-e_asin.o/ 0 0 0 644 5201 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_asin .visible .func (.param .f64 %value_out) __ieee754_asin (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_asin.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_asin .visible .func (.param .f64 %value_out) __ieee754_asin (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r26; .reg .f64 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .f64 %r54; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r63; .reg .f64 %r65; .reg .u64 %r84; .reg .f64 %r85; .reg .f64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .pred %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r93; .reg .pred %r94; .reg .f64 %r95; .reg .pred %r96; .reg .pred %r97; .reg .f64 %r98; .reg .pred %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r124; .reg .pred %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .u64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r135; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r141; .reg .f64 %r142; .reg .pred %r143; mov.f64 %r86,%ar0; .loc 1 80 0 mov.b64 %r87,%r86; shr.u64 %r88,%r87,32; cvt.u32.u64 %r52,%r88; .loc 1 81 0 and.b32 %r53,%r52,2147483647; .loc 1 82 0 setp.le.s32 %r89,%r53,1072693247; @ %r89 bra $L2; .loc 1 85 0 add.u32 %r90,%r53,-1072693248; cvt.u32.u64 %r93,%r87; or.b32 %r92,%r90,%r93; setp.ne.u32 %r94,%r92,0; @ %r94 bra $L3; .loc 1 87 0 mul.f64 %r95,%r86,0d3c91a62633145c07; fma.rn.f64 %r85,%r86,0d3ff921fb54442d18,%r95; bra $L1; $L3: .loc 1 88 0 sub.f64 %r26,%r86,%r86; div.rn.f64 %r85,%r26,%r26; bra $L1; $L2: .loc 1 89 0 setp.gt.s32 %r96,%r53,1071644671; @ %r96 bra $L5; .loc 1 90 0 setp.gt.s32 %r97,%r53,1044381695; @ %r97 bra $L6; .loc 1 91 0 add.f64 %r98,%r86,0d7e37e43c8800759c; setp.gt.f64 %r99,%r98,0d3ff0000000000000; @ %r99 bra $L9; bra $L5; $L6: .loc 1 93 0 mul.f64 %r54,%r86,%r86; .loc 1 94 0 fma.rn.f64 %r100,%r54,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r101,%r100,%r54,0dbfa48228b5688f3b; fma.rn.f64 %r102,%r101,%r54,0d3fc9c1550e884455; fma.rn.f64 %r103,%r102,%r54,0dbfd4d61203eb6f7d; fma.rn.f64 %r104,%r103,%r54,0d3fc5555555555555; mul.f64 %r105,%r104,%r54; .loc 1 95 0 fma.rn.f64 %r106,%r54,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r107,%r106,%r54,0d40002ae59c598ac8; fma.rn.f64 %r108,%r107,%r54,0dc0033a271c8a2d4b; fma.rn.f64 %r109,%r108,%r54,0d3ff0000000000000; .loc 1 96 0 div.rn.f64 %r110,%r105,%r109; .loc 1 97 0 fma.rn.f64 %r85,%r86,%r110,%r86; bra $L1; $L5: .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r112,[%value_in]; } mov.f64 %r114,0d3ff0000000000000; sub.f64 %r113,%r114,%r112; .loc 1 102 0 mul.f64 %r59,%r113,0d3fe0000000000000; .loc 1 103 0 fma.rn.f64 %r115,%r59,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r116,%r115,%r59,0dbfa48228b5688f3b; fma.rn.f64 %r117,%r116,%r59,0d3fc9c1550e884455; fma.rn.f64 %r118,%r117,%r59,0dbfd4d61203eb6f7d; fma.rn.f64 %r119,%r118,%r59,0d3fc5555555555555; mul.f64 %r60,%r119,%r59; .loc 1 104 0 fma.rn.f64 %r120,%r59,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r121,%r120,%r59,0d40002ae59c598ac8; fma.rn.f64 %r122,%r121,%r59,0dc0033a271c8a2d4b; fma.rn.f64 %r61,%r122,%r59,0d3ff0000000000000; .loc 1 105 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r124,[%value_in]; } .loc 1 106 0 setp.le.s32 %r125,%r53,1072640818; @ %r125 bra $L7; .loc 1 107 0 div.rn.f64 %r126,%r60,%r61; .loc 1 108 0 fma.rn.f64 %r127,%r124,%r126,%r124; fma.rn.f64 %r128,%r127,0d4000000000000000,0dbc91a62633145c07; mov.f64 %r129,0d3ff921fb54442d18; sub.f64 %r85,%r129,%r128; bra $L8; $L7: .loc 1 111 0 mov.b64 %r84,%r124; and.b64 %r130,%r84,-4294967296; mov.b64 %r63,%r130; .loc 1 113 0 div.rn.f64 %r65,%r60,%r61; .loc 1 114 0 add.f64 %r131,%r124,%r124; .loc 1 112 0 neg.f64 %r132,%r63; fma.rn.f64 %r133,%r132,%r63,%r59; add.f64 %r134,%r124,%r63; div.rn.f64 %r135,%r133,%r134; .loc 1 114 0 fma.rn.f64 %r137,%r135,0dc000000000000000,0d3c91a62633145c07; neg.f64 %r138,%r137; fma.rn.f64 %r139,%r131,%r65,%r138; .loc 1 115 0 fma.rn.f64 %r141,%r132,0d4000000000000000,0d3fe921fb54442d18; .loc 1 116 0 sub.f64 %r51,%r139,%r141; mov.f64 %r142,0d3fe921fb54442d18; sub.f64 %r85,%r142,%r51; $L8: .loc 1 118 0 setp.gt.s32 %r143,%r52,0; @ %r143 bra $L1; neg.f64 %r85,%r85; bra $L1; $L9: .loc 1 91 0 mov.f64 %r85,%r86; $L1: .loc 1 119 0 mov.f64 %value,%r85; st.param.f64 [%value_out],%value; ret; } lib_a-e_atan2.o/0 0 0 644 6206 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2 .visible .func (.param .f64 %value_out) __ieee754_atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_atan2.c" // BEGIN GLOBAL FUNCTION DECL: atan .extern .func (.param .f64 %value_out) atan (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atan2 .visible .func (.param .f64 %value_out) __ieee754_atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .f64 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .pred %r90; .reg .pred %r91; .reg .pred %r92; .reg .u32 %r93; .reg .pred %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .u32 %r106; .reg .pred %r107; .reg .u32 %r109; .reg .u32 %r111; .reg .u32 %r112; .reg .u16 %r114; .reg .u16 %r115; .reg .u16 %r116; .reg .u32 %r117; .reg .u16 %r118; .reg .pred %r119; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r124; .reg .pred %r125; .reg .pred %r126; .reg .pred %r127; .reg .u64 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .f64 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; mov.f64 %r63,%ar0; mov.f64 %r64,%ar1; .loc 1 69 0 mov.b64 %r65,%r64; shr.u64 %r66,%r65,32; cvt.u32.u64 %r50,%r66; cvt.u32.u64 %r56,%r65; .loc 1 70 0 and.b32 %r51,%r50,2147483647; .loc 1 73 0 neg.s32 %r68,%r56; or.b32 %r69,%r68,%r56; shr.u32 %r70,%r69,31; or.b32 %r71,%r70,%r51; setp.gt.u32 %r72,%r71,2146435072; @ %r72 bra $L2; mov.b64 %r73,%r63; shr.u64 %r74,%r73,32; cvt.u32.u64 %r57,%r74; cvt.u32.u64 %r58,%r73; .loc 1 72 0 and.b32 %r53,%r57,2147483647; .loc 1 74 0 neg.s32 %r76,%r58; or.b32 %r77,%r76,%r58; shr.u32 %r78,%r77,31; or.b32 %r79,%r78,%r53; .loc 1 73 0 setp.le.u32 %r80,%r79,2146435072; @ %r80 bra $L3; $L2: .loc 1 75 0 add.f64 %r62,%r64,%r63; bra $L1; $L3: .loc 1 76 0 add.u32 %r81,%r50,-1072693248; or.b32 %r82,%r81,%r56; setp.ne.u32 %r83,%r82,0; @ %r83 bra $L5; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r63; call (%value_in),atan,(%out_arg1); ld.param.f64 %r85,[%value_in]; } mov.f64 %r62,%r85; bra $L1; $L5: .loc 1 77 0 shr.s32 %r86,%r50,30; and.b32 %r87,%r86,2; shr.u32 %r88,%r57,31; or.b32 %r54,%r87,%r88; .loc 1 80 0 or.b32 %r89,%r53,%r58; setp.ne.u32 %r90,%r89,0; @ %r90 bra $L6; .loc 1 81 0 setp.eq.u32 %r91,%r54,2; @ %r91 bra $L23; setp.eq.u32 %r92,%r54,3; .loc 1 83 0 selp.f64 %r62,0dc00921fb54442d18,%r63,%r92; bra $L1; $L6: .loc 1 89 0 or.b32 %r93,%r51,%r56; setp.ne.u32 %r94,%r93,0; @ %r94 bra $L9; setp.ge.s32 %r95,%r57,0; selp.f64 %r62,0d3ff921fb54442d18,0dbff921fb54442d18,%r95; bra $L1; $L9: .loc 1 92 0 setp.ne.u32 %r96,%r51,2146435072; @ %r96 bra $L10; .loc 1 93 0 setp.ne.u32 %r97,%r53,2146435072; @ %r97 bra $L11; .loc 1 94 0 setp.eq.u32 %r98,%r54,2; @ %r98 bra $L12; setp.eq.u32 %r99,%r54,3; @ %r99 bra $L13; setp.eq.u32 %r100,%r54,1; .loc 1 95 0 selp.f64 %r62,0dbfe921fb54442d18,0d3fe921fb54442d18,%r100; bra $L1; $L12: .loc 1 97 0 mov.f64 %r62,0d4002d97c7f3321d2; bra $L1; $L13: .loc 1 98 0 mov.f64 %r62,0dc002d97c7f3321d2; bra $L1; $L11: .loc 1 101 0 setp.eq.u32 %r101,%r54,2; @ %r101 bra $L26; setp.eq.u32 %r102,%r54,3; @ %r102 bra $L16; setp.eq.u32 %r103,%r54,1; .loc 1 102 0 selp.f64 %r62,0d8000000000000000,0d0000000000000000,%r103; bra $L1; $L16: .loc 1 85 0 mov.f64 %r62,0dc00921fb54442d18; bra $L1; $L10: .loc 1 110 0 setp.ne.u32 %r104,%r53,2146435072; @ %r104 bra $L18; setp.ge.s32 %r105,%r57,0; .loc 1 89 0 selp.f64 %r62,0d3ff921fb54442d18,0dbff921fb54442d18,%r105; bra $L1; $L18: .loc 1 113 0 sub.u32 %r106,%r53,%r51; shr.s32 %r60,%r106,20; .loc 1 114 0 setp.gt.s32 %r107,%r60,60; @ %r107 bra $L28; .loc 1 115 0 shr.u32 %r109,%r50,31; set.u32.lt.s32 %r111,%r60,-60; neg.s32 %r112,%r111; cvt.u16.u32 %r115,%r109; cvt.u16.u32 %r116,%r112; and.b16 %r114,%r115,%r116; cvt.u32.u16 %r117,%r114; cvt.u16.u8 %r118,%r117; setp.ne.u16 %r119,%r118,0; @ %r119 bra $L29; .loc 1 116 0 div.rn.f64 %r121,%r63,%r64; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r121; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r122,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r122; call (%value_in),atan,(%out_arg1); ld.param.f64 %r124,[%value_in]; } mov.f64 %r62,%r124; bra $L19; $L28: .loc 1 114 0 mov.f64 %r62,0d3ff921fb54442d18; bra $L19; $L29: .loc 1 115 0 mov.f64 %r62,0d0000000000000000; $L19: .loc 1 117 0 setp.eq.u32 %r125,%r54,1; @ %r125 bra $L21; setp.eq.u32 %r126,%r54,2; @ %r126 bra $L22; setp.eq.u32 %r127,%r54,0; @ ! %r127 bra $L33; bra $L1; $L21: .loc 1 122 0 mov.b64 %r61,%r62; shr.u64 %r129,%r61,32; cvt.u32.u64 %r131,%r129; add.u32 %r130,%r131,-2147483648; cvt.u64.u32 %r132,%r130; shl.b64 %r133,%r132,32; and.b64 %r134,%r61,4294967295; or.b64 %r135,%r134,%r133; mov.b64 %r62,%r135; .loc 1 124 0 bra $L1; $L22: .loc 1 125 0 mov.f64 %r137,0d3ca1a62633145c07; sub.f64 %r136,%r62,%r137; mov.f64 %r138,0d400921fb54442d18; sub.f64 %r62,%r138,%r136; bra $L1; $L33: .loc 1 127 0 mov.f64 %r140,0d3ca1a62633145c07; sub.f64 %r139,%r62,%r140; mov.f64 %r141,0d400921fb54442d18; sub.f64 %r62,%r139,%r141; bra $L1; $L23: .loc 1 84 0 mov.f64 %r62,0d400921fb54442d18; bra $L1; $L26: mov.f64 %r62,0d400921fb54442d18; $L1: .loc 1 129 0 mov.f64 %value,%r62; st.param.f64 [%value_out],%value; ret; } lib_a-e_atanh.o/0 0 0 644 3122 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanh .visible .func (.param .f64 %value_out) __ieee754_atanh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_atanh.c" // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atanh .visible .func (.param .f64 %value_out) __ieee754_atanh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r27; .reg .u32 %r38; .reg .u32 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .u32 %r43; .reg .f64 %r45; .reg .f64 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .pred %r77; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r81; .reg .u64 %r82; mov.f64 %r46,%ar0; .loc 1 59 0 mov.b64 %r47,%r46; shr.u64 %r48,%r47,32; cvt.u32.u64 %r38,%r48; cvt.u32.u64 %r43,%r47; .loc 1 60 0 and.b32 %r39,%r38,2147483647; .loc 1 61 0 neg.s32 %r50,%r43; or.b32 %r51,%r50,%r43; shr.u32 %r52,%r51,31; or.b32 %r53,%r52,%r39; setp.le.u32 %r54,%r53,1072693248; @ %r54 bra $L2; .loc 1 62 0 sub.f64 %r27,%r46,%r46; div.rn.f64 %r45,%r27,%r27; bra $L1; $L2: .loc 1 63 0 setp.ne.u32 %r55,%r39,1072693248; @ %r55 bra $L4; .loc 1 64 0 div.rn.f64 %r45,%r46,0d0000000000000000; bra $L1; $L4: .loc 1 65 0 setp.gt.s32 %r56,%r39,1043333119; @ %r56 bra $L5; add.f64 %r57,%r46,0d7e37e43c8800759c; setp.gt.f64 %r58,%r57,0d0000000000000000; @ %r58 bra $L10; bra $L11; $L5: .loc 1 66 0 cvt.u64.u32 %r59,%r39; shl.b64 %r60,%r59,32; and.b64 %r61,%r47,4294967295; or.b64 %r62,%r61,%r60; mov.b64 %r40,%r62; .loc 1 67 0 setp.gt.s32 %r63,%r39,1071644671; @ %r63 bra $L7; $L9: .loc 1 68 0 add.f64 %r41,%r40,%r40; .loc 1 69 0 mul.f64 %r65,%r41,%r40; mov.f64 %r67,0d3ff0000000000000; sub.f64 %r66,%r67,%r40; div.rn.f64 %r68,%r65,%r66; add.f64 %r69,%r68,%r41; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r69; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r70,[%value_in]; } mul.f64 %r45,%r70,0d3fe0000000000000; bra $L8; $L7: .loc 1 71 0 add.f64 %r72,%r40,%r40; mov.f64 %r74,0d3ff0000000000000; sub.f64 %r73,%r74,%r40; div.rn.f64 %r75,%r72,%r73; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r75; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r76,[%value_in]; } mul.f64 %r45,%r76,0d3fe0000000000000; $L8: .loc 1 72 0 setp.ge.s32 %r77,%r38,0; @ %r77 bra $L1; neg.f64 %r45,%r45; bra $L1; $L10: .loc 1 65 0 mov.f64 %r45,%r46; bra $L1; $L11: .loc 1 66 0 cvt.u64.u32 %r79,%r39; shl.b64 %r80,%r79,32; and.b64 %r81,%r47,4294967295; or.b64 %r82,%r81,%r80; mov.b64 %r40,%r82; bra $L9; $L1: .loc 1 73 0 mov.f64 %value,%r45; st.param.f64 [%value_out],%value; ret; } lib_a-e_cosh.o/ 0 0 0 644 4181 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_cosh .visible .func (.param .f64 %value_out) __ieee754_cosh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_cosh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_cosh .visible .func (.param .f64 %value_out) __ieee754_cosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r43; .reg .f64 %r44; .reg .u64 %r45; .reg .u64 %r46; .reg .pred %r47; .reg .pred %r48; .reg .f64 %r50; .reg .f64 %r52; .reg .pred %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .pred %r57; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .pred %r64; .reg .f64 %r66; .reg .f64 %r68; .reg .pred %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .u16 %r78; .reg .u16 %r79; .reg .u16 %r80; .reg .u32 %r81; .reg .u16 %r82; .reg .pred %r83; .reg .f64 %r85; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r90; mov.f64 %r44,%ar0; .loc 1 57 0 mov.b64 %r45,%r44; shr.u64 %r46,%r45,32; cvt.u32.u64 %r35,%r46; .loc 1 58 0 and.b32 %r36,%r35,2147483647; .loc 1 61 0 setp.le.s32 %r47,%r36,2146435071; @ %r47 bra $L2; mul.f64 %r43,%r44,%r44; bra $L1; $L2: .loc 1 64 0 setp.gt.s32 %r48,%r36,1071001154; @ %r48 bra $L4; .loc 1 65 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r50,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r52,[%value_in]; } .loc 1 66 0 add.f64 %r43,%r52,0d3ff0000000000000; .loc 1 67 0 setp.le.s32 %r53,%r36,1015021567; @ %r53 bra $L1; .loc 1 68 0 mul.f64 %r54,%r52,%r52; add.f64 %r55,%r43,%r43; div.rn.f64 %r56,%r54,%r55; add.f64 %r43,%r56,0d3ff0000000000000; bra $L1; $L4: .loc 1 72 0 setp.gt.s32 %r57,%r36,1077280767; @ %r57 bra $L5; .loc 1 73 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r59,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r61,[%value_in]; } .loc 1 74 0 mov.f64 %r63,0d3fe0000000000000; div.rn.f64 %r62,%r63,%r61; fma.rn.f64 %r43,%r61,0d3fe0000000000000,%r62; bra $L1; $L5: .loc 1 78 0 setp.gt.s32 %r64,%r36,1082535489; @ %r64 bra $L6; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r66,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r68,[%value_in]; } mul.f64 %r43,%r68,0d3fe0000000000000; bra $L1; $L6: .loc 1 82 0 setp.le.s32 %r69,%r36,1082536909; @ %r69 bra $L7; .loc 1 83 0 set.u32.eq.u32 %r71,%r36,1082536910; neg.s32 %r72,%r71; cvt.u32.u64 %r75,%r45; set.u32.le.u32 %r76,%r75,-1883637635; neg.s32 %r77,%r76; cvt.u16.u32 %r79,%r72; cvt.u16.u32 %r80,%r77; and.b16 %r78,%r79,%r80; .loc 1 82 0 cvt.u32.u16 %r81,%r78; cvt.u16.u8 %r82,%r81; setp.eq.u16 %r83,%r82,0; @ %r83 bra $L8; $L7: .loc 1 84 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r85,[%value_in]; } mul.f64 %r87,%r85,0d3fe0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r87; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r88,[%value_in]; } .loc 1 85 0 mul.f64 %r89,%r88,0d3fe0000000000000; .loc 1 86 0 mul.f64 %r43,%r89,%r88; bra $L1; $L8: .loc 1 90 0 mov.f64 %r90,0d7e37e43c8800759c; mul.f64 %r43,%r90,0d7e37e43c8800759c; $L1: .loc 1 91 0 mov.f64 %value,%r43; st.param.f64 [%value_out],%value; ret; } lib_a-e_exp.o/ 0 0 0 644 5566 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .visible .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_exp.c" // BEGIN VAR DEF: ln2LO .const .align 8 .u64 ln2LO[2] = {4461442080421002358,-4761929956433773450 }; // BEGIN VAR DEF: halF .const .align 8 .u64 halF[2] = {4602678819172646912,-4620693217682128896 }; // BEGIN VAR DEF: ln2HI .const .align 8 .u64 ln2HI[2] = {4604418534311723008,-4618953502543052800 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_exp .visible .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .u32 %r53; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r64; .reg .u32 %r65; .reg .f64 %r68; .reg .f64 %r69; .reg .u64 %r70; .reg .u64 %r71; .reg .pred %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .f64 %r81; .reg .pred %r82; .reg .pred %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .f64 %r89; .reg .u64 %r90; .reg .u64 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .pred %r103; .reg .f64 %r104; .reg .pred %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .pred %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .pred %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .u32 %r133; .reg .u32 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; mov.f64 %r69,%ar0; mov.b64 %r70,%r69; shr.u64 %r71,%r70,32; cvt.u32.u64 %r53,%r71; .loc 1 116 0 shr.u32 %r22,%r53,31; .loc 1 117 0 and.b32 %r52,%r53,2147483647; .loc 1 120 0 setp.le.u32 %r72,%r52,1082535489; @ %r72 bra $L2; .loc 1 121 0 setp.le.u32 %r73,%r52,2146435071; @ %r73 bra $L3; .loc 1 124 0 and.b32 %r74,%r53,1048575; cvt.u32.u64 %r77,%r70; or.b32 %r76,%r74,%r77; setp.eq.u32 %r78,%r76,0; @ %r78 bra $L4; .loc 1 125 0 add.f64 %r68,%r69,%r69; bra $L1; $L4: .loc 1 126 0 setp.ne.u32 %r79,%r22,0; selp.f64 %r68,0d0000000000000000,%r69,%r79; bra $L1; $L3: .loc 1 128 0 setp.gt.f64 %r80,%r69,0d40862e42fefa39ef; @ ! %r80 bra $L22; mov.f64 %r81,0d7e37e43c8800759c; mul.f64 %r68,%r81,0d7e37e43c8800759c; bra $L1; $L22: .loc 1 129 0 setp.lt.f64 %r82,%r69,0dc0874910d52d3051; @ ! %r82 bra $L10; bra $L17; $L2: .loc 1 133 0 setp.le.u32 %r83,%r52,1071001154; @ %r83 bra $L9; .loc 1 134 0 setp.gt.u32 %r84,%r52,1072734897; @ %r84 bra $L10; .loc 1 135 0 cvta.const.u64 %r85,ln2HI; cvt.s64.s32 %r86,%r22; shl.b64 %r87,%r86,3; add.u64 %r88,%r85,%r87; ld.f64 %r89,[%r88]; sub.f64 %r48,%r69,%r89; cvta.const.u64 %r90,ln2LO; add.u64 %r93,%r90,%r87; ld.f64 %r49,[%r93]; mov.u32 %r95,1; sub.u32 %r94,%r95,%r22; sub.u32 %r50,%r94,%r22; bra $L11; $L10: .loc 1 137 0 cvta.const.u64 %r96,halF; cvt.s64.s32 %r97,%r22; shl.b64 %r98,%r97,3; add.u64 %r99,%r96,%r98; ld.f64 %r101,[%r99]; fma.rn.f64 %r100,%r69,0d3ff71547652b82fe,%r101; cvt.rzi.s32.f64 %r50,%r100; .loc 1 138 0 cvt.rn.f64.s32 %r55,%r50; .loc 1 139 0 fma.rn.f64 %r48,%r55,0dbfe62e42fee00000,%r69; .loc 1 140 0 mul.f64 %r49,%r55,0d3dea39ef35793c76; $L11: .loc 1 142 0 sub.f64 %r69,%r48,%r49; bra $L12; $L9: .loc 1 144 0 setp.gt.u32 %r103,%r52,1043333119; @ %r103 bra $L18; .loc 1 145 0 add.f64 %r104,%r69,0d7e37e43c8800759c; setp.gt.f64 %r105,%r104,0d3ff0000000000000; @ ! %r105 bra $L23; add.f64 %r68,%r69,0d3ff0000000000000; bra $L1; $L18: .loc 1 112 0 mov.u32 %r50,0; bra $L12; $L23: mov.u32 %r50,0; $L12: .loc 1 149 0 mul.f64 %r56,%r69,%r69; .loc 1 150 0 fma.rn.f64 %r106,%r56,0d3e66376972bea4d0,0dbebbbd41c5d26bf1; fma.rn.f64 %r107,%r106,%r56,0d3f11566aaf25de2c; fma.rn.f64 %r108,%r107,%r56,0dbf66c16c16bebd93; fma.rn.f64 %r109,%r108,%r56,0d3fc555555555553e; neg.f64 %r110,%r109; fma.rn.f64 %r57,%r110,%r56,%r69; mul.f64 %r64,%r69,%r57; .loc 1 151 0 setp.ne.u32 %r111,%r50,0; @ %r111 bra $L14; mov.f64 %r113,0d4000000000000000; sub.f64 %r112,%r57,%r113; div.rn.f64 %r114,%r64,%r112; sub.f64 %r115,%r114,%r69; mov.f64 %r116,0d3ff0000000000000; sub.f64 %r68,%r116,%r115; bra $L1; $L14: .loc 1 152 0 mov.f64 %r118,0d4000000000000000; sub.f64 %r117,%r118,%r57; div.rn.f64 %r119,%r64,%r117; sub.f64 %r120,%r49,%r119; sub.f64 %r121,%r120,%r48; mov.f64 %r122,0d3ff0000000000000; sub.f64 %r58,%r122,%r121; mov.b64 %r123,%r58; shr.u64 %r124,%r123,32; cvt.u32.u64 %r65,%r124; .loc 1 153 0 setp.lt.s32 %r125,%r50,-1021; @ %r125 bra $L15; .loc 1 156 0 shl.b32 %r126,%r50,20; add.u32 %r127,%r126,%r65; cvt.u64.u32 %r128,%r127; shl.b64 %r129,%r128,32; and.b64 %r130,%r123,4294967295; or.b64 %r131,%r130,%r129; mov.b64 %r68,%r131; .loc 1 157 0 bra $L1; $L15: .loc 1 161 0 add.u32 %r132,%r50,1000; shl.b32 %r133,%r132,20; add.u32 %r134,%r133,%r65; cvt.u64.u32 %r135,%r134; shl.b64 %r136,%r135,32; and.b64 %r137,%r123,4294967295; or.b64 %r138,%r137,%r136; mov.b64 %r59,%r138; .loc 1 162 0 mul.f64 %r68,%r59,0d0170000000000000; bra $L1; $L17: .loc 1 126 0 mov.f64 %r68,0d0000000000000000; $L1: .loc 1 164 0 mov.f64 %value,%r68; st.param.f64 [%value_out],%value; ret; } lib_a-e_fmod.o/ 0 0 0 644 9870 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmod .visible .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_fmod.c" // BEGIN VAR DEF: Zero .const .align 8 .u64 Zero[2] = {0,-9223372036854775808 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_fmod .visible .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r45; .reg .u32 %r53; .reg .u32 %r61; .reg .u32 %r94; .reg .u32 %r101; .reg .u32 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r129; .reg .u32 %r131; .reg .u32 %r132; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r142; .reg .u64 %r143; .reg .u32 %r145; .reg .u32 %r147; .reg .u32 %r148; .reg .u32 %r150; .reg .u32 %r151; .reg .u16 %r152; .reg .u16 %r153; .reg .u16 %r154; .reg .u32 %r155; .reg .u16 %r156; .reg .pred %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .pred %r162; .reg .pred %r164; .reg .u32 %r166; .reg .u32 %r167; .reg .u32 %r169; .reg .u32 %r170; .reg .u16 %r171; .reg .u16 %r172; .reg .u16 %r173; .reg .u32 %r174; .reg .u16 %r175; .reg .pred %r176; .reg .pred %r177; .reg .u64 %r178; .reg .u32 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .pred %r183; .reg .pred %r184; .reg .pred %r185; .reg .pred %r187; .reg .pred %r189; .reg .u32 %r190; .reg .pred %r191; .reg .pred %r192; .reg .pred %r193; .reg .pred %r195; .reg .pred %r197; .reg .u32 %r198; .reg .pred %r199; .reg .u32 %r200; .reg .pred %r201; .reg .u32 %r202; .reg .u32 %r203; .reg .u32 %r204; .reg .u32 %r205; .reg .u32 %r206; .reg .u32 %r208; .reg .pred %r209; .reg .u32 %r210; .reg .u32 %r211; .reg .u32 %r212; .reg .u32 %r213; .reg .u32 %r214; .reg .pred %r215; .reg .pred %r216; .reg .u32 %r217; .reg .u32 %r218; .reg .u32 %r220; .reg .pred %r221; .reg .u64 %r222; .reg .u32 %r223; .reg .u64 %r224; .reg .u64 %r225; .reg .u64 %r226; .reg .u32 %r227; .reg .u32 %r228; .reg .pred %r230; .reg .pred %r231; .reg .pred %r232; .reg .u32 %r233; .reg .pred %r234; .reg .pred %r235; .reg .u64 %r236; .reg .u32 %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u32 %r241; .reg .u32 %r242; .reg .pred %r244; .reg .u32 %r246; .reg .u32 %r247; .reg .u32 %r248; .reg .u32 %r249; .reg .u32 %r250; .reg .u64 %r251; .reg .u64 %r255; .reg .u64 %r256; .reg .u64 %r257; .reg .u32 %r258; .reg .pred %r259; .reg .u32 %r260; .reg .u32 %r261; .reg .u32 %r262; .reg .pred %r263; .reg .u32 %r264; .reg .u32 %r265; .reg .u32 %r266; .reg .u32 %r267; .reg .u64 %r268; .reg .u64 %r272; .reg .u64 %r273; .reg .u64 %r274; .reg .pred %r276; mov.f64 %r138,%ar0; mov.f64 %r139,%ar1; .loc 1 40 0 mov.b64 %r140,%r138; shr.u64 %r141,%r140,32; cvt.u32.u64 %r114,%r141; .loc 1 41 0 mov.b64 %r142,%r139; shr.u64 %r143,%r142,32; cvt.u32.u64 %r115,%r143; cvt.u32.u64 %r113,%r142; .loc 1 43 0 and.b32 %r117,%r114,2147483647; .loc 1 44 0 and.b32 %r118,%r115,2147483647; .loc 1 47 0 or.b32 %r145,%r118,%r113; set.u32.eq.u32 %r147,%r145,0; neg.s32 %r148,%r147; set.u32.gt.s32 %r150,%r117,2146435071; neg.s32 %r151,%r150; cvt.u16.u32 %r153,%r148; cvt.u16.u32 %r154,%r151; or.b16 %r152,%r153,%r154; cvt.u32.u16 %r155,%r152; cvt.u16.u8 %r156,%r155; setp.ne.u16 %r157,%r156,0; @ %r157 bra $L2; .loc 1 48 0 neg.s32 %r158,%r113; or.b32 %r159,%r158,%r113; shr.u32 %r160,%r159,31; or.b32 %r161,%r160,%r118; .loc 1 47 0 setp.le.u32 %r162,%r161,2146435072; @ %r162 bra $L3; $L2: .loc 1 49 0 mul.f64 %r45,%r138,%r139; div.rn.f64 %r137,%r45,%r45; bra $L1; $L3: cvt.u32.u64 %r110,%r140; .loc 1 42 0 and.b32 %r116,%r114,-2147483648; .loc 1 50 0 setp.gt.s32 %r164,%r117,%r118; @ %r164 bra $L5; .loc 1 51 0 set.u32.lt.s32 %r166,%r117,%r118; neg.s32 %r167,%r166; set.u32.lt.u32 %r169,%r110,%r113; neg.s32 %r170,%r169; cvt.u16.u32 %r172,%r167; cvt.u16.u32 %r173,%r170; or.b16 %r171,%r172,%r173; cvt.u32.u16 %r174,%r171; cvt.u16.u8 %r175,%r174; setp.ne.u16 %r176,%r175,0; @ %r176 bra $L37; .loc 1 52 0 setp.ne.u32 %r177,%r110,%r113; @ %r177 bra $L5; .loc 1 53 0 cvta.const.u64 %r178,Zero; shr.u32 %r179,%r116,31; cvt.u64.u32 %r180,%r179; shl.b64 %r181,%r180,3; add.u64 %r182,%r178,%r181; ld.f64 %r137,[%r182]; bra $L1; $L5: .loc 1 57 0 setp.gt.s32 %r183,%r117,1048575; @ %r183 bra $L6; .loc 1 58 0 setp.ne.u32 %r184,%r117,0; @ %r184 bra $L7; .loc 1 59 0 mov.u32 %r121,%r110; setp.le.s32 %r185,%r110,0; @ %r185 bra $L38; mov.u32 %r119,-1043; $L9: add.u32 %r119,%r119,-1; add.u32 %r121,%r121,%r121; setp.gt.s32 %r187,%r121,0; @ %r187 bra $L9; bra $L8; $L7: .loc 1 61 0 shl.b32 %r120,%r117,11; mov.u32 %r119,-1022; $L10: add.u32 %r119,%r119,-1; add.u32 %r120,%r120,%r120; setp.gt.s32 %r189,%r120,0; @ %r189 bra $L10; bra $L8; $L6: .loc 1 63 0 shr.s32 %r190,%r117,20; add.u32 %r119,%r190,-1023; bra $L8; $L38: .loc 1 59 0 mov.u32 %r119,-1043; $L8: .loc 1 66 0 setp.gt.s32 %r191,%r118,1048575; @ %r191 bra $L11; .loc 1 67 0 setp.ne.u32 %r192,%r118,0; @ %r192 bra $L12; .loc 1 68 0 mov.u32 %r124,%r113; setp.le.s32 %r193,%r113,0; @ %r193 bra $L39; mov.u32 %r131,-1043; $L14: add.u32 %r131,%r131,-1; add.u32 %r124,%r124,%r124; setp.gt.s32 %r195,%r124,0; @ %r195 bra $L14; bra $L13; $L12: .loc 1 70 0 shl.b32 %r122,%r118,11; mov.u32 %r131,-1022; $L15: add.u32 %r131,%r131,-1; add.u32 %r122,%r122,%r122; setp.gt.s32 %r197,%r122,0; @ %r197 bra $L15; bra $L13; $L11: .loc 1 72 0 shr.s32 %r198,%r118,20; add.u32 %r131,%r198,-1023; bra $L13; $L39: .loc 1 68 0 mov.u32 %r131,-1043; $L13: .loc 1 75 0 setp.lt.s32 %r199,%r119,-1022; @ %r199 bra $L16; .loc 1 76 0 and.b32 %r53,%r114,1048575; or.b32 %r105,%r53,1048576; bra $L17; $L16: .loc 1 78 0 mov.u32 %r200,-1022; sub.u32 %r125,%r200,%r119; .loc 1 79 0 setp.gt.s32 %r201,%r125,31; @ %r201 bra $L18; .loc 1 80 0 add.u32 %r202,%r119,1054; shr.u32 %r203,%r110,%r202; shl.b32 %r204,%r117,%r125; or.b32 %r105,%r203,%r204; .loc 1 81 0 shl.b32 %r110,%r110,%r125; bra $L17; $L18: .loc 1 83 0 mov.u32 %r206,-1054; sub.u32 %r205,%r206,%r119; shl.b32 %r105,%r110,%r205; .loc 1 84 0 mov.u32 %r110,0; $L17: .loc 1 87 0 setp.lt.s32 %r276,%r131,-1022; @ %r276 bra $L19; .loc 1 88 0 and.b32 %r61,%r115,1048575; or.b32 %r106,%r61,1048576; bra $L20; $L19: .loc 1 90 0 mov.u32 %r208,-1022; sub.u32 %r126,%r208,%r131; .loc 1 91 0 setp.gt.s32 %r209,%r126,31; @ %r209 bra $L21; .loc 1 92 0 add.u32 %r210,%r131,1054; shr.u32 %r211,%r113,%r210; shl.b32 %r212,%r118,%r126; or.b32 %r106,%r211,%r212; .loc 1 93 0 shl.b32 %r113,%r113,%r126; bra $L20; $L21: .loc 1 95 0 mov.u32 %r214,-1054; sub.u32 %r213,%r214,%r131; shl.b32 %r106,%r113,%r213; .loc 1 96 0 mov.u32 %r113,0; $L20: .loc 1 101 0 sub.u32 %r132,%r119,%r131; .loc 1 102 0 bra $L22; $L27: .loc 1 103 0 setp.ge.u32 %r215,%r110,%r113; @ %r215 bra $L23; add.u32 %r107,%r107,-1; $L23: .loc 1 104 0 setp.ge.s32 %r216,%r107,0; @ %r216 bra $L24; add.u32 %r217,%r105,%r105; shr.u32 %r218,%r110,31; add.u32 %r105,%r217,%r218; add.u32 %r110,%r110,%r110; bra $L25; $L24: .loc 1 106 0 or.b32 %r220,%r107,%r111; setp.ne.u32 %r221,%r220,0; @ %r221 bra $L26; .loc 1 107 0 cvta.const.u64 %r222,Zero; shr.u32 %r223,%r116,31; cvt.u64.u32 %r224,%r223; shl.b64 %r225,%r224,3; add.u64 %r226,%r222,%r225; ld.f64 %r137,[%r226]; bra $L1; $L26: .loc 1 108 0 add.u32 %r227,%r107,%r107; shr.u32 %r228,%r111,31; add.u32 %r105,%r227,%r228; add.u32 %r110,%r111,%r111; $L25: add.u32 %r132,%r132,-1; $L22: sub.u32 %r107,%r105,%r106; sub.u32 %r111,%r110,%r113; .loc 1 102 0 setp.ne.u32 %r230,%r132,0; @ %r230 bra $L27; .loc 1 111 0 setp.ge.u32 %r231,%r110,%r113; @ %r231 bra $L28; add.u32 %r107,%r107,-1; $L28: .loc 1 112 0 setp.ge.s32 %r232,%r107,0; selp.u32 %r111,%r111,%r110,%r232; selp.u32 %r107,%r107,%r105,%r232; .loc 1 115 0 or.b32 %r233,%r107,%r111; setp.eq.u32 %r234,%r233,0; @ %r234 bra $L30; .loc 1 117 0 setp.le.s32 %r235,%r107,1048575; @ %r235 bra $L31; bra $L32; $L30: .loc 1 116 0 cvta.const.u64 %r236,Zero; shr.u32 %r237,%r116,31; cvt.u64.u32 %r238,%r237; shl.b64 %r239,%r238,3; add.u64 %r240,%r236,%r239; ld.f64 %r137,[%r240]; bra $L1; $L31: .loc 1 118 0 add.u32 %r241,%r107,%r107; shr.u32 %r242,%r111,31; add.u32 %r107,%r241,%r242; add.u32 %r111,%r111,%r111; .loc 1 119 0 add.u32 %r131,%r131,-1; .loc 1 117 0 setp.le.s32 %r244,%r107,1048575; @ %r244 bra $L31; setp.lt.s32 %r276,%r131,-1022; $L32: .loc 1 121 0 @ %r276 bra $L33; .loc 1 122 0 add.u32 %r246,%r131,1023; shl.b32 %r247,%r246,20; add.u32 %r248,%r107,-1048576; .loc 1 123 0 or.b32 %r249,%r248,%r116; or.b32 %r250,%r247,%r249; cvt.u64.u32 %r251,%r250; cvt.u64.u32 %r255,%r111; shl.b64 %r256,%r251,32; or.b64 %r257,%r256,%r255; mov.b64 %r137,%r257; bra $L1; $L33: .loc 1 125 0 mov.u32 %r258,-1022; sub.u32 %r129,%r258,%r131; .loc 1 126 0 setp.gt.s32 %r259,%r129,20; @ %r259 bra $L34; .loc 1 127 0 shr.u32 %r94,%r111,%r129; add.u32 %r260,%r131,1054; shl.b32 %r261,%r107,%r260; or.b32 %r112,%r261,%r94; .loc 1 128 0 shr.s32 %r262,%r107,%r129; or.b32 %r116,%r116,%r262; bra $L35; $L34: .loc 1 129 0 setp.gt.s32 %r263,%r129,31; @ %r263 bra $L36; .loc 1 130 0 shr.u32 %r101,%r111,%r129; add.u32 %r264,%r131,1054; shl.b32 %r265,%r107,%r264; or.b32 %r112,%r265,%r101; bra $L35; $L36: .loc 1 132 0 mov.u32 %r267,-1054; sub.u32 %r266,%r267,%r131; shr.s32 %r112,%r107,%r266; $L35: .loc 1 134 0 cvt.u64.u32 %r268,%r116; cvt.u64.u32 %r272,%r112; shl.b64 %r273,%r268,32; or.b64 %r274,%r273,%r272; mov.b64 %r137,%r274; bra $L1; $L37: .loc 1 51 0 mov.f64 %r137,%r138; $L1: .loc 1 138 0 mov.f64 %value,%r137; st.param.f64 [%value_out],%value; ret; } lib_a-e_hypot.o/0 0 0 644 6486 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypot .visible .func (.param .f64 %value_out) __ieee754_hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_hypot.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_hypot .visible .func (.param .f64 %value_out) __ieee754_hypot (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r49; .reg .f64 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .f64 %r62; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r67; .reg .f64 %r70; .reg .f64 %r72; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r83; .reg .u64 %r84; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .u32 %r92; .reg .f64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .pred %r98; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .pred %r109; .reg .pred %r110; .reg .u32 %r111; .reg .u32 %r113; .reg .u32 %r114; .reg .pred %r115; .reg .u32 %r116; .reg .u32 %r118; .reg .u32 %r119; .reg .pred %r120; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .u32 %r133; .reg .pred %r134; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r142; .reg .pred %r143; .reg .u64 %r145; .reg .f64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .u64 %r159; .reg .u32 %r162; .reg .u64 %r163; .reg .u64 %r164; .reg .f64 %r167; .reg .f64 %r168; .reg .f64 %r169; .reg .f64 %r170; .reg .f64 %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .f64 %r174; .reg .f64 %r175; .reg .f64 %r177; .reg .pred %r178; .reg .u32 %r179; .reg .u32 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .u64 %r186; .reg .u64 %r187; mov.f64 %r90,%ar0; mov.f64 %r91,%ar1; .loc 1 60 0 mov.b64 %r94,%r90; shr.u64 %r95,%r94,32; cvt.u32.u64 %r57,%r95; .loc 1 61 0 and.b32 %r55,%r57,2147483647; .loc 1 62 0 mov.b64 %r96,%r91; shr.u64 %r97,%r96,32; cvt.u32.u64 %r58,%r97; .loc 1 63 0 and.b32 %r56,%r58,2147483647; .loc 1 64 0 setp.ge.s32 %r98,%r55,%r56; @ %r98 bra $L2; mov.u32 %r92,%r55; mov.u32 %r55,%r56; mov.u32 %r56,%r92; mov.f64 %r93,%r90; mov.f64 %r90,%r91; mov.f64 %r91,%r93; $L2: .loc 1 65 0 mov.b64 %r78,%r90; cvt.u64.u32 %r186,%r55; shl.b64 %r100,%r186,32; and.b64 %r101,%r78,4294967295; or.b64 %r102,%r101,%r100; mov.b64 %r89,%r102; .loc 1 66 0 mov.b64 %r79,%r91; cvt.u64.u32 %r187,%r56; shl.b64 %r104,%r187,32; and.b64 %r105,%r79,4294967295; or.b64 %r106,%r105,%r104; mov.b64 %r53,%r106; .loc 1 67 0 sub.u32 %r107,%r55,%r56; setp.le.s32 %r108,%r107,62914560; @ %r108 bra $L3; add.f64 %r89,%r89,%r53; bra $L1; $L3: .loc 1 69 0 setp.le.s32 %r109,%r55,1596981248; @ %r109 bra $L13; .loc 1 70 0 setp.le.s32 %r110,%r55,2146435071; @ %r110 bra $L6; .loc 1 74 0 and.b32 %r111,%r55,1048575; cvt.u32.u64 %r114,%r102; or.b32 %r113,%r111,%r114; setp.eq.u32 %r115,%r113,0; @ %r115 bra $L7; .loc 1 72 0 add.f64 %r89,%r89,%r53; $L7: .loc 1 76 0 xor.b32 %r116,%r56,2146435072; cvt.u32.u64 %r119,%r106; or.b32 %r118,%r116,%r119; setp.ne.u32 %r120,%r118,0; selp.f64 %r89,%r89,%r53,%r120; bra $L1; $L6: .loc 1 80 0 add.u32 %r55,%r55,-629145600; add.u32 %r56,%r56,-629145600; .loc 1 81 0 cvt.u64.u32 %r186,%r55; shl.b64 %r122,%r186,32; and.b64 %r123,%r102,4294967295; or.b64 %r124,%r123,%r122; mov.b64 %r89,%r124; .loc 1 82 0 cvt.u64.u32 %r187,%r56; shl.b64 %r126,%r187,32; and.b64 %r127,%r106,4294967295; or.b64 %r128,%r127,%r126; mov.b64 %r53,%r128; .loc 1 80 0 mov.u32 %r54,600; bra $L5; $L13: .loc 1 68 0 mov.u32 %r54,0; $L5: .loc 1 84 0 setp.gt.s32 %r129,%r56,548405247; @ %r129 bra $L8; .loc 1 85 0 setp.gt.s32 %r130,%r56,1048575; @ %r130 bra $L9; .loc 1 88 0 mov.b64 %r131,%r53; cvt.u32.u64 %r133,%r131; or.b32 %r132,%r56,%r133; setp.eq.u32 %r134,%r132,0; @ %r134 bra $L1; .loc 1 90 0 mov.f64 %r62,0d7fd0000000000000; .loc 1 91 0 mul.f64 %r53,%r53,%r62; .loc 1 92 0 mul.f64 %r89,%r89,%r62; .loc 1 93 0 add.u32 %r54,%r54,-1022; bra $L8; $L9: .loc 1 95 0 add.u32 %r55,%r55,629145600; .loc 1 96 0 add.u32 %r56,%r56,629145600; .loc 1 97 0 add.u32 %r54,%r54,-600; .loc 1 98 0 mov.b64 %r83,%r89; cvt.u64.u32 %r186,%r55; shl.b64 %r136,%r186,32; and.b64 %r137,%r83,4294967295; or.b64 %r138,%r137,%r136; mov.b64 %r89,%r138; .loc 1 99 0 mov.b64 %r84,%r53; cvt.u64.u32 %r187,%r56; shl.b64 %r140,%r187,32; and.b64 %r141,%r84,4294967295; or.b64 %r142,%r141,%r140; mov.b64 %r53,%r142; $L8: .loc 1 103 0 sub.f64 %r64,%r89,%r53; .loc 1 104 0 setp.lt.f64 %r143,%r53,%r64; @ ! %r143 bra $L24; .loc 1 106 0 shl.b64 %r145,%r186,32; mov.b64 %r70,%r145; .loc 1 108 0 neg.f64 %r149,%r53; add.f64 %r150,%r89,%r70; .loc 1 107 0 sub.f64 %r151,%r89,%r70; .loc 1 108 0 mul.f64 %r152,%r150,%r151; neg.f64 %r153,%r152; fma.rn.f64 %r154,%r149,%r53,%r153; neg.f64 %r155,%r154; fma.rn.f64 %r156,%r70,%r70,%r155; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r156; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r157,[%value_in]; } mov.f64 %r89,%r157; bra $L12; $L24: .loc 1 112 0 shl.b64 %r159,%r187,32; mov.b64 %r65,%r159; .loc 1 115 0 add.u32 %r162,%r55,1048576; cvt.u64.u32 %r163,%r162; shl.b64 %r164,%r163,32; mov.b64 %r67,%r164; .loc 1 117 0 neg.f64 %r167,%r64; .loc 1 113 0 sub.f64 %r168,%r53,%r65; .loc 1 116 0 neg.f64 %r169,%r67; fma.rn.f64 %r170,%r89,0d4000000000000000,%r169; .loc 1 117 0 mul.f64 %r171,%r170,%r53; fma.rn.f64 %r172,%r168,%r67,%r171; neg.f64 %r173,%r172; fma.rn.f64 %r174,%r167,%r64,%r173; neg.f64 %r175,%r174; fma.rn.f64 %r49,%r65,%r67,%r175; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r177,[%value_in]; } mov.f64 %r89,%r177; $L12: .loc 1 119 0 setp.eq.u32 %r178,%r54,0; @ %r178 bra $L1; .loc 1 123 0 shl.b32 %r179,%r54,20; add.u32 %r180,%r179,1072693248; cvt.u64.u32 %r181,%r180; shl.b64 %r182,%r181,32; mov.b64 %r72,%r182; .loc 1 124 0 mul.f64 %r89,%r89,%r72; $L1: .loc 1 126 0 mov.f64 %value,%r89; st.param.f64 [%value_out],%value; ret; } lib_a-e_j0.o/ 0 0 0 644 17024 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: pzero .func (.param .f64 %value_out) pzero (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_j0.c" // BEGIN FUNCTION DECL: qzero .func (.param .f64 %value_out) qzero (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0 .visible .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0 .visible .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN FUNCTION DEF: pzero .func (.param .f64 %value_out) pzero (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; mov.f64 %r50,%ar0; .loc 1 339 0 mov.b64 %r51,%r50; shr.u64 %r52,%r51,32; cvt.u32.u64 %r35,%r52; .loc 1 340 0 and.b32 %r36,%r35,2147483647; .loc 1 341 0 setp.gt.s32 %r53,%r36,1075838975; @ %r53 bra $L3; .loc 1 342 0 setp.gt.s32 %r54,%r36,1074933386; @ %r54 bra $L4; .loc 1 343 0 setp.gt.s32 %r55,%r36,1074191212; selp.f64 %r48,0d4065b296fc379081,0d402d50b344391809,%r55; selp.f64 %r47,0d40919ffcb8c39b7e,0d40633c033ab6faff,%r55; selp.f64 %r46,0d4092a66e6d1061d6,0d4070e78642ea079b,%r55; selp.f64 %r45,0d40769839464a7c0e,0d4061069e0ee8878f,%r55; selp.f64 %r44,0dc03f72aca892d80f,0dc009de81af8fe70f,%r55; selp.f64 %r43,0dc04d0a22420a1a45,0dc02662e6c5246303,%r55; selp.f64 %r42,0dc035f74a4cb94e14,0dc01e8af3edafa7f3,%r55; selp.f64 %r41,0dc00345b2aea48074,0dbff736398a24a843,%r55; selp.f64 %r40,0dbfb1fff6f7c0e24b,0dbfb1ff62495e1e42,%r55; selp.f64 %r28,0d4041ed9284077dd3,0d40363865908b5959,%r55; selp.f64 %r23,0dbe25e1036fe1aa86,0dbe77d316e927026d,%r55; bra $L2; $L3: mov.f64 %r48,0d40e741774f2c49dc; mov.f64 %r47,0d40fc810f8f9fa9bd; mov.f64 %r46,0d40e3d2bb6eb6b05f; mov.f64 %r45,0d40adf37d50596938; mov.f64 %r44,0dc0b4850b36cc643d; mov.f64 %r43,0dc0a36a6ecd4dcafc; mov.f64 %r42,0dc07011027b19e863; mov.f64 %r41,0dc02029d0b44fa779; mov.f64 %r40,0dbfb1fffffffffd32; .loc 1 341 0 mov.f64 %r28,0d405d223307a96751; mov.f64 %r23,0d0000000000000000; bra $L2; $L4: mov.f64 %r48,0d40a2cc1dc70be864; mov.f64 %r47,0d40c2ccb8fa76fa38; mov.f64 %r46,0d40b75af88fbe1d60; mov.f64 %r45,0d40906d025c7e2864; mov.f64 %r44,0dc075a6ef28a38bd7; mov.f64 %r43,0dc074b3b36742cc63; mov.f64 %r42,0dc050eb2f5a7d1783; mov.f64 %r41,0dc010a370f90c6bbf; mov.f64 %r40,0dbfb1ffffe69afbc6; .loc 1 342 0 mov.f64 %r28,0d404e60810c98c5de; mov.f64 %r23,0dbda918b147e495cc; $L2: .loc 1 345 0 mul.f64 %r56,%r50,%r50; mov.f64 %r57,0d3ff0000000000000; div.rn.f64 %r37,%r57,%r56; .loc 1 346 0 fma.rn.f64 %r59,%r37,%r44,%r43; fma.rn.f64 %r60,%r59,%r37,%r42; fma.rn.f64 %r61,%r60,%r37,%r41; fma.rn.f64 %r62,%r61,%r37,%r40; fma.rn.f64 %r63,%r62,%r37,%r23; .loc 1 347 0 fma.rn.f64 %r64,%r37,%r48,%r47; fma.rn.f64 %r65,%r64,%r37,%r46; fma.rn.f64 %r66,%r65,%r37,%r45; fma.rn.f64 %r67,%r66,%r37,%r28; fma.rn.f64 %r68,%r67,%r37,0d3ff0000000000000; .loc 1 348 0 div.rn.f64 %r69,%r63,%r68; add.f64 %value,%r69,0d3ff0000000000000; .loc 1 349 0 st.param.f64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qzero .func (.param .f64 %value_out) qzero (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .pred %r56; .reg .pred %r57; .reg .pred %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; mov.f64 %r53,%ar0; .loc 1 475 0 mov.b64 %r54,%r53; shr.u64 %r55,%r54,32; cvt.u32.u64 %r37,%r55; .loc 1 476 0 and.b32 %r38,%r37,2147483647; .loc 1 477 0 setp.gt.s32 %r56,%r38,1075838975; @ %r56 bra $L8; .loc 1 478 0 setp.gt.s32 %r57,%r38,1074933386; @ %r57 bra $L9; .loc 1 479 0 setp.gt.s32 %r58,%r38,1074191212; selp.f64 %r51,0dc062a7eb201cf40f,0dc0153e6af8b32931,%r58; selp.f64 %r50,0d40a3a8aad94fb1c0,0d406a95530e001365,%r58; selp.f64 %r49,0d40b93c6cd7c76a28,0d408b977c9c5cc214,%r58; selp.f64 %r48,0d40acf04be44dfc63,0d408a664522b3bf22,%r58; selp.f64 %r47,0d40862d8386544eb3,0d4070d591e4d14b40,%r58; selp.f64 %r46,0d4064d77c81fa21e0,0d403040b171814bb4,%r58; selp.f64 %r45,0d406559dbe25efd1f,0d403faa8e29fbdc4a,%r58; selp.f64 %r44,0d40454f98962daedd,0d402cfdbfaaf96fe5,%r58; selp.f64 %r43,0d400ac0fc61149cf5,0d3ffff897e727779c,%r58; selp.f64 %r42,0d3fb2bfee0e8d0842,0d3fb2bec53e883e34,%r58; selp.f64 %r28,0d40486122bfe343a6,0d403e5d96f7c07aed,%r58; selp.f64 %r23,0d3e32cd036adecb82,0d3e84313b54f76bdb,%r58; bra $L7; $L8: mov.f64 %r51,0dc114fd6d2c9530c5; mov.f64 %r50,0d4129a66b28de0b3d; mov.f64 %r49,0d412883da83a52b43; mov.f64 %r48,0d4101665254d38c3f; mov.f64 %r47,0d40bfa2584e6b0563; mov.f64 %r46,0d40e212d40e901566; mov.f64 %r45,0d40c14d993e18f46d; mov.f64 %r44,0d40816d6315301825; mov.f64 %r43,0d402789525bb334d6; mov.f64 %r42,0d3fb2bffffffffe2c; .loc 1 477 0 mov.f64 %r28,0d406478d5365b39bc; mov.f64 %r23,0d0000000000000000; bra $L7; $L9: mov.f64 %r51,0dc0b4ea57bedbc609; mov.f64 %r50,0d40e191181f7a54a0; mov.f64 %r49,0d40ebb5e397e02372; mov.f64 %r48,0d40d267d27b591e6d; mov.f64 %r47,0d40a03ba0da21c0ce; mov.f64 %r46,0d409f17e953c6e3a6; mov.f64 %r45,0d40900cf99dc8c481; mov.f64 %r44,0d4060e3920a8788e9; mov.f64 %r43,0d401757b0b9953dd3; mov.f64 %r42,0d3fb2bfffd172b04c; .loc 1 478 0 mov.f64 %r28,0d4054b1b3fb5e1543; mov.f64 %r23,0d3db43d8f29cc8cd9; $L7: .loc 1 481 0 mul.f64 %r59,%r53,%r53; mov.f64 %r60,0d3ff0000000000000; div.rn.f64 %r39,%r60,%r59; .loc 1 482 0 fma.rn.f64 %r62,%r39,%r46,%r45; fma.rn.f64 %r63,%r62,%r39,%r44; fma.rn.f64 %r64,%r63,%r39,%r43; fma.rn.f64 %r65,%r64,%r39,%r42; fma.rn.f64 %r66,%r65,%r39,%r23; .loc 1 483 0 fma.rn.f64 %r67,%r39,%r51,%r50; fma.rn.f64 %r68,%r67,%r39,%r49; fma.rn.f64 %r69,%r68,%r39,%r48; fma.rn.f64 %r70,%r69,%r39,%r47; fma.rn.f64 %r71,%r70,%r39,%r28; fma.rn.f64 %r72,%r71,%r39,0d3ff0000000000000; .loc 1 484 0 div.rn.f64 %r73,%r66,%r72; mov.f64 %r75,0d3fc0000000000000; sub.f64 %r74,%r73,%r75; div.rn.f64 %value,%r74,%r53; .loc 1 485 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j0 .visible .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r44; .reg .f64 %r45; .reg .u32 %r47; .reg .f64 %r49; .reg .f64 %r54; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .pred %r73; .reg .f64 %r75; .reg .f64 %r77; .reg .pred %r78; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r82; .reg .pred %r83; .reg .pred %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r89; .reg .f64 %r91; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .pred %r98; .reg .f64 %r99; .reg .pred %r100; .reg .pred %r101; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .pred %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r118; mov.f64 %r64,%ar0; .loc 1 104 0 mov.b64 %r65,%r64; shr.u64 %r66,%r65,32; .loc 1 105 0 cvt.u32.u64 %r67,%r66; and.b32 %r47,%r67,2147483647; .loc 1 106 0 setp.le.s32 %r68,%r47,2146435071; @ %r68 bra $L12; mul.f64 %r69,%r64,%r64; mov.f64 %r70,0d3ff0000000000000; div.rn.f64 %r63,%r70,%r69; bra $L11; $L12: .loc 1 107 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r64; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r72,[%value_in]; } .loc 1 108 0 setp.le.s32 %r73,%r47,1073741823; @ %r73 bra $L14; .loc 1 109 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),sin,(%out_arg1); ld.param.f64 %r75,[%value_in]; } .loc 1 110 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),cos,(%out_arg1); ld.param.f64 %r77,[%value_in]; } .loc 1 111 0 sub.f64 %r44,%r75,%r77; .loc 1 112 0 add.f64 %r45,%r75,%r77; .loc 1 113 0 setp.gt.s32 %r78,%r47,2145386495; @ %r78 bra $L15; .loc 1 114 0 add.f64 %r80,%r72,%r72; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r80; call (%value_in),cos,(%out_arg1); ld.param.f64 %r81,[%value_in]; } neg.f64 %r54,%r81; .loc 1 115 0 mul.f64 %r82,%r75,%r77; setp.lt.f64 %r83,%r82,0d0000000000000000; @ ! %r83 bra $L25; div.rn.f64 %r45,%r54,%r44; bra $L15; $L25: .loc 1 116 0 div.rn.f64 %r44,%r54,%r45; $L15: .loc 1 122 0 setp.le.s32 %r84,%r47,1207959552; @ %r84 bra $L18; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r86,[%value_in]; } mul.f64 %r87,%r45,0d3fe20dd750429b6d; div.rn.f64 %r63,%r87,%r86; bra $L11; $L18: .loc 1 124 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),pzero,(%out_arg1); ld.param.f64 %r89,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),qzero,(%out_arg1); ld.param.f64 %r91,[%value_in]; } .loc 1 125 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r93,[%value_in]; } mul.f64 %r94,%r44,%r91; neg.f64 %r95,%r94; fma.rn.f64 %r96,%r45,%r89,%r95; mul.f64 %r97,%r96,0d3fe20dd750429b6d; div.rn.f64 %r63,%r97,%r93; bra $L11; $L14: .loc 1 129 0 setp.gt.s32 %r98,%r47,1059061759; @ %r98 bra $L19; .loc 1 130 0 add.f64 %r99,%r72,0d7e37e43c8800759c; setp.gt.f64 %r100,%r99,0d3ff0000000000000; @ ! %r100 bra $L19; .loc 1 131 0 setp.le.s32 %r101,%r47,1044381695; @ %r101 bra $L22; .loc 1 132 0 mul.f64 %r103,%r72,0dbfd0000000000000; fma.rn.f64 %r63,%r103,%r72,0d3ff0000000000000; bra $L11; $L19: .loc 1 135 0 mul.f64 %r49,%r72,%r72; .loc 1 136 0 fma.rn.f64 %r104,%r49,0dbe33d5e773d63fce,0d3ebeb1d10c503919; fma.rn.f64 %r105,%r104,%r49,0dbf28e6a5b61ac6e9; fma.rn.f64 %r106,%r105,%r49,0d3f8ffffffffffffd; mul.f64 %r107,%r106,%r49; .loc 1 137 0 fma.rn.f64 %r108,%r49,0d3e1408bcf4745d8f,0d3ea13b54ce84d5a9; fma.rn.f64 %r109,%r108,%r49,0d3f1ea6d2dd57dbf4; fma.rn.f64 %r110,%r109,%r49,0d3f8ffce882c8c2a4; fma.rn.f64 %r111,%r110,%r49,0d3ff0000000000000; div.rn.f64 %r62,%r107,%r111; .loc 1 138 0 setp.gt.s32 %r112,%r47,1072693247; @ %r112 bra $L21; .loc 1 139 0 mov.f64 %r114,0d3fd0000000000000; sub.f64 %r113,%r62,%r114; fma.rn.f64 %r63,%r113,%r49,0d3ff0000000000000; bra $L11; $L21: .loc 1 142 0 fma.rn.f64 %r115,%r72,0d3fe0000000000000,0d3ff0000000000000; mul.f64 %r116,%r49,%r62; fma.rn.f64 %r118,%r72,0dbfe0000000000000,0d3ff0000000000000; fma.rn.f64 %r63,%r115,%r118,%r116; bra $L11; $L22: .loc 1 131 0 mov.f64 %r63,0d3ff0000000000000; $L11: .loc 1 144 0 mov.f64 %value,%r63; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y0 .visible .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r42; .reg .f64 %r46; .reg .f64 %r47; .reg .u32 %r48; .reg .u32 %r50; .reg .f64 %r51; .reg .f64 %r56; .reg .f64 %r65; .reg .f64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .u32 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .f64 %r76; .reg .pred %r77; .reg .f64 %r78; .reg .pred %r79; .reg .f64 %r81; .reg .f64 %r83; .reg .pred %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .pred %r89; .reg .pred %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r95; .reg .f64 %r97; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .pred %r103; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r117; .reg .f64 %r119; .reg .f64 %r120; mov.f64 %r66,%ar0; .loc 1 173 0 mov.b64 %r67,%r66; shr.u64 %r68,%r67,32; cvt.u32.u64 %r48,%r68; .loc 1 174 0 and.b32 %r50,%r48,2147483647; .loc 1 176 0 setp.le.s32 %r69,%r50,2146435071; @ %r69 bra $L27; fma.rn.f64 %r70,%r66,%r66,%r66; mov.f64 %r71,0d3ff0000000000000; div.rn.f64 %r65,%r71,%r70; bra $L26; $L27: .loc 1 177 0 cvt.u32.u64 %r74,%r67; or.b32 %r73,%r50,%r74; setp.ne.u32 %r75,%r73,0; @ %r75 bra $L29; mov.f64 %r76,0dbff0000000000000; div.rn.f64 %r65,%r76,0d0000000000000000; bra $L26; $L29: .loc 1 178 0 setp.ge.s32 %r77,%r48,0; @ %r77 bra $L30; mov.f64 %r78,0d0000000000000000; div.rn.f64 %r65,%r78,0d0000000000000000; bra $L26; $L30: .loc 1 179 0 setp.le.s32 %r79,%r50,1073741823; @ %r79 bra $L31; .loc 1 191 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),sin,(%out_arg1); ld.param.f64 %r81,[%value_in]; } .loc 1 192 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),cos,(%out_arg1); ld.param.f64 %r83,[%value_in]; } .loc 1 193 0 sub.f64 %r46,%r81,%r83; .loc 1 194 0 add.f64 %r47,%r81,%r83; .loc 1 199 0 setp.gt.s32 %r84,%r50,2145386495; @ %r84 bra $L32; .loc 1 200 0 add.f64 %r86,%r66,%r66; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; call (%value_in),cos,(%out_arg1); ld.param.f64 %r87,[%value_in]; } neg.f64 %r56,%r87; .loc 1 201 0 mul.f64 %r88,%r81,%r83; setp.lt.f64 %r89,%r88,0d0000000000000000; @ ! %r89 bra $L38; div.rn.f64 %r47,%r56,%r46; bra $L32; $L38: .loc 1 202 0 div.rn.f64 %r46,%r56,%r47; $L32: .loc 1 204 0 setp.le.s32 %r90,%r50,1207959552; @ %r90 bra $L35; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r92,[%value_in]; } mul.f64 %r93,%r46,0d3fe20dd750429b6d; div.rn.f64 %r65,%r93,%r92; bra $L26; $L35: .loc 1 206 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),pzero,(%out_arg1); ld.param.f64 %r95,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),qzero,(%out_arg1); ld.param.f64 %r97,[%value_in]; } .loc 1 207 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r99,[%value_in]; } mul.f64 %r100,%r47,%r97; fma.rn.f64 %r101,%r46,%r95,%r100; mul.f64 %r102,%r101,0d3fe20dd750429b6d; div.rn.f64 %r65,%r102,%r99; bra $L26; $L31: .loc 1 211 0 setp.gt.s32 %r103,%r50,1044381696; @ %r103 bra $L36; .loc 1 212 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r105,[%value_in]; } fma.rn.f64 %r65,%r105,0d3fe45f306dc9c883,0dbfb2e4d699cbd01f; bra $L26; $L36: .loc 1 214 0 mul.f64 %r51,%r66,%r66; .loc 1 215 0 fma.rn.f64 %r106,%r51,0dbdc5e43d693fb3c8,0d3e5500573b4eabd4; fma.rn.f64 %r107,%r106,%r51,0dbecffea773d25cad; fma.rn.f64 %r108,%r107,%r51,0d3f36c54d20b29b6b; fma.rn.f64 %r109,%r108,%r51,0dbf8c4ce8b16cfa97; fma.rn.f64 %r110,%r109,%r51,0d3fc69d019de9e3fc; fma.rn.f64 %r111,%r110,%r51,0dbfb2e4d699cbd01f; .loc 1 216 0 fma.rn.f64 %r112,%r51,0d3dfe50183bd6d9ef,0d3e91642d7ff202fd; fma.rn.f64 %r113,%r112,%r51,0d3f13ecbbf578c6c1; fma.rn.f64 %r114,%r113,%r51,0d3f8a127091c9c71a; fma.rn.f64 %r115,%r114,%r51,0d3ff0000000000000; .loc 1 217 0 div.rn.f64 %r42,%r111,%r115; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r117,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r119,[%value_in]; } mul.f64 %r120,%r117,%r119; fma.rn.f64 %r65,%r120,0d3fe45f306dc9c883,%r42; $L26: .loc 1 218 0 mov.f64 %value,%r65; st.param.f64 [%value_out],%value; ret; } lib_a-e_j1.o/ 0 0 0 644 16407 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: pone .func (.param .f64 %value_out) pone (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_j1.c" // BEGIN FUNCTION DECL: qone .func (.param .f64 %value_out) qone (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1 .visible .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1 .visible .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN FUNCTION DEF: pone .func (.param .f64 %value_out) pone (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; mov.f64 %r50,%ar0; .loc 1 337 0 mov.b64 %r51,%r50; shr.u64 %r52,%r51,32; cvt.u32.u64 %r35,%r52; .loc 1 338 0 and.b32 %r36,%r35,2147483647; .loc 1 339 0 setp.gt.s32 %r53,%r36,1075838975; @ %r53 bra $L3; .loc 1 340 0 setp.gt.s32 %r54,%r36,1074933386; @ %r54 bra $L4; .loc 1 341 0 setp.gt.s32 %r55,%r36,1074191212; selp.f64 %r48,0d4059f26d7c2eed53,0d4020bab1f44e5192,%r55; selp.f64 %r47,0d408bd67da32e31e9,0d405d6b7ada1884a9,%r55; selp.f64 %r46,0d40905b7c5037d523,0d406d08d8d5a2dbd9,%r55; selp.f64 %r45,0d40750c3307f1a75f,0d405f529314f92cd5,%r55; selp.f64 %r44,0d4048478f8ea83ee5,0d40144b49a574c1fe,%r55; selp.f64 %r43,0d4056c3854d2c1837,0d4031b1a8177f8ee2,%r55; selp.f64 %r42,0d40418f489da6d129,0d40287c377f71a964,%r55; selp.f64 %r41,0d400f76bce85ead8a,0d4002f2b7f98faec0,%r55; selp.f64 %r40,0d3fbdfff55b21d17b,0d3fbdff42be760d83,%r55; selp.f64 %r28,0d40416549a134069c,0d40356fbd8ad5ecdc,%r55; selp.f64 %r23,0d3e29fc21a7ad9edd,0d3e7ce9d4f65544f4,%r55; bra $L2; $L3: mov.f64 %r48,0d40de1511697a0b2d; mov.f64 %r47,0d40f7d42cb28f17bb; mov.f64 %r46,0d40e20b8697c5bb7f; mov.f64 %r45,0d40ac85dc964d274f; mov.f64 %r44,0d40beea7ac32782dd; mov.f64 %r43,0d40ae457da3a532cc; mov.f64 %r42,0d4079c0d4652ea590; mov.f64 %r41,0d402a7a9d357f7fce; mov.f64 %r40,0d3fbdfffffffffcce; .loc 1 339 0 mov.f64 %r28,0d405c8d458e656cac; mov.f64 %r23,0d0000000000000000; bra $L2; $L4: mov.f64 %r48,0d40978030036f5e51; mov.f64 %r47,0d40bea4b0b8a5bb15; mov.f64 %r46,0d40b4e9445706b6fb; mov.f64 %r45,0d408efb361b066701; mov.f64 %r44,0d408085b8bb7e0cb7; mov.f64 %r43,0d40802d16d052d649; mov.f64 %r42,0d405b13b9452602ed; mov.f64 %r41,0d401b36046e6315e3; mov.f64 %r40,0d3fbdffffe2c10043; .loc 1 340 0 mov.f64 %r28,0d404da3eaa8af633d; mov.f64 %r23,0d3dad0667dae1ca7d; $L2: .loc 1 343 0 mul.f64 %r56,%r50,%r50; mov.f64 %r57,0d3ff0000000000000; div.rn.f64 %r37,%r57,%r56; .loc 1 344 0 fma.rn.f64 %r59,%r37,%r44,%r43; fma.rn.f64 %r60,%r59,%r37,%r42; fma.rn.f64 %r61,%r60,%r37,%r41; fma.rn.f64 %r62,%r61,%r37,%r40; fma.rn.f64 %r63,%r62,%r37,%r23; .loc 1 345 0 fma.rn.f64 %r64,%r37,%r48,%r47; fma.rn.f64 %r65,%r64,%r37,%r46; fma.rn.f64 %r66,%r65,%r37,%r45; fma.rn.f64 %r67,%r66,%r37,%r28; fma.rn.f64 %r68,%r67,%r37,0d3ff0000000000000; .loc 1 346 0 div.rn.f64 %r69,%r63,%r68; add.f64 %value,%r69,0d3ff0000000000000; .loc 1 347 0 st.param.f64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qone .func (.param .f64 %value_out) qone (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .pred %r56; .reg .pred %r57; .reg .pred %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; mov.f64 %r53,%ar0; .loc 1 474 0 mov.b64 %r54,%r53; shr.u64 %r55,%r54,32; cvt.u32.u64 %r37,%r55; .loc 1 475 0 and.b32 %r38,%r37,2147483647; .loc 1 476 0 setp.gt.s32 %r56,%r38,1075838975; @ %r56 bra $L8; .loc 1 477 0 setp.gt.s32 %r57,%r38,1074933386; @ %r57 bra $L9; .loc 1 478 0 setp.gt.s32 %r58,%r38,1074191212; selp.f64 %r51,0dc060e670290a311f,0dc013d686e71be86b,%r58; selp.f64 %r50,0d409dbc7a0dd4df4b,0d40637e5e3c3ed8d4,%r58; selp.f64 %r49,0d40b5abbaa61d54a6,0d40871b2548d4c029,%r58; selp.f64 %r48,0d40aa684e448e7c9a,0d4087ac05ce49a0f7,%r58; selp.f64 %r47,0d40850eebc031ee3e,0d406f9f68db821cba,%r58; selp.f64 %r46,0dc06b66b95f5c1bf6,0dc0355f3639cf6e52,%r58; selp.f64 %r45,0dc06c87d34718d55f,0dc04529a3de104aaa,%r58; selp.f64 %r44,0dc04cec71c25d16da,0dc033a9e2c168907f,%r58; selp.f64 %r43,0dc01270c23302d9ff,0dc006048469bb4eda,%r58; selp.f64 %r42,0dbfba3feb51aeed54,0dbfba3e8e9148b010,%r58; selp.f64 %r28,0d4047d523ccd367e4,0d403d888a78ae64ff,%r58; selp.f64 %r23,0dbe35cfa9d38fc84f,0dbe87f12644c626d2,%r58; bra $L7; $L8: mov.f64 %r51,0dc111f9690ea5aa18; mov.f64 %r50,0d412457d27719ad5c; mov.f64 %r49,0d4125f65372869c19; mov.f64 %r48,0d4100579ab0b75e98; mov.f64 %r47,0d40be9162d0d88419; mov.f64 %r46,0dc0e7a6d065d09c6a; mov.f64 %r45,0dc0c724e740f87415; mov.f64 %r44,0dc087bcd053e4b576; mov.f64 %r43,0dc0304591a26779f7; mov.f64 %r42,0dbfba3ffffffffdf3; .loc 1 476 0 mov.f64 %r28,0d40642ca6de5bcde5; mov.f64 %r23,0d0000000000000000; bra $L7; $L9: mov.f64 %r51,0dc0b26f2efcffa004; mov.f64 %r50,0d40db4b04cf7c364b; mov.f64 %r49,0d40e8576daabad197; mov.f64 %r48,0d40d10f1f0d64ce29; mov.f64 %r47,0d409f1f31e77bf839; mov.f64 %r46,0dc0a468e388fda79d; mov.f64 %r45,0dc09574c66931734f; mov.f64 %r44,0dc066f56d6ca7b9b0; mov.f64 %r43,0dc0201ce6ca03ad4b; mov.f64 %r42,0dbfba3fffcb597fef; .loc 1 477 0 mov.f64 %r28,0d405451b2ff5a11b2; mov.f64 %r23,0dbdb6fa431aa1a098; $L7: .loc 1 480 0 mul.f64 %r59,%r53,%r53; mov.f64 %r60,0d3ff0000000000000; div.rn.f64 %r39,%r60,%r59; .loc 1 481 0 fma.rn.f64 %r62,%r39,%r46,%r45; fma.rn.f64 %r63,%r62,%r39,%r44; fma.rn.f64 %r64,%r63,%r39,%r43; fma.rn.f64 %r65,%r64,%r39,%r42; fma.rn.f64 %r66,%r65,%r39,%r23; .loc 1 482 0 fma.rn.f64 %r67,%r39,%r51,%r50; fma.rn.f64 %r68,%r67,%r39,%r49; fma.rn.f64 %r69,%r68,%r39,%r48; fma.rn.f64 %r70,%r69,%r39,%r47; fma.rn.f64 %r71,%r70,%r39,%r28; fma.rn.f64 %r72,%r71,%r39,0d3ff0000000000000; .loc 1 483 0 div.rn.f64 %r73,%r66,%r72; add.f64 %r74,%r73,0d3fd8000000000000; div.rn.f64 %value,%r74,%r53; .loc 1 484 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j1 .visible .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r40; .reg .f64 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r58; .reg .f64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .pred %r62; .reg .f64 %r63; .reg .f64 %r65; .reg .pred %r66; .reg .f64 %r68; .reg .f64 %r70; .reg .f64 %r71; .reg .pred %r72; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .pred %r77; .reg .pred %r78; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r83; .reg .f64 %r85; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .pred %r92; .reg .pred %r93; .reg .f64 %r94; .reg .pred %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; mov.f64 %r59,%ar0; .loc 1 105 0 mov.b64 %r60,%r59; shr.u64 %r61,%r60,32; cvt.u32.u64 %r42,%r61; .loc 1 106 0 and.b32 %r43,%r42,2147483647; .loc 1 107 0 setp.le.s32 %r62,%r43,2146435071; @ %r62 bra $L12; mov.f64 %r63,0d3ff0000000000000; div.rn.f64 %r58,%r63,%r59; bra $L11; $L12: .loc 1 108 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r65,[%value_in]; } .loc 1 109 0 setp.le.s32 %r66,%r43,1073741823; @ %r66 bra $L14; .loc 1 110 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),sin,(%out_arg1); ld.param.f64 %r68,[%value_in]; } .loc 1 111 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),cos,(%out_arg1); ld.param.f64 %r70,[%value_in]; } .loc 1 112 0 neg.f64 %r71,%r68; sub.f64 %r40,%r71,%r70; .loc 1 113 0 sub.f64 %r41,%r68,%r70; .loc 1 114 0 setp.gt.s32 %r72,%r43,2145386495; @ %r72 bra $L15; .loc 1 115 0 add.f64 %r74,%r65,%r65; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),cos,(%out_arg1); ld.param.f64 %r75,[%value_in]; } .loc 1 116 0 mul.f64 %r76,%r68,%r70; setp.gt.f64 %r77,%r76,0d0000000000000000; @ ! %r77 bra $L22; div.rn.f64 %r41,%r75,%r40; bra $L15; $L22: .loc 1 117 0 div.rn.f64 %r40,%r75,%r41; $L15: .loc 1 123 0 setp.le.s32 %r78,%r43,1207959552; @ %r78 bra $L18; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r80,[%value_in]; } mul.f64 %r81,%r41,0d3fe20dd750429b6d; div.rn.f64 %r58,%r81,%r80; bra $L19; $L18: .loc 1 125 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),pone,(%out_arg1); ld.param.f64 %r83,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),qone,(%out_arg1); ld.param.f64 %r85,[%value_in]; } .loc 1 126 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r87,[%value_in]; } mul.f64 %r88,%r40,%r85; neg.f64 %r89,%r88; fma.rn.f64 %r90,%r41,%r83,%r89; mul.f64 %r91,%r90,0d3fe20dd750429b6d; div.rn.f64 %r58,%r91,%r87; $L19: .loc 1 128 0 setp.ge.s32 %r92,%r42,0; @ %r92 bra $L11; neg.f64 %r58,%r58; bra $L11; $L14: mul.f64 %r58,%r59,0d3fe0000000000000; .loc 1 131 0 setp.gt.s32 %r93,%r43,1044381695; @ %r93 bra $L20; .loc 1 132 0 add.f64 %r94,%r59,0d7e37e43c8800759c; setp.gt.f64 %r95,%r94,0d3ff0000000000000; @ %r95 bra $L11; $L20: .loc 1 134 0 mul.f64 %r45,%r59,%r59; .loc 1 135 0 fma.rn.f64 %r96,%r45,0d3e6aaafa46ca0bd9,0dbef0c5c6ba169668; fma.rn.f64 %r97,%r96,%r45,0d3f570d9f98472c61; fma.rn.f64 %r98,%r97,%r45,0dbfb0000000000000; mul.f64 %r46,%r98,%r45; .loc 1 137 0 mul.f64 %r99,%r59,%r46; .loc 1 136 0 fma.rn.f64 %r100,%r45,0d3dab2acfcfb97ed8,0d3e35ac88c97dff2c; fma.rn.f64 %r101,%r100,%r45,0d3eb3bff8333f8498; fma.rn.f64 %r102,%r101,%r45,0d3f285f56b9cdf664; fma.rn.f64 %r103,%r102,%r45,0d3f939d0b12637e53; fma.rn.f64 %r104,%r103,%r45,0d3ff0000000000000; .loc 1 138 0 div.rn.f64 %r105,%r99,%r104; add.f64 %r58,%r58,%r105; $L11: .loc 1 139 0 mov.f64 %value,%r58; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y1 .visible .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r42; .reg .f64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .f64 %r53; .reg .f64 %r64; .reg .f64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .f64 %r75; .reg .pred %r76; .reg .f64 %r77; .reg .pred %r78; .reg .f64 %r80; .reg .f64 %r82; .reg .f64 %r83; .reg .pred %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .pred %r89; .reg .pred %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r95; .reg .f64 %r97; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .pred %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r115; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; mov.f64 %r65,%ar0; .loc 1 174 0 mov.b64 %r66,%r65; shr.u64 %r67,%r66,32; cvt.u32.u64 %r50,%r67; .loc 1 175 0 and.b32 %r52,%r50,2147483647; .loc 1 177 0 setp.le.s32 %r68,%r52,2146435071; @ %r68 bra $L24; fma.rn.f64 %r69,%r65,%r65,%r65; mov.f64 %r70,0d3ff0000000000000; div.rn.f64 %r64,%r70,%r69; bra $L23; $L24: .loc 1 178 0 cvt.u32.u64 %r73,%r66; or.b32 %r72,%r52,%r73; setp.ne.u32 %r74,%r72,0; @ %r74 bra $L26; mov.f64 %r75,0dbff0000000000000; div.rn.f64 %r64,%r75,0d0000000000000000; bra $L23; $L26: .loc 1 179 0 setp.ge.s32 %r76,%r50,0; @ %r76 bra $L27; mov.f64 %r77,0d0000000000000000; div.rn.f64 %r64,%r77,0d0000000000000000; bra $L23; $L27: .loc 1 180 0 setp.le.s32 %r78,%r52,1073741823; @ %r78 bra $L28; .loc 1 181 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),sin,(%out_arg1); ld.param.f64 %r80,[%value_in]; } .loc 1 182 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),cos,(%out_arg1); ld.param.f64 %r82,[%value_in]; } .loc 1 183 0 neg.f64 %r83,%r80; sub.f64 %r48,%r83,%r82; .loc 1 184 0 sub.f64 %r49,%r80,%r82; .loc 1 185 0 setp.gt.s32 %r84,%r52,2145386495; @ %r84 bra $L29; .loc 1 186 0 add.f64 %r86,%r65,%r65; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; call (%value_in),cos,(%out_arg1); ld.param.f64 %r87,[%value_in]; } .loc 1 187 0 mul.f64 %r88,%r80,%r82; setp.gt.f64 %r89,%r88,0d0000000000000000; @ ! %r89 bra $L35; div.rn.f64 %r49,%r87,%r48; bra $L29; $L35: .loc 1 188 0 div.rn.f64 %r48,%r87,%r49; $L29: .loc 1 201 0 setp.le.s32 %r90,%r52,1207959552; @ %r90 bra $L32; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r92,[%value_in]; } mul.f64 %r93,%r48,0d3fe20dd750429b6d; div.rn.f64 %r64,%r93,%r92; bra $L23; $L32: .loc 1 203 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),pone,(%out_arg1); ld.param.f64 %r95,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),qone,(%out_arg1); ld.param.f64 %r97,[%value_in]; } .loc 1 204 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r99,[%value_in]; } mul.f64 %r100,%r49,%r97; fma.rn.f64 %r101,%r48,%r95,%r100; mul.f64 %r102,%r101,0d3fe20dd750429b6d; div.rn.f64 %r64,%r102,%r99; bra $L23; $L28: .loc 1 208 0 setp.gt.s32 %r103,%r52,1016070144; @ %r103 bra $L33; .loc 1 209 0 mov.f64 %r104,0dbfe45f306dc9c883; div.rn.f64 %r64,%r104,%r65; bra $L23; $L33: .loc 1 211 0 mul.f64 %r53,%r65,%r65; .loc 1 212 0 fma.rn.f64 %r105,%r53,0dbe78ac00569105b8,0d3ef8ab038fa6b88e; fma.rn.f64 %r106,%r105,%r53,0dbf5f55e54844f50f; fma.rn.f64 %r107,%r106,%r53,0d3fa9d3c776292cd1; fma.rn.f64 %r108,%r107,%r53,0dbfc91866143cbc8a; .loc 1 213 0 fma.rn.f64 %r109,%r53,0d3db25039daca772a,0d3e3abf1d5ba69a86; fma.rn.f64 %r110,%r109,%r53,0d3eb6c05a894e8ca6; fma.rn.f64 %r111,%r110,%r53,0d3f2a8c896c257764; fma.rn.f64 %r112,%r111,%r53,0d3f94650d3f4da9f0; fma.rn.f64 %r113,%r112,%r53,0d3ff0000000000000; .loc 1 214 0 div.rn.f64 %r42,%r108,%r113; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r115,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r117,[%value_in]; } mov.f64 %r119,0d3ff0000000000000; div.rn.f64 %r118,%r119,%r65; neg.f64 %r120,%r118; fma.rn.f64 %r121,%r115,%r117,%r120; mul.f64 %r122,%r121,0d3fe45f306dc9c883; fma.rn.f64 %r64,%r42,%r65,%r122; $L23: .loc 1 215 0 mov.f64 %value,%r64; st.param.f64 [%value_out],%value; ret; } lib_a-e_jn.o/ 0 0 0 644 18004 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_jn .visible .func (.param .f64 %value_out) __ieee754_jn (.param .u32 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_jn.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_yn .visible .func (.param .f64 %value_out) __ieee754_yn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0 .extern .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1 .extern .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0 .extern .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1 .extern .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_jn .visible .func (.param .f64 %value_out) __ieee754_jn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r55; .reg .f64 %r71; .reg .u32 %r73; .reg .f64 %r75; .reg .f64 %r76; .reg .u32 %r77; .reg .f64 %r80; .reg .f64 %r84; .reg .f64 %r85; .reg .u32 %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .u32 %r94; .reg .f64 %r95; .reg .f64 %r97; .reg .f64 %r98; .reg .u32 %r99; .reg .u32 %r100; .reg .u32 %r101; .reg .u32 %r102; .reg .f64 %r104; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .f64 %r115; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .u32 %r120; .reg .f64 %r121; .reg .u32 %r122; .reg .f64 %r127; .reg .f64 %r128; .reg .u32 %r129; .reg .f64 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u32 %r134; .reg .u32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .pred %r139; .reg .pred %r140; .reg .f64 %r142; .reg .pred %r143; .reg .f64 %r145; .reg .u32 %r147; .reg .f64 %r149; .reg .u32 %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r155; .reg .u32 %r156; .reg .u16 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u32 %r160; .reg .u16 %r161; .reg .pred %r162; .reg .pred %r163; .reg .pred %r164; .reg .u32 %r165; .reg .pred %r166; .reg .pred %r167; .reg .pred %r168; .reg .f64 %r170; .reg .f64 %r172; .reg .f64 %r174; .reg .f64 %r176; .reg .f64 %r178; .reg .f64 %r180; .reg .f64 %r181; .reg .f64 %r183; .reg .f64 %r185; .reg .f64 %r187; .reg .f64 %r188; .reg .f64 %r190; .reg .f64 %r192; .reg .u32 %r193; .reg .f64 %r194; .reg .f64 %r195; .reg .f64 %r196; .reg .pred %r197; .reg .pred %r198; .reg .pred %r199; .reg .f64 %r200; .reg .pred %r201; .reg .f64 %r203; .reg .f64 %r204; .reg .pred %r205; .reg .f64 %r206; .reg .pred %r207; .reg .pred %r209; .reg .f64 %r210; .reg .f64 %r211; .reg .f64 %r212; .reg .pred %r213; .reg .f64 %r215; .reg .f64 %r216; .reg .f64 %r218; .reg .f64 %r219; .reg .pred %r220; .reg .f64 %r221; .reg .f64 %r222; .reg .pred %r223; .reg .f64 %r224; .reg .f64 %r225; .reg .pred %r226; .reg .pred %r227; .reg .f64 %r229; .reg .f64 %r230; .reg .pred %r231; .reg .f64 %r233; mov.u32 %r129,%ar0; mov.f64 %r130,%ar1; mov.b64 %r131,%r130; shr.u64 %r132,%r131,32; .loc 1 73 0 cvt.u32.u64 %r99,%r132; cvt.u32.u64 %r100,%r131; .loc 1 74 0 and.b32 %r101,%r99,2147483647; .loc 1 76 0 neg.s32 %r134,%r100; or.b32 %r135,%r134,%r100; shr.u32 %r136,%r135,31; or.b32 %r137,%r136,%r101; setp.le.u32 %r138,%r137,2146435072; @ %r138 bra $L2; add.f64 %r128,%r130,%r130; bra $L1; $L2: .loc 1 77 0 setp.ge.s32 %r139,%r129,0; @ %r139 bra $L4; .loc 1 78 0 neg.s32 %r129,%r129; .loc 1 79 0 neg.f64 %r130,%r130; .loc 1 80 0 add.u32 %r99,%r99,-2147483648; bra $L5; $L4: .loc 1 82 0 setp.ne.u32 %r140,%r129,0; @ %r140 bra $L5; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r130; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r142,[%value_in]; } mov.f64 %r128,%r142; bra $L1; $L5: .loc 1 83 0 setp.ne.u32 %r143,%r129,1; @ %r143 bra $L6; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r130; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r145,[%value_in]; } mov.f64 %r128,%r145; bra $L1; $L6: .loc 1 84 0 shr.u32 %r147,%r99,31; and.b32 %r102,%r147,%r129; .loc 1 85 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r130; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r149,[%value_in]; } .loc 1 86 0 or.b32 %r150,%r100,%r101; set.u32.eq.u32 %r152,%r150,0; neg.s32 %r153,%r152; set.u32.gt.s32 %r155,%r101,2146435071; neg.s32 %r156,%r155; cvt.u16.u32 %r158,%r153; cvt.u16.u32 %r159,%r156; or.b16 %r157,%r158,%r159; cvt.u32.u16 %r160,%r157; cvt.u16.u8 %r161,%r160; setp.ne.u16 %r162,%r161,0; @ %r162 bra $L31; .loc 1 88 0 cvt.rn.f64.s32 %r55,%r129; setp.le.f64 %r163,%r55,%r149; @ ! %r163 bra $L46; .loc 1 90 0 setp.le.s32 %r164,%r101,1389363199; @ %r164 bra $L10; .loc 1 104 0 and.b32 %r165,%r129,3; setp.eq.u32 %r166,%r165,2; @ %r166 bra $L12; setp.eq.u32 %r167,%r165,3; @ %r167 bra $L13; setp.eq.u32 %r168,%r165,1; @ %r168 bra $L14; .loc 1 105 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r170,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r172,[%value_in]; } add.f64 %r95,%r170,%r172; bra $L15; $L14: .loc 1 106 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r174,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r176,[%value_in]; } sub.f64 %r95,%r174,%r176; bra $L15; $L12: .loc 1 107 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r178,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r180,[%value_in]; } neg.f64 %r181,%r178; sub.f64 %r95,%r181,%r180; bra $L15; $L13: .loc 1 108 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r183,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r185,[%value_in]; } sub.f64 %r95,%r183,%r185; $L15: .loc 1 110 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r187,[%value_in]; } mul.f64 %r188,%r95,0d3fe20dd750429b6d; div.rn.f64 %r128,%r188,%r187; bra $L7; $L10: .loc 1 112 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r190,[%value_in]; } mov.f64 %r76,%r190; .loc 1 113 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r192,[%value_in]; } mov.f64 %r121,%r192; .loc 1 114 0 mov.u32 %r122,1; bra $L16; $L32: .loc 1 116 0 mov.f64 %r121,%r128; $L16: add.u32 %r193,%r122,%r122; cvt.rn.f64.s32 %r194,%r193; div.rn.f64 %r195,%r194,%r149; neg.f64 %r196,%r76; fma.rn.f64 %r128,%r195,%r121,%r196; .loc 1 114 0 add.u32 %r122,%r122,1; mov.f64 %r76,%r121; setp.lt.s32 %r197,%r122,%r129; @ %r197 bra $L32; bra $L7; $L46: .loc 1 121 0 setp.gt.s32 %r198,%r101,1041235967; @ %r198 bra $L17; .loc 1 125 0 setp.gt.s32 %r199,%r129,33; @ %r199 bra $L33; .loc 1 128 0 mul.f64 %r117,%r149,0d3fe0000000000000; mov.f64 %r119,%r117; .loc 1 129 0 mov.f64 %r118,0d3ff0000000000000; mov.u32 %r120,2; $L18: .loc 1 130 0 cvt.rn.f64.s32 %r200,%r120; mul.f64 %r118,%r118,%r200; .loc 1 131 0 mul.f64 %r119,%r119,%r117; .loc 1 129 0 add.u32 %r120,%r120,1; setp.le.s32 %r201,%r120,%r129; @ %r201 bra $L18; .loc 1 133 0 div.rn.f64 %r128,%r119,%r118; bra $L7; $L17: .loc 1 167 0 add.u32 %r73,%r129,%r129; cvt.rn.f64.s32 %r203,%r73; div.rn.f64 %r75,%r203,%r149; mov.f64 %r204,0d4000000000000000; div.rn.f64 %r104,%r204,%r149; .loc 1 168 0 add.f64 %r115,%r75,%r104; fma.rn.f64 %r71,%r75,%r115,0dbff0000000000000; .loc 1 169 0 setp.lt.f64 %r205,%r71,0d41cdcd6500000000; @ ! %r205 bra $L47; .loc 1 168 0 mov.u32 %r94,1; $L21: .loc 1 170 0 add.u32 %r94,%r94,1; add.f64 %r115,%r115,%r104; .loc 1 171 0 neg.f64 %r206,%r75; mov.f64 %r75,%r71; .loc 1 173 0 fma.rn.f64 %r71,%r71,%r115,%r206; .loc 1 169 0 setp.lt.f64 %r207,%r71,0d41cdcd6500000000; @ %r207 bra $L21; bra $L19; $L47: .loc 1 168 0 mov.u32 %r94,1; $L19: .loc 1 176 0 add.u32 %r77,%r94,%r129; add.u32 %r114,%r77,%r77; setp.lt.s32 %r209,%r77,%r129; @ %r209 bra $L35; mov.f64 %r98,0d0000000000000000; mov.f64 %r212,0d3ff0000000000000; $L23: cvt.rn.f64.s32 %r210,%r114; div.rn.f64 %r211,%r210,%r149; sub.f64 %r80,%r211,%r98; div.rn.f64 %r98,%r212,%r80; add.u32 %r114,%r114,-2; setp.le.s32 %r213,%r73,%r114; @ %r213 bra $L23; bra $L22; $L35: mov.f64 %r98,0d0000000000000000; $L22: .loc 1 189 0 mul.f64 %r215,%r55,%r104; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r215; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r216,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r216; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r218,[%value_in]; } add.u32 %r113,%r129,-1; add.u32 %r90,%r73,-2; mul.f64 %r219,%r55,%r218; .loc 1 190 0 setp.lt.f64 %r220,%r219,0d40862e42fefa39ef; @ ! %r220 bra $L48; .loc 1 191 0 cvt.rn.f64.s32 %r112,%r90; mov.f64 %r97,%r98; .loc 1 178 0 mov.f64 %r127,0d3ff0000000000000; .loc 1 196 0 mov.f64 %r222,0d4000000000000000; bra $L26; $L36: .loc 1 194 0 mov.f64 %r127,%r93; $L26: .loc 1 193 0 mul.f64 %r221,%r127,%r112; .loc 1 194 0 div.rn.f64 %r84,%r221,%r149; sub.f64 %r93,%r84,%r97; .loc 1 196 0 sub.f64 %r112,%r112,%r222; .loc 1 191 0 add.u32 %r113,%r113,-1; mov.f64 %r97,%r127; setp.ne.u32 %r223,%r113,0; @ %r223 bra $L36; bra $L27; $L48: .loc 1 199 0 cvt.rn.f64.s32 %r110,%r90; mov.f64 %r92,%r98; .loc 1 178 0 mov.f64 %r93,0d3ff0000000000000; .loc 1 204 0 mov.f64 %r225,0d4000000000000000; .loc 1 209 0 mov.f64 %r233,%r93; $L30: .loc 1 201 0 mul.f64 %r224,%r93,%r110; .loc 1 202 0 div.rn.f64 %r85,%r224,%r149; sub.f64 %r109,%r85,%r92; .loc 1 204 0 sub.f64 %r110,%r110,%r225; .loc 1 206 0 setp.gt.f64 %r226,%r109,0d54b249ad2594c37d; @ ! %r226 bra $L49; .loc 1 207 0 div.rn.f64 %r92,%r93,%r109; .loc 1 208 0 div.rn.f64 %r98,%r98,%r109; .loc 1 209 0 mov.f64 %r93,%r233; bra $L28; $L49: mov.f64 %r92,%r93; .loc 1 202 0 mov.f64 %r93,%r109; $L28: .loc 1 199 0 add.u32 %r113,%r113,-1; setp.ne.u32 %r227,%r113,0; @ %r227 bra $L30; $L27: .loc 1 213 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r229,[%value_in]; } mul.f64 %r230,%r229,%r98; div.rn.f64 %r128,%r230,%r93; bra $L7; $L31: .loc 1 87 0 mov.f64 %r128,0d0000000000000000; bra $L7; $L33: mov.f64 %r128,0d0000000000000000; $L7: .loc 1 216 0 setp.ne.u32 %r231,%r102,1; @ %r231 bra $L1; neg.f64 %r128,%r128; $L1: .loc 1 217 0 mov.f64 %value,%r128; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_yn .visible .func (.param .f64 %value_out) __ieee754_yn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .f64 %r61; .reg .u32 %r62; .reg .f64 %r67; .reg .f64 %r71; .reg .u32 %r72; .reg .f64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .pred %r81; .reg .u32 %r82; .reg .pred %r83; .reg .f64 %r84; .reg .pred %r85; .reg .f64 %r86; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .f64 %r93; .reg .pred %r94; .reg .f64 %r96; .reg .f64 %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .f64 %r105; .reg .f64 %r107; .reg .f64 %r109; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r114; .reg .f64 %r116; .reg .f64 %r118; .reg .f64 %r120; .reg .f64 %r122; .reg .f64 %r123; .reg .f64 %r125; .reg .f64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u32 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r135; .reg .u32 %r137; .reg .u32 %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .u16 %r145; .reg .u16 %r146; .reg .u16 %r147; .reg .u32 %r148; .reg .u16 %r149; .reg .pred %r150; .reg .pred %r151; mov.u32 %r72,%ar0; mov.f64 %r73,%ar1; .loc 1 230 0 mov.b64 %r74,%r73; shr.u64 %r75,%r74,32; cvt.u32.u64 %r57,%r75; cvt.u32.u64 %r58,%r74; .loc 1 231 0 and.b32 %r59,%r57,2147483647; .loc 1 233 0 neg.s32 %r77,%r58; or.b32 %r78,%r77,%r58; shr.u32 %r79,%r78,31; or.b32 %r80,%r79,%r59; setp.le.u32 %r81,%r80,2146435072; @ %r81 bra $L51; add.f64 %r71,%r73,%r73; bra $L50; $L51: .loc 1 234 0 or.b32 %r82,%r58,%r59; setp.ne.u32 %r83,%r82,0; @ %r83 bra $L53; mov.f64 %r84,0dbff0000000000000; div.rn.f64 %r71,%r84,0d0000000000000000; bra $L50; $L53: .loc 1 235 0 setp.ge.s32 %r85,%r57,0; @ %r85 bra $L54; mov.f64 %r86,0d0000000000000000; div.rn.f64 %r71,%r86,0d0000000000000000; bra $L50; $L54: .loc 1 237 0 setp.ge.s32 %r87,%r72,0; @ %r87 bra $L55; .loc 1 238 0 neg.s32 %r72,%r72; .loc 1 239 0 add.u32 %r88,%r72,%r72; and.b32 %r89,%r88,2; mov.u32 %r90,1; sub.u32 %r60,%r90,%r89; bra $L56; $L55: .loc 1 241 0 setp.ne.u32 %r91,%r72,0; @ %r91 bra $L66; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y0,(%out_arg1); ld.param.f64 %r93,[%value_in]; } mov.f64 %r71,%r93; bra $L50; $L66: .loc 1 236 0 mov.u32 %r60,1; $L56: .loc 1 242 0 setp.ne.u32 %r94,%r72,1; @ %r94 bra $L57; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y1,(%out_arg1); ld.param.f64 %r96,[%value_in]; } cvt.rn.f64.s32 %r97,%r60; mul.f64 %r71,%r97,%r96; bra $L50; $L57: .loc 1 243 0 setp.eq.u32 %r98,%r59,2146435072; @ %r98 bra $L67; .loc 1 244 0 setp.le.s32 %r99,%r59,1389363199; @ %r99 bra $L58; .loc 1 258 0 and.b32 %r100,%r72,3; setp.eq.u32 %r101,%r100,2; @ %r101 bra $L60; setp.eq.u32 %r102,%r100,3; @ %r102 bra $L61; setp.eq.u32 %r103,%r100,1; @ %r103 bra $L62; .loc 1 259 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r105,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r107,[%value_in]; } sub.f64 %r56,%r105,%r107; bra $L63; $L62: .loc 1 260 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r109,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r111,[%value_in]; } neg.f64 %r112,%r109; sub.f64 %r56,%r112,%r111; bra $L63; $L60: .loc 1 261 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r114,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r116,[%value_in]; } sub.f64 %r56,%r114,%r116; bra $L63; $L61: .loc 1 262 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r118,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r120,[%value_in]; } add.f64 %r56,%r118,%r120; $L63: .loc 1 264 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r122,[%value_in]; } mul.f64 %r123,%r56,0d3fe20dd750429b6d; div.rn.f64 %r71,%r123,%r122; bra $L64; $L58: .loc 1 267 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y0,(%out_arg1); ld.param.f64 %r125,[%value_in]; } mov.f64 %r67,%r125; .loc 1 268 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y1,(%out_arg1); ld.param.f64 %r127,[%value_in]; } mov.f64 %r61,%r127; .loc 1 271 0 mov.b64 %r128,%r61; shr.u64 %r129,%r128,32; cvt.u32.u64 %r130,%r129; setp.eq.u32 %r131,%r130,-1048576; @ %r131 bra $L68; mov.u32 %r62,1; bra $L65; $L69: .loc 1 273 0 mov.f64 %r61,%r71; $L65: add.u32 %r132,%r62,%r62; cvt.rn.f64.s32 %r133,%r132; div.rn.f64 %r134,%r133,%r73; neg.f64 %r135,%r67; fma.rn.f64 %r71,%r134,%r61,%r135; .loc 1 271 0 add.u32 %r62,%r62,1; mov.f64 %r67,%r61; set.u32.lt.s32 %r137,%r62,%r72; neg.s32 %r138,%r137; mov.b64 %r139,%r71; shr.u64 %r140,%r139,32; cvt.u32.u64 %r142,%r140; set.u32.ne.u32 %r143,%r142,-1048576; neg.s32 %r144,%r143; cvt.u16.u32 %r146,%r138; cvt.u16.u32 %r147,%r144; and.b16 %r145,%r146,%r147; cvt.u32.u16 %r148,%r145; cvt.u16.u8 %r149,%r148; setp.ne.u16 %r150,%r149,0; @ %r150 bra $L69; bra $L64; $L68: .loc 1 268 0 mov.f64 %r71,%r127; $L64: .loc 1 278 0 setp.eq.u32 %r151,%r60,1; @ %r151 bra $L50; neg.f64 %r71,%r71; bra $L50; $L67: .loc 1 243 0 mov.f64 %r71,0d0000000000000000; $L50: .loc 1 279 0 mov.f64 %value,%r71; st.param.f64 [%value_out],%value; ret; } lib_a-e_log.o/ 0 0 0 644 5660 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .visible .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_log.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_log .visible .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .f64 %r63; .reg .u32 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .u32 %r69; .reg .f64 %r70; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .u32 %r79; .reg .f64 %r82; .reg .f64 %r85; .reg .u64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .pred %r96; .reg .f64 %r97; .reg .pred %r98; .reg .f64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u32 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u32 %r112; .reg .f64 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .f64 %r119; .reg .f64 %r121; .reg .f64 %r122; .reg .pred %r123; .reg .f64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .u32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .pred %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .pred %r148; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; mov.f64 %r88,%ar0; mov.b64 %r89,%r88; shr.u64 %r90,%r89,32; cvt.u32.u64 %r79,%r90; .loc 1 102 0 cvt.u32.u64 %r58,%r90; .loc 1 105 0 setp.gt.s32 %r91,%r79,1048575; @ %r91 bra $L13; .loc 1 106 0 and.b32 %r92,%r79,2147483647; cvt.u32.u64 %r95,%r89; or.b32 %r94,%r92,%r95; setp.ne.u32 %r96,%r94,0; @ %r96 bra $L3; .loc 1 107 0 mov.f64 %r97,0dc350000000000000; div.rn.f64 %r87,%r97,0d0000000000000000; bra $L1; $L3: .loc 1 108 0 setp.ge.s32 %r98,%r79,0; @ %r98 bra $L5; sub.f64 %r99,%r88,%r88; div.rn.f64 %r87,%r99,0d0000000000000000; bra $L1; $L5: .loc 1 109 0 mul.f64 %r88,%r88,0d4350000000000000; .loc 1 110 0 mov.b64 %r100,%r88; shr.u64 %r101,%r100,32; cvt.u32.u64 %r58,%r101; .loc 1 109 0 mov.u32 %r57,-54; bra $L2; $L13: .loc 1 104 0 mov.u32 %r57,0; $L2: .loc 1 112 0 setp.le.s32 %r102,%r58,2146435071; @ %r102 bra $L6; add.f64 %r87,%r88,%r88; bra $L1; $L6: .loc 1 113 0 shr.s32 %r103,%r58,20; add.u32 %r104,%r103,-1023; add.u32 %r60,%r104,%r57; .loc 1 114 0 and.b32 %r61,%r58,1048575; .loc 1 115 0 add.u32 %r105,%r61,614244; and.b32 %r62,%r105,1048576; .loc 1 116 0 mov.b64 %r86,%r88; xor.b32 %r106,%r62,1072693248; or.b32 %r107,%r106,%r61; cvt.u64.u32 %r108,%r107; shl.b64 %r109,%r108,32; and.b64 %r110,%r86,4294967295; or.b64 %r111,%r110,%r109; mov.b64 %r63,%r111; .loc 1 117 0 shr.s32 %r112,%r62,20; add.u32 %r64,%r112,%r60; .loc 1 118 0 mov.f64 %r113,0d3ff0000000000000; sub.f64 %r65,%r63,%r113; .loc 1 119 0 add.u32 %r114,%r61,2; and.b32 %r115,%r114,1048575; setp.gt.s32 %r116,%r115,2; @ %r116 bra $L7; .loc 1 120 0 setp.neu.f64 %r117,%r65,0d0000000000000000; @ %r117 bra $L8; setp.eq.u32 %r118,%r64,0; @ %r118 bra $L14; cvt.rn.f64.s32 %r78,%r64; .loc 1 121 0 mul.f64 %r119,%r78,0d3dea39ef35793c76; fma.rn.f64 %r87,%r78,0d3fe62e42fee00000,%r119; bra $L1; $L8: .loc 1 122 0 fma.rn.f64 %r121,%r65,0dbfd5555555555555,0d3fe0000000000000; mul.f64 %r122,%r65,%r65; mul.f64 %r76,%r121,%r122; .loc 1 123 0 setp.ne.u32 %r123,%r64,0; @ %r123 bra $L9; sub.f64 %r87,%r65,%r76; bra $L1; $L9: cvt.rn.f64.s32 %r77,%r64; .loc 1 124 0 fma.rn.f64 %r125,%r77,0dbdea39ef35793c76,%r76; sub.f64 %r126,%r125,%r65; neg.f64 %r127,%r126; fma.rn.f64 %r87,%r77,0d3fe62e42fee00000,%r127; bra $L1; $L7: .loc 1 126 0 add.f64 %r128,%r65,0d4000000000000000; div.rn.f64 %r66,%r65,%r128; .loc 1 127 0 cvt.rn.f64.s32 %r67,%r64; .loc 1 128 0 mul.f64 %r68,%r66,%r66; .loc 1 129 0 add.u32 %r69,%r61,-398458; .loc 1 130 0 mul.f64 %r70,%r68,%r68; .loc 1 132 0 fma.rn.f64 %r129,%r70,0d3fc39a09d078c69f,0d3fcc71c51d8e78af; fma.rn.f64 %r130,%r129,%r70,0d3fd999999997fa04; .loc 1 133 0 fma.rn.f64 %r131,%r70,0d3fc2f112df3e5244,0d3fc7466496cb03de; fma.rn.f64 %r132,%r131,%r70,0d3fd2492494229359; fma.rn.f64 %r133,%r132,%r70,0d3fe5555555555593; mul.f64 %r134,%r133,%r68; .loc 1 135 0 fma.rn.f64 %r74,%r130,%r70,%r134; .loc 1 131 0 mov.u32 %r136,440401; sub.u32 %r135,%r136,%r61; .loc 1 134 0 or.b32 %r137,%r135,%r69; .loc 1 136 0 setp.le.s32 %r138,%r137,0; @ %r138 bra $L10; .loc 1 137 0 mul.f64 %r139,%r65,0d3fe0000000000000; mul.f64 %r75,%r139,%r65; add.f64 %r140,%r74,%r75; mul.f64 %r82,%r140,%r66; .loc 1 138 0 setp.ne.u32 %r141,%r64,0; @ %r141 bra $L11; sub.f64 %r142,%r75,%r82; sub.f64 %r87,%r65,%r142; bra $L1; $L11: .loc 1 139 0 fma.rn.f64 %r143,%r67,0d3dea39ef35793c76,%r82; sub.f64 %r144,%r75,%r143; sub.f64 %r145,%r144,%r65; neg.f64 %r146,%r145; fma.rn.f64 %r87,%r67,0d3fe62e42fee00000,%r146; bra $L1; $L10: sub.f64 %r147,%r65,%r74; mul.f64 %r85,%r147,%r66; .loc 1 141 0 setp.ne.u32 %r148,%r64,0; @ %r148 bra $L12; sub.f64 %r87,%r65,%r85; bra $L1; $L12: .loc 1 142 0 fma.rn.f64 %r150,%r67,0dbdea39ef35793c76,%r85; sub.f64 %r151,%r150,%r65; neg.f64 %r152,%r151; fma.rn.f64 %r87,%r67,0d3fe62e42fee00000,%r152; bra $L1; $L14: .loc 1 120 0 mov.f64 %r87,0d0000000000000000; $L1: .loc 1 144 0 mov.f64 %value,%r87; st.param.f64 [%value_out],%value; ret; } lib_a-e_log10.o/0 0 0 644 2886 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10 .visible .func (.param .f64 %value_out) __ieee754_log10 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_log10.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_log10 .visible .func (.param .f64 %value_out) __ieee754_log10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .f64 %r41; .reg .f64 %r42; .reg .u32 %r44; .reg .u64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .f64 %r58; .reg .pred %r59; .reg .f64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; mov.f64 %r49,%ar0; mov.b64 %r50,%r49; shr.u64 %r51,%r50,32; cvt.u32.u64 %r44,%r51; .loc 1 78 0 cvt.u32.u64 %r37,%r51; .loc 1 81 0 setp.gt.s32 %r52,%r44,1048575; @ %r52 bra $L7; .loc 1 82 0 and.b32 %r53,%r44,2147483647; cvt.u32.u64 %r56,%r50; or.b32 %r55,%r53,%r56; setp.ne.u32 %r57,%r55,0; @ %r57 bra $L3; .loc 1 83 0 mov.f64 %r58,0dc350000000000000; div.rn.f64 %r48,%r58,0d0000000000000000; bra $L1; $L3: .loc 1 84 0 setp.ge.s32 %r59,%r44,0; @ %r59 bra $L5; sub.f64 %r60,%r49,%r49; div.rn.f64 %r48,%r60,0d0000000000000000; bra $L1; $L5: .loc 1 85 0 mul.f64 %r49,%r49,0d4350000000000000; .loc 1 86 0 mov.b64 %r61,%r49; shr.u64 %r62,%r61,32; cvt.u32.u64 %r37,%r62; .loc 1 85 0 mov.u32 %r36,-54; bra $L2; $L7: .loc 1 80 0 mov.u32 %r36,0; $L2: .loc 1 88 0 setp.le.s32 %r63,%r37,2146435071; @ %r63 bra $L6; add.f64 %r48,%r49,%r49; bra $L1; $L6: .loc 1 89 0 shr.s32 %r64,%r37,20; add.u32 %r65,%r64,-1023; add.u32 %r38,%r65,%r36; .loc 1 90 0 shr.u32 %r39,%r38,31; .loc 1 91 0 and.b32 %r29,%r37,1048575; .loc 1 92 0 add.u32 %r66,%r38,%r39; cvt.rn.f64.s32 %r41,%r66; .loc 1 93 0 mov.b64 %r47,%r49; .loc 1 91 0 mov.u32 %r68,1023; sub.u32 %r67,%r68,%r39; shl.b32 %r69,%r67,20; or.b32 %r70,%r69,%r29; .loc 1 93 0 cvt.u64.u32 %r71,%r70; shl.b64 %r72,%r71,32; and.b64 %r73,%r47,4294967295; or.b64 %r74,%r73,%r72; mov.b64 %r42,%r74; .loc 1 94 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r76,[%value_in]; } mul.f64 %r77,%r76,0d3fdbcb7b1526e50e; fma.rn.f64 %r78,%r41,0d3d59fef311f12b36,%r77; .loc 1 95 0 fma.rn.f64 %r48,%r41,0d3fd34413509f6000,%r78; $L1: .loc 1 96 0 mov.f64 %value,%r48; st.param.f64 [%value_out],%value; ret; } lib_a-e_pow.o/ 0 0 0 644 20877 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __ieee754_pow .visible .func (.param .f64 %value_out) __ieee754_pow (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_pow.c" // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_pow .visible .func (.param .f64 %value_out) __ieee754_pow (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %r34; .reg .u32 %r39; .reg .f64 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .f64 %r54; .reg .u32 %r119; .reg .f64 %r133; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .u32 %r146; .reg .u32 %r147; .reg .u32 %r149; .reg .u32 %r150; .reg .u32 %r151; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .u32 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .f64 %r163; .reg .f64 %r164; .reg .f64 %r165; .reg .f64 %r167; .reg .f64 %r168; .reg .f64 %r169; .reg .f64 %r171; .reg .f64 %r173; .reg .f64 %r175; .reg .f64 %r177; .reg .f64 %r178; .reg .u32 %r180; .reg .u32 %r181; .reg .f64 %r183; .reg .f64 %r185; .reg .f64 %r187; .reg .f64 %r188; .reg .u32 %r190; .reg .u32 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .f64 %r195; .reg .f64 %r197; .reg .f64 %r198; .reg .f64 %r199; .reg .f64 %r200; .reg .f64 %r201; .reg .f64 %r202; .reg .f64 %r204; .reg .u32 %r205; .reg .u32 %r206; .reg .f64 %r211; .reg .f64 %r214; .reg .f64 %r216; .reg .u32 %r217; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .u64 %r238; .reg .f64 %r240; .reg .f64 %r241; .reg .f64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u32 %r246; .reg .pred %r247; .reg .u64 %r248; .reg .u64 %r249; .reg .pred %r251; .reg .u32 %r253; .reg .u32 %r254; .reg .u32 %r256; .reg .u32 %r257; .reg .u16 %r258; .reg .u16 %r259; .reg .u16 %r260; .reg .u32 %r261; .reg .u16 %r262; .reg .pred %r263; .reg .pred %r264; .reg .u32 %r266; .reg .u32 %r267; .reg .u32 %r269; .reg .u32 %r270; .reg .u16 %r271; .reg .u16 %r272; .reg .u16 %r273; .reg .u32 %r274; .reg .u16 %r275; .reg .pred %r276; .reg .u32 %r277; .reg .u32 %r278; .reg .pred %r279; .reg .u64 %r280; .reg .f64 %r281; .reg .pred %r282; .reg .pred %r283; .reg .pred %r284; .reg .u32 %r285; .reg .pred %r286; .reg .u32 %r287; .reg .u32 %r288; .reg .pred %r289; .reg .u32 %r290; .reg .u32 %r291; .reg .pred %r292; .reg .u32 %r293; .reg .u32 %r294; .reg .pred %r295; .reg .u32 %r296; .reg .u32 %r297; .reg .pred %r298; .reg .pred %r299; .reg .u32 %r300; .reg .u32 %r301; .reg .pred %r302; .reg .pred %r303; .reg .pred %r304; .reg .pred %r305; .reg .pred %r306; .reg .pred %r307; .reg .f64 %r308; .reg .pred %r309; .reg .u32 %r311; .reg .u32 %r312; .reg .u32 %r314; .reg .u32 %r315; .reg .u16 %r317; .reg .u16 %r318; .reg .u16 %r319; .reg .u32 %r320; .reg .u16 %r321; .reg .pred %r322; .reg .f64 %r324; .reg .f64 %r326; .reg .pred %r327; .reg .u32 %r328; .reg .u32 %r330; .reg .u32 %r331; .reg .u32 %r333; .reg .u32 %r334; .reg .u16 %r335; .reg .u16 %r336; .reg .u16 %r337; .reg .u32 %r338; .reg .u16 %r339; .reg .pred %r340; .reg .pred %r341; .reg .f64 %r342; .reg .pred %r343; .reg .u32 %r344; .reg .u32 %r345; .reg .pred %r346; .reg .pred %r347; .reg .u32 %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .pred %r353; .reg .pred %r354; .reg .f64 %r355; .reg .pred %r356; .reg .pred %r357; .reg .pred %r358; .reg .pred %r359; .reg .pred %r360; .reg .f64 %r361; .reg .f64 %r362; .reg .f64 %r363; .reg .f64 %r364; .reg .f64 %r365; .reg .f64 %r366; .reg .f64 %r367; .reg .f64 %r369; .reg .f64 %r370; .reg .u64 %r371; .reg .f64 %r373; .reg .pred %r374; .reg .u64 %r375; .reg .u64 %r376; .reg .u32 %r377; .reg .u32 %r378; .reg .pred %r379; .reg .pred %r380; .reg .u64 %r381; .reg .u64 %r382; .reg .u64 %r383; .reg .u64 %r384; .reg .f64 %r385; .reg .f64 %r386; .reg .u64 %r387; .reg .u32 %r388; .reg .u32 %r389; .reg .u32 %r390; .reg .u32 %r391; .reg .u64 %r392; .reg .u64 %r393; .reg .f64 %r396; .reg .f64 %r398; .reg .f64 %r399; .reg .f64 %r400; .reg .f64 %r401; .reg .f64 %r402; .reg .f64 %r403; .reg .f64 %r404; .reg .f64 %r405; .reg .f64 %r406; .reg .f64 %r407; .reg .f64 %r408; .reg .f64 %r409; .reg .f64 %r410; .reg .f64 %r411; .reg .u64 %r412; .reg .f64 %r414; .reg .f64 %r415; .reg .f64 %r416; .reg .f64 %r417; .reg .f64 %r418; .reg .f64 %r419; .reg .u64 %r420; .reg .f64 %r422; .reg .f64 %r423; .reg .f64 %r424; .reg .f64 %r425; .reg .f64 %r426; .reg .f64 %r427; .reg .f64 %r428; .reg .u64 %r429; .reg .f64 %r431; .reg .f64 %r432; .reg .f64 %r433; .reg .u32 %r434; .reg .u32 %r435; .reg .pred %r436; .reg .u64 %r437; .reg .f64 %r438; .reg .f64 %r439; .reg .u64 %r440; .reg .u64 %r441; .reg .pred %r443; .reg .u32 %r444; .reg .u32 %r445; .reg .pred %r446; .reg .f64 %r447; .reg .f64 %r448; .reg .f64 %r449; .reg .pred %r450; .reg .f64 %r451; .reg .u32 %r452; .reg .pred %r453; .reg .u32 %r454; .reg .u32 %r455; .reg .pred %r456; .reg .f64 %r457; .reg .f64 %r458; .reg .pred %r459; .reg .f64 %r460; .reg .pred %r461; .reg .u32 %r462; .reg .u32 %r463; .reg .u32 %r464; .reg .u32 %r465; .reg .u32 %r466; .reg .u32 %r467; .reg .u32 %r468; .reg .u32 %r469; .reg .u32 %r470; .reg .u32 %r471; .reg .u64 %r472; .reg .u64 %r473; .reg .u32 %r476; .reg .u32 %r477; .reg .u32 %r478; .reg .pred %r479; .reg .u64 %r481; .reg .f64 %r482; .reg .f64 %r483; .reg .f64 %r484; .reg .f64 %r486; .reg .f64 %r487; .reg .f64 %r488; .reg .f64 %r489; .reg .f64 %r490; .reg .f64 %r491; .reg .f64 %r492; .reg .f64 %r493; .reg .f64 %r494; .reg .f64 %r495; .reg .f64 %r496; .reg .f64 %r497; .reg .f64 %r498; .reg .u64 %r499; .reg .u64 %r500; .reg .u32 %r501; .reg .pred %r503; .reg .f64 %r506; .reg .u64 %r507; .reg .u64 %r508; .reg .u64 %r509; .reg .u64 %r510; .reg .f64 %r512; mov.f64 %r241,%ar0; mov.f64 %r242,%ar1; .loc 1 115 0 mov.b64 %r243,%r242; shr.u64 %r244,%r243,32; cvt.u32.u64 %r150,%r244; cvt.u32.u64 %r49,%r243; .loc 1 116 0 and.b32 %r151,%r150,2147483647; .loc 1 119 0 or.b32 %r246,%r151,%r49; setp.eq.u32 %r247,%r246,0; @ %r247 bra $L39; mov.b64 %r248,%r241; shr.u64 %r249,%r248,32; cvt.u32.u64 %r155,%r249; .loc 1 114 0 cvt.u32.u64 %r149,%r249; cvt.u32.u64 %r156,%r248; .loc 1 116 0 and.b32 %r146,%r155,2147483647; .loc 1 122 0 setp.gt.s32 %r251,%r146,2146435072; @ %r251 bra $L3; set.u32.eq.u32 %r253,%r146,2146435072; neg.s32 %r254,%r253; set.u32.ne.u32 %r256,%r156,0; neg.s32 %r257,%r256; cvt.u16.u32 %r259,%r254; cvt.u16.u32 %r260,%r257; and.b16 %r258,%r259,%r260; cvt.u32.u16 %r261,%r258; cvt.u16.u8 %r262,%r261; setp.ne.u16 %r263,%r262,0; @ %r263 bra $L4; setp.gt.s32 %r264,%r151,2146435072; @ %r264 bra $L3; .loc 1 123 0 set.u32.eq.u32 %r266,%r151,2146435072; neg.s32 %r267,%r266; set.u32.ne.u32 %r269,%r49,0; neg.s32 %r270,%r269; cvt.u16.u32 %r272,%r267; cvt.u16.u32 %r273,%r270; and.b16 %r271,%r272,%r273; cvt.u32.u16 %r274,%r271; cvt.u16.u8 %r275,%r274; setp.eq.u16 %r276,%r275,0; @ %r276 bra $L5; $L3: .loc 1 124 0 add.u32 %r277,%r146,-1072693248; or.b32 %r278,%r277,%r156; setp.eq.u32 %r279,%r278,0; @ %r279 bra $L40; $L4: .loc 1 125 0 cvta.const.u64 %r280,$LC0; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r280; call (%value_in),nan,(%out_arg1); ld.param.f64 %r281,[%value_in]; } mov.f64 %r240,%r281; bra $L1; $L5: .loc 1 134 0 setp.ge.s32 %r282,%r155,0; @ %r282 bra $L41; .loc 1 135 0 setp.gt.s32 %r283,%r151,1128267775; @ %r283 bra $L42; .loc 1 136 0 setp.le.s32 %r284,%r151,1072693247; @ %r284 bra $L43; .loc 1 137 0 shr.s32 %r285,%r151,20; add.u32 %r152,%r285,-1023; .loc 1 138 0 setp.le.s32 %r286,%r152,20; @ %r286 bra $L7; .loc 1 139 0 mov.u32 %r287,52; sub.u32 %r34,%r287,%r152; shr.u32 %r154,%r49,%r34; .loc 1 140 0 shl.b32 %r288,%r154,%r34; setp.ne.u32 %r289,%r288,%r49; @ %r289 bra $L44; and.b32 %r290,%r154,1; mov.u32 %r291,2; sub.u32 %r142,%r291,%r290; bra $L6; $L7: .loc 1 141 0 setp.ne.u32 %r292,%r49,0; @ %r292 bra $L45; .loc 1 142 0 mov.u32 %r293,20; sub.u32 %r39,%r293,%r152; shr.s32 %r153,%r151,%r39; .loc 1 143 0 shl.b32 %r294,%r153,%r39; setp.ne.u32 %r295,%r294,%r151; @ %r295 bra $L46; and.b32 %r296,%r153,1; mov.u32 %r297,2; sub.u32 %r142,%r297,%r296; bra $L10; $L41: .loc 1 133 0 mov.u32 %r142,0; bra $L6; $L42: .loc 1 135 0 mov.u32 %r142,2; bra $L6; $L43: .loc 1 133 0 mov.u32 %r142,0; bra $L6; $L44: mov.u32 %r142,0; $L6: .loc 1 149 0 setp.ne.u32 %r298,%r49,0; @ %r298 bra $L8; .loc 1 150 0 setp.ne.u32 %r299,%r151,2146435072; @ %r299 bra $L10; .loc 1 151 0 add.u32 %r300,%r146,-1072693248; or.b32 %r301,%r300,%r156; setp.eq.u32 %r302,%r301,0; @ %r302 bra $L47; .loc 1 153 0 setp.le.s32 %r303,%r146,1072693247; @ %r303 bra $L11; .loc 1 154 0 setp.ge.s32 %r304,%r150,0; @ %r304 bra $L48; $L12: mov.f64 %r240,0d0000000000000000; bra $L1; $L11: .loc 1 156 0 setp.ge.s32 %r305,%r150,0; @ %r305 bra $L12; neg.f64 %r240,%r242; bra $L1; $L10: .loc 1 158 0 setp.ne.u32 %r306,%r151,1072693248; @ %r306 bra $L13; .loc 1 159 0 setp.ge.s32 %r307,%r150,0; @ %r307 bra $L49; mov.f64 %r308,0d3ff0000000000000; div.rn.f64 %r240,%r308,%r241; bra $L1; $L13: .loc 1 161 0 setp.ne.u32 %r309,%r150,1073741824; @ %r309 bra $L14; mul.f64 %r240,%r241,%r241; bra $L1; $L14: .loc 1 162 0 set.u32.eq.u32 %r311,%r150,1071644672; neg.s32 %r312,%r311; .loc 1 163 0 not.b32 %r314,%r149; shr.u32 %r315,%r314,31; cvt.u16.u32 %r318,%r312; cvt.u16.u32 %r319,%r315; and.b16 %r317,%r318,%r319; cvt.u32.u16 %r320,%r317; cvt.u16.u8 %r321,%r320; setp.eq.u16 %r322,%r321,0; @ %r322 bra $L8; .loc 1 164 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r241; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r324,[%value_in]; } mov.f64 %r240,%r324; bra $L1; $L45: .loc 1 133 0 mov.u32 %r142,0; $L8: .loc 1 168 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r241; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r326,[%value_in]; } mov.f64 %r240,%r326; .loc 1 170 0 setp.ne.u32 %r327,%r156,0; @ %r327 bra $L15; .loc 1 171 0 and.b32 %r328,%r149,1073741823; set.u32.eq.u32 %r330,%r328,1072693248; neg.s32 %r331,%r330; set.u32.eq.u32 %r333,%r146,0; neg.s32 %r334,%r333; cvt.u16.u32 %r336,%r331; cvt.u16.u32 %r337,%r334; or.b16 %r335,%r336,%r337; cvt.u32.u16 %r338,%r335; cvt.u16.u8 %r339,%r338; setp.eq.u16 %r340,%r339,0; @ %r340 bra $L15; .loc 1 173 0 setp.ge.s32 %r341,%r150,0; @ %r341 bra $L16; mov.f64 %r342,0d3ff0000000000000; div.rn.f64 %r240,%r342,%r240; $L16: .loc 1 174 0 setp.ge.s32 %r343,%r149,0; @ %r343 bra $L1; .loc 1 175 0 add.u32 %r344,%r146,-1072693248; or.b32 %r345,%r344,%r142; setp.ne.u32 %r346,%r345,0; @ %r346 bra $L17; .loc 1 176 0 sub.f64 %r48,%r240,%r240; div.rn.f64 %r240,%r48,%r48; bra $L1; $L17: .loc 1 177 0 setp.ne.u32 %r347,%r142,1; @ %r347 bra $L1; .loc 1 178 0 neg.f64 %r240,%r240; bra $L1; $L15: .loc 1 189 0 set.u32.ge.s32 %r51,%r155,0; or.b32 %r349,%r142,%r51; setp.ne.u32 %r350,%r349,0; @ %r350 bra $L18; sub.f64 %r54,%r241,%r241; div.rn.f64 %r240,%r54,%r54; bra $L1; $L18: .loc 1 192 0 setp.le.s32 %r351,%r151,1105199104; @ %r351 bra $L19; .loc 1 193 0 setp.le.s32 %r352,%r151,1139802112; @ %r352 bra $L20; .loc 1 194 0 setp.gt.s32 %r353,%r146,1072693247; @ %r353 bra $L21; setp.ge.s32 %r354,%r150,0; @ %r354 bra $L12; $L22: mov.f64 %r355,0d7e37e43c8800759c; mul.f64 %r240,%r355,0d7e37e43c8800759c; bra $L1; $L21: .loc 1 195 0 setp.gt.s32 %r356,%r150,0; @ %r356 bra $L22; bra $L12; $L20: .loc 1 198 0 setp.gt.s32 %r357,%r146,1072693246; @ %r357 bra $L23; setp.lt.s32 %r358,%r150,0; @ ! %r358 bra $L12; bra $L22; $L23: .loc 1 199 0 setp.le.s32 %r359,%r146,1072693248; @ %r359 bra $L24; setp.gt.s32 %r360,%r150,0; @ %r360 bra $L22; bra $L12; $L24: .loc 1 202 0 mov.f64 %r361,0d3ff0000000000000; sub.f64 %r183,%r326,%r361; .loc 1 203 0 neg.f64 %r362,%r183; fma.rn.f64 %r363,%r362,0d3fd0000000000000,0d3fd5555555555555; neg.f64 %r364,%r363; fma.rn.f64 %r365,%r364,%r183,0d3fe0000000000000; mul.f64 %r366,%r183,%r183; mul.f64 %r367,%r365,%r366; .loc 1 205 0 mul.f64 %r369,%r367,0dbff71547652b82fe; fma.rn.f64 %r185,%r183,0d3e54ae0bf85ddf44,%r369; .loc 1 206 0 fma.rn.f64 %r370,%r183,0d3ff7154760000000,%r185; .loc 1 207 0 mov.b64 %r229,%r370; and.b64 %r371,%r229,-4294967296; mov.b64 %r139,%r371; .loc 1 208 0 fma.rn.f64 %r373,%r362,0d3ff7154760000000,%r139; sub.f64 %r140,%r185,%r373; bra $L25; $L19: .loc 1 213 0 setp.gt.s32 %r374,%r146,1048575; @ %r374 bra $L50; .loc 1 214 0 mul.f64 %r240,%r326,0d4340000000000000; mov.b64 %r375,%r240; shr.u64 %r376,%r375,32; cvt.u32.u64 %r146,%r376; mov.u32 %r143,-53; bra $L26; $L50: .loc 1 211 0 mov.u32 %r143,0; $L26: .loc 1 215 0 shr.s32 %r377,%r146,20; add.u32 %r378,%r377,-1023; add.u32 %r144,%r378,%r143; .loc 1 216 0 and.b32 %r159,%r146,1048575; .loc 1 218 0 or.b32 %r147,%r159,1072693248; .loc 1 219 0 setp.le.s32 %r379,%r159,235662; @ %r379 bra $L51; .loc 1 220 0 setp.le.s32 %r380,%r159,767609; @ %r380 bra $L52; .loc 1 221 0 add.u32 %r144,%r144,1; add.u32 %r147,%r147,-1048576; mov.f64 %r211,0d0000000000000000; mov.f64 %r216,%r211; mov.u32 %r217,0; mov.f64 %r214,0d3ff0000000000000; bra $L27; $L51: mov.f64 %r211,0d0000000000000000; mov.f64 %r216,%r211; mov.u32 %r217,0; mov.f64 %r214,0d3ff0000000000000; bra $L27; $L52: mov.f64 %r211,0d3fe2b80340000000; mov.f64 %r216,0d3e4cfdeb43cfd006; mov.u32 %r217,262144; mov.f64 %r214,0d3ff8000000000000; $L27: .loc 1 222 0 mov.b64 %r230,%r240; cvt.u64.u32 %r381,%r147; shl.b64 %r382,%r381,32; and.b64 %r383,%r230,4294967295; or.b64 %r384,%r383,%r382; mov.b64 %r160,%r384; .loc 1 225 0 sub.f64 %r161,%r160,%r214; .loc 1 226 0 add.f64 %r385,%r160,%r214; mov.f64 %r386,0d3ff0000000000000; div.rn.f64 %r162,%r386,%r385; .loc 1 227 0 mul.f64 %r163,%r161,%r162; .loc 1 229 0 mov.b64 %r231,%r163; and.b64 %r387,%r231,-4294967296; mov.b64 %r164,%r387; .loc 1 232 0 shr.s32 %r388,%r147,1; or.b32 %r389,%r388,536870912; add.u32 %r390,%r389,524288; add.u32 %r391,%r390,%r217; cvt.u64.u32 %r392,%r391; shl.b64 %r393,%r392,32; mov.b64 %r165,%r393; .loc 1 234 0 neg.f64 %r396,%r164; fma.rn.f64 %r398,%r396,%r165,%r161; .loc 1 233 0 sub.f64 %r399,%r165,%r214; sub.f64 %r400,%r160,%r399; .loc 1 234 0 fma.rn.f64 %r401,%r396,%r400,%r398; mul.f64 %r167,%r401,%r162; .loc 1 236 0 mul.f64 %r168,%r163,%r163; .loc 1 237 0 mul.f64 %r402,%r168,%r168; .loc 1 238 0 add.f64 %r403,%r163,%r164; mul.f64 %r404,%r403,%r167; .loc 1 237 0 fma.rn.f64 %r405,%r168,0d3fca7e284a454eef,0d3fcd864a93c9db65; fma.rn.f64 %r406,%r405,%r168,0d3fd17460a91d4101; fma.rn.f64 %r407,%r406,%r168,0d3fd55555518f264d; fma.rn.f64 %r408,%r407,%r168,0d3fdb6db6db6fabff; fma.rn.f64 %r409,%r408,%r168,0d3fe3333333333303; .loc 1 238 0 fma.rn.f64 %r169,%r402,%r409,%r404; .loc 1 240 0 fma.rn.f64 %r410,%r164,%r164,0d4008000000000000; add.f64 %r411,%r410,%r169; .loc 1 241 0 mov.b64 %r233,%r411; and.b64 %r412,%r233,-4294967296; mov.b64 %r171,%r412; .loc 1 242 0 mov.f64 %r415,0d4008000000000000; sub.f64 %r414,%r171,%r415; fma.rn.f64 %r416,%r396,%r164,%r414; sub.f64 %r417,%r169,%r416; .loc 1 245 0 mul.f64 %r418,%r417,%r163; fma.rn.f64 %r173,%r167,%r171,%r418; .loc 1 247 0 fma.rn.f64 %r419,%r164,%r171,%r173; .loc 1 248 0 mov.b64 %r234,%r419; and.b64 %r420,%r234,-4294967296; mov.b64 %r175,%r420; .loc 1 249 0 fma.rn.f64 %r422,%r396,%r171,%r175; sub.f64 %r423,%r173,%r422; .loc 1 251 0 mul.f64 %r424,%r423,0d3feec709dc3a03fd; fma.rn.f64 %r425,%r175,0dbe3e2fe0145b01f5,%r424; add.f64 %r177,%r425,%r216; .loc 1 253 0 cvt.rn.f64.s32 %r178,%r144; .loc 1 254 0 fma.rn.f64 %r426,%r175,0d3feec709e0000000,%r177; add.f64 %r427,%r426,%r211; add.f64 %r428,%r427,%r178; .loc 1 255 0 mov.b64 %r235,%r428; and.b64 %r429,%r235,-4294967296; mov.b64 %r139,%r429; .loc 1 256 0 sub.f64 %r431,%r139,%r178; sub.f64 %r432,%r431,%r211; fma.rn.f64 %r433,%r175,0dbfeec709e0000000,%r432; sub.f64 %r140,%r177,%r433; $L25: .loc 1 260 0 add.u32 %r434,%r142,-1; or.b32 %r435,%r434,%r51; setp.eq.u32 %r436,%r435,0; .loc 1 259 0 selp.f64 %r141,0dbff0000000000000,0d3ff0000000000000,%r436; .loc 1 265 0 mov.b64 %r236,%r242; and.b64 %r437,%r236,-4294967296; mov.b64 %r187,%r437; .loc 1 266 0 sub.f64 %r438,%r242,%r187; mul.f64 %r439,%r140,%r242; fma.rn.f64 %r188,%r438,%r139,%r439; .loc 1 267 0 mul.f64 %r138,%r139,%r187; .loc 1 268 0 add.f64 %r512,%r188,%r138; mov.b64 %r440,%r512; shr.u64 %r441,%r440,32; cvt.u32.u64 %r180,%r441; .loc 1 269 0 cvt.u32.u64 %r190,%r441; cvt.u32.u64 %r181,%r440; .loc 1 270 0 setp.le.s32 %r443,%r180,1083179007; @ %r443 bra $L29; .loc 1 271 0 add.u32 %r444,%r180,-1083179008; or.b32 %r445,%r444,%r181; setp.eq.u32 %r446,%r445,0; @ %r446 bra $L30; .loc 1 272 0 mul.f64 %r447,%r141,0d7e37e43c8800759c; mul.f64 %r240,%r447,0d7e37e43c8800759c; bra $L1; $L30: .loc 1 274 0 add.f64 %r448,%r188,0d3c971547652b82fe; sub.f64 %r449,%r512,%r138; setp.gt.f64 %r450,%r448,%r449; @ ! %r450 bra $L31; mul.f64 %r451,%r141,0d7e37e43c8800759c; mul.f64 %r240,%r451,0d7e37e43c8800759c; bra $L1; $L29: .loc 1 276 0 and.b32 %r452,%r180,2147483647; setp.le.s32 %r453,%r452,1083231231; @ %r453 bra $L31; .loc 1 277 0 add.u32 %r454,%r180,1064252416; or.b32 %r455,%r454,%r181; setp.eq.u32 %r456,%r455,0; @ %r456 bra $L33; .loc 1 278 0 mul.f64 %r457,%r141,0d01a56e1fc2f8f359; mul.f64 %r240,%r457,0d01a56e1fc2f8f359; bra $L1; $L33: .loc 1 280 0 sub.f64 %r458,%r512,%r138; setp.ge.f64 %r459,%r458,%r188; @ ! %r459 bra $L31; mul.f64 %r460,%r141,0d01a56e1fc2f8f359; mul.f64 %r240,%r460,0d01a56e1fc2f8f359; bra $L1; $L31: .loc 1 286 0 and.b32 %r192,%r190,2147483647; .loc 1 289 0 setp.le.s32 %r461,%r192,1071644672; @ %r461 bra $L54; .loc 1 287 0 shr.s32 %r462,%r192,20; .loc 1 290 0 add.u32 %r463,%r462,-1022; mov.u32 %r465,1048576; shr.s32 %r464,%r465,%r463; add.u32 %r193,%r464,%r190; .loc 1 291 0 shr.s32 %r466,%r193,20; and.b32 %r467,%r466,2047; add.u32 %r194,%r467,-1023; .loc 1 293 0 mov.u32 %r469,1048575; shr.s32 %r468,%r469,%r194; not.b32 %r470,%r468; and.b32 %r471,%r470,%r193; cvt.u64.u32 %r472,%r471; shl.b64 %r473,%r472,32; mov.b64 %r195,%r473; .loc 1 294 0 and.b32 %r476,%r193,1048575; or.b32 %r119,%r476,1048576; mov.u32 %r478,20; sub.u32 %r477,%r478,%r194; shr.s32 %r145,%r119,%r477; .loc 1 295 0 setp.ge.s32 %r479,%r190,0; @ %r479 bra $L36; neg.s32 %r145,%r145; $L36: .loc 1 296 0 sub.f64 %r138,%r138,%r195; add.f64 %r512,%r188,%r138; bra $L35; $L54: .loc 1 288 0 mov.u32 %r145,0; $L35: .loc 1 299 0 mov.b64 %r238,%r512; and.b64 %r481,%r238,-4294967296; mov.b64 %r197,%r481; .loc 1 301 0 sub.f64 %r482,%r197,%r138; sub.f64 %r483,%r188,%r482; mul.f64 %r484,%r197,0dbe205c610ca86c39; fma.rn.f64 %r198,%r483,0d3fe62e42fefa39ef,%r484; .loc 1 302 0 fma.rn.f64 %r199,%r197,0d3fe62e4300000000,%r198; .loc 1 303 0 fma.rn.f64 %r486,%r197,0dbfe62e4300000000,%r199; sub.f64 %r200,%r198,%r486; .loc 1 304 0 mul.f64 %r201,%r199,%r199; .loc 1 305 0 fma.rn.f64 %r487,%r201,0d3e66376972bea4d0,0dbebbbd41c5d26bf1; fma.rn.f64 %r488,%r487,%r201,0d3f11566aaf25de2c; fma.rn.f64 %r489,%r488,%r201,0dbf66c16c16bebd93; fma.rn.f64 %r490,%r489,%r201,0d3fc555555555553e; neg.f64 %r491,%r490; fma.rn.f64 %r202,%r491,%r201,%r199; .loc 1 306 0 mul.f64 %r492,%r199,%r202; mov.f64 %r494,0d4000000000000000; sub.f64 %r493,%r202,%r494; div.rn.f64 %r495,%r492,%r493; fma.rn.f64 %r496,%r199,%r200,%r200; sub.f64 %r497,%r495,%r496; .loc 1 307 0 sub.f64 %r133,%r497,%r199; mov.f64 %r498,0d3ff0000000000000; sub.f64 %r204,%r498,%r133; .loc 1 308 0 mov.b64 %r499,%r204; shr.u64 %r500,%r499,32; cvt.u32.u64 %r205,%r500; .loc 1 309 0 shl.b32 %r501,%r145,20; add.u32 %r206,%r501,%r205; .loc 1 310 0 setp.gt.s32 %r503,%r206,1048575; @ %r503 bra $L37; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r204; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r145; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r506,[%value_in]; } mov.f64 %r137,%r506; bra $L38; $L37: .loc 1 311 0 cvt.u64.u32 %r507,%r206; shl.b64 %r508,%r507,32; and.b64 %r509,%r499,4294967295; or.b64 %r510,%r509,%r508; mov.b64 %r137,%r510; $L38: .loc 1 312 0 mul.f64 %r240,%r137,%r141; bra $L1; $L39: .loc 1 119 0 mov.f64 %r240,0d3ff0000000000000; bra $L1; $L40: mov.f64 %r240,0d3ff0000000000000; bra $L1; $L47: mov.f64 %r240,0d3ff0000000000000; bra $L1; $L48: .loc 1 154 0 mov.f64 %r240,%r242; bra $L1; $L49: .loc 1 159 0 mov.f64 %r240,%r241; bra $L1; $L46: .loc 1 133 0 mov.u32 %r142,0; bra $L10; $L1: .loc 1 313 0 mov.f64 %value,%r240; st.param.f64 [%value_out],%value; ret; } /62 0 0 0 644 9706 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .visible .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2 .extern .func (.param .u32 %value_out) __kernel_rem_pio2 (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); // BEGIN VAR DEF: npio2_hw .const .align 4 .u32 npio2_hw[32] = {1073291771,1074340347,1074977148,1075388923,1075800698,1076025724,1076231611,1076437499,1076643386,1076849274,1076971356,1077074300,1077177244,1077280187,1077383131,1077486075,1077589019,1077691962,1077794906,1077897850,1077968460,1078019932,1078071404,1078122876,1078174348,1078225820,1078277292,1078328763,1078380235,1078431707,1078483179,1078534651 }; // BEGIN VAR DEF: two_over_pi .const .align 4 .u32 two_over_pi[66] = {10680707,7228996,1387004,2578385,16069853,12639074,9804092,4427841,16666979,11263675,12935607,2387514,4345298,14681673,3074569,13734428,16653803,1880361,10960616,8533493,3062596,8710556,7349940,6258241,3772886,3769171,3798172,8675211,12450088,3874808,9961438,366607,15675153,9132554,7151469,3571407,2607881,12013382,4155038,6285869,7677882,13102053,15825725,473591,9065106,15363067,6271263,9264392,5636912,4652155,7056368,13614112,10155062,1944035,9527646,15080200,6658437,6231200,6832269,16767104,5075751,3212806,1398474,7579849,6349435,12618859 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_rem_pio2 .visible .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[24]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r22; .reg .f64 %r25; .reg .f64 %r28; .reg .u32 %r30; .reg .f64 %r32; .reg .u32 %r41; .reg .f64 %r54; .reg .f64 %r59; .reg .f64 %r64; .reg .f64 %r72; .reg .f64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .f64 %r78; .reg .f64 %r81; .reg .f64 %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .u32 %r101; .reg .f64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .pred %r106; .reg .f64 %r107; .reg .pred %r108; .reg .pred %r109; .reg .f64 %r110; .reg .pred %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .pred %r121; .reg .f64 %r122; .reg .f64 %r123; .reg .f64 %r124; .reg .f64 %r125; .reg .pred %r126; .reg .f64 %r128; .reg .f64 %r129; .reg .pred %r131; .reg .u64 %r132; .reg .u32 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .pred %r145; .reg .f64 %r148; .reg .f64 %r149; .reg .f64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .pred %r157; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .f64 %r163; .reg .pred %r164; .reg .f64 %r165; .reg .f64 %r166; .reg .pred %r167; .reg .u32 %r170; .reg .u32 %r173; .reg .u32 %r174; .reg .u32 %r175; .reg .u64 %r176; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r179; .reg .u32 %r180; .reg .u32 %r181; .reg .pred %r182; .reg .pred %r183; .reg .u32 %r188; .reg .u64 %r189; .reg .u32 %r190; .reg .pred %r191; .reg .f64 %r192; .reg .f64 %r193; .reg .f64 %r194; .reg .f64 %r195; .reg .f64 %r197; mov.f64 %r102,%ar0; mov.u64 %r103,%ar1; .loc 1 98 0 mov.b64 %r104,%r102; shr.u64 %r105,%r104,32; cvt.u32.u64 %r74,%r105; .loc 1 99 0 and.b32 %r75,%r74,2147483647; .loc 1 100 0 setp.gt.s32 %r106,%r75,1072243195; @ %r106 bra $L2; .loc 1 101 0 st.f64 [%r103],%r102; mov.f64 %r107,0d0000000000000000; st.f64 [%r103+8],%r107; mov.u32 %r101,0; bra $L1; $L2: .loc 1 102 0 setp.gt.s32 %r108,%r75,1073928571; @ %r108 bra $L4; .loc 1 103 0 setp.le.s32 %r109,%r74,0; @ %r109 bra $L5; .loc 1 104 0 mov.f64 %r110,0d3ff921fb54400000; sub.f64 %r88,%r102,%r110; .loc 1 105 0 setp.eq.u32 %r111,%r75,1073291771; @ %r111 bra $L6; .loc 1 106 0 mov.f64 %r112,0d3dd0b4611a626331; sub.f64 %r22,%r88,%r112; st.f64 [%r103],%r22; .loc 1 107 0 sub.f64 %r113,%r88,%r22; sub.f64 %r114,%r113,%r112; st.f64 [%r103+8],%r114; .loc 1 113 0 mov.u32 %r101,1; bra $L1; $L6: .loc 1 109 0 mov.f64 %r116,0d3dd0b4611a600000; sub.f64 %r89,%r88,%r116; .loc 1 110 0 mov.f64 %r117,0d3ba3198a2e037073; sub.f64 %r25,%r89,%r117; st.f64 [%r103],%r25; .loc 1 111 0 sub.f64 %r118,%r89,%r25; sub.f64 %r119,%r118,%r117; st.f64 [%r103+8],%r119; .loc 1 113 0 mov.u32 %r101,1; bra $L1; $L5: .loc 1 115 0 add.f64 %r86,%r102,0d3ff921fb54400000; .loc 1 116 0 setp.eq.u32 %r121,%r75,1073291771; @ %r121 bra $L7; .loc 1 117 0 add.f64 %r28,%r86,0d3dd0b4611a626331; st.f64 [%r103],%r28; .loc 1 118 0 sub.f64 %r122,%r86,%r28; add.f64 %r123,%r122,0d3dd0b4611a626331; st.f64 [%r103+8],%r123; .loc 1 124 0 mov.u32 %r101,-1; bra $L1; $L7: .loc 1 120 0 add.f64 %r87,%r86,0d3dd0b4611a600000; .loc 1 121 0 add.f64 %r32,%r87,0d3ba3198a2e037073; st.f64 [%r103],%r32; .loc 1 122 0 sub.f64 %r124,%r87,%r32; add.f64 %r125,%r124,0d3ba3198a2e037073; st.f64 [%r103+8],%r125; .loc 1 124 0 mov.u32 %r101,-1; bra $L1; $L4: .loc 1 127 0 setp.gt.s32 %r126,%r75,1094263291; @ %r126 bra $L8; .loc 1 128 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r102; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r128,[%value_in]; } .loc 1 129 0 fma.rn.f64 %r129,%r128,0d3fe45f306dc9c883,0d3fe0000000000000; cvt.rzi.s32.f64 %r101,%r129; .loc 1 130 0 cvt.rn.f64.s32 %r81,%r101; .loc 1 131 0 neg.f64 %r197,%r81; fma.rn.f64 %r73,%r197,0d3ff921fb54400000,%r128; .loc 1 132 0 mul.f64 %r72,%r81,0d3dd0b4611a626331; .loc 1 133 0 setp.gt.s32 %r131,%r101,31; @ %r131 bra $L9; sub.f64 %r64,%r73,%r72; cvta.const.u64 %r132,npio2_hw; add.u32 %r133,%r101,-1; cvt.s64.s32 %r134,%r133; shl.b64 %r135,%r134,2; add.u64 %r136,%r132,%r135; ld.u32 %r137,[%r136]; setp.eq.u32 %r138,%r137,%r75; @ %r138 bra $L10; .loc 1 134 0 st.f64 [%r103],%r64; bra $L11; $L9: sub.f64 %r64,%r73,%r72; $L10: .loc 1 137 0 shr.s32 %r41,%r75,20; .loc 1 140 0 mov.b64 %r139,%r64; shr.u64 %r140,%r139,32; cvt.u32.u64 %r142,%r140; shr.u32 %r141,%r142,20; and.b32 %r143,%r141,2047; sub.u32 %r144,%r41,%r143; .loc 1 141 0 setp.gt.s32 %r145,%r144,16; @ %r145 bra $L12; .loc 1 138 0 st.f64 [%r103],%r64; bra $L11; $L12: .loc 1 144 0 fma.rn.f64 %r84,%r197,0d3dd0b4611a600000,%r73; .loc 1 145 0 sub.f64 %r148,%r73,%r84; fma.rn.f64 %r149,%r197,0d3dd0b4611a600000,%r148; neg.f64 %r150,%r149; fma.rn.f64 %r72,%r81,0d3ba3198a2e037073,%r150; .loc 1 146 0 sub.f64 %r64,%r84,%r72; .loc 1 148 0 mov.b64 %r151,%r64; shr.u64 %r152,%r151,32; cvt.u32.u64 %r154,%r152; shr.u32 %r153,%r154,20; and.b32 %r155,%r153,2047; sub.u32 %r156,%r41,%r155; .loc 1 149 0 setp.gt.s32 %r157,%r156,49; @ %r157 bra $L13; .loc 1 146 0 st.f64 [%r103],%r64; .loc 1 144 0 mov.f64 %r73,%r84; bra $L11; $L13: .loc 1 152 0 fma.rn.f64 %r73,%r197,0d3ba3198a2e000000,%r84; .loc 1 153 0 sub.f64 %r160,%r84,%r73; fma.rn.f64 %r161,%r197,0d3ba3198a2e000000,%r160; neg.f64 %r162,%r161; fma.rn.f64 %r72,%r81,0d397b839a252049c1,%r162; .loc 1 154 0 sub.f64 %r64,%r73,%r72; st.f64 [%r103],%r64; $L11: .loc 1 158 0 sub.f64 %r163,%r73,%r64; sub.f64 %r54,%r163,%r72; st.f64 [%r103+8],%r54; .loc 1 159 0 setp.ge.s32 %r164,%r74,0; @ %r164 bra $L1; neg.f64 %r165,%r64; st.f64 [%r103],%r165; neg.f64 %r166,%r54; st.f64 [%r103+8],%r166; neg.s32 %r101,%r101; bra $L1; $L8: .loc 1 165 0 setp.le.s32 %r167,%r75,2146435071; @ %r167 bra $L14; .loc 1 166 0 sub.f64 %r59,%r102,%r102; st.f64 [%r103+8],%r59; st.f64 [%r103],%r59; mov.u32 %r101,0; bra $L1; $L14: .loc 1 170 0 cvt.u32.u64 %r170,%r104; .loc 1 171 0 shr.s32 %r173,%r75,20; add.u32 %r77,%r173,-1046; .loc 1 172 0 shl.b32 %r174,%r77,20; sub.u32 %r175,%r75,%r174; cvt.u64.u32 %r176,%r175; shl.b64 %r177,%r176,32; cvt.u64.u32 %r178,%r170; or.b64 %r179,%r178,%r177; mov.b64 %r78,%r179; .loc 1 174 0 cvt.rzi.s32.f64 %r180,%r78; cvt.rn.f64.s32 %r92,%r180; st.f64 [%frame],%r92; .loc 1 175 0 sub.f64 %r93,%r78,%r92; mul.f64 %r94,%r93,0d4170000000000000; .loc 1 174 0 cvt.rzi.s32.f64 %r181,%r94; cvt.rn.f64.s32 %r96,%r181; st.f64 [%frame+8],%r96; .loc 1 175 0 sub.f64 %r97,%r94,%r96; mul.f64 %r98,%r97,0d4170000000000000; .loc 1 177 0 st.f64 [%frame+16],%r98; .loc 1 179 0 setp.neu.f64 %r182,%r98,0d0000000000000000; @ %r182 bra $L16; setp.eq.f64 %r183,%r96,0d0000000000000000; selp.u32 %r30,1,2,%r183; bra $L15; $L16: .loc 1 178 0 mov.u32 %r30,3; $L15: .loc 1 180 0 cvta.const.u64 %r189,two_over_pi; mov.u32 %r188,2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r103; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r77; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r30; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r188; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r189; call (%value_in),__kernel_rem_pio2,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u32 %r190,[%value_in]; } mov.u32 %r101,%r190; .loc 1 181 0 setp.ge.s32 %r191,%r74,0; @ %r191 bra $L1; ld.f64 %r193,[%r103]; neg.f64 %r192,%r193; st.f64 [%r103],%r192; ld.f64 %r195,[%r103+8]; neg.f64 %r194,%r195; st.f64 [%r103+8],%r194; neg.s32 %r101,%r101; $L1: .loc 1 183 0 mov.u32 %value,%r101; st.param.u32 [%value_out],%value; ret; } /82 0 0 0 644 4200 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainder .visible .func (.param .f64 %value_out) __ieee754_remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_remainder.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmod .extern .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_remainder .visible .func (.param .f64 %value_out) __ieee754_remainder (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .f64 %r28; .reg .f64 %r37; .reg .f64 %r38; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .f64 %r45; .reg .u32 %r46; .reg .u32 %r49; .reg .u64 %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .pred %r66; .reg .pred %r67; .reg .f64 %r70; .reg .f64 %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .f64 %r79; .reg .f64 %r81; .reg .pred %r82; .reg .f64 %r83; .reg .pred %r84; .reg .f64 %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .u32 %r89; .reg .u64 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; mov.f64 %r53,%ar0; mov.f64 %r54,%ar1; .loc 1 46 0 mov.b64 %r55,%r54; shr.u64 %r56,%r55,32; cvt.u32.u64 %r40,%r56; cvt.u32.u64 %r49,%r55; .loc 1 48 0 and.b32 %r42,%r40,2147483647; .loc 1 52 0 or.b32 %r58,%r42,%r49; setp.ne.u32 %r59,%r58,0; @ %r59 bra $L2; mul.f64 %r24,%r53,%r54; div.rn.f64 %r52,%r24,%r24; bra $L1; $L2: mov.b64 %r60,%r53; shr.u64 %r61,%r60,32; cvt.u32.u64 %r46,%r61; .loc 1 49 0 and.b32 %r43,%r46,2147483647; .loc 1 53 0 setp.gt.s32 %r62,%r43,2146435071; @ %r62 bra $L4; setp.le.s32 %r63,%r42,2146435071; @ %r63 bra $L5; .loc 1 55 0 add.u32 %r64,%r42,-2146435072; or.b32 %r65,%r64,%r49; .loc 1 54 0 setp.eq.u32 %r66,%r65,0; @ %r66 bra $L14; $L4: .loc 1 56 0 mul.f64 %r28,%r53,%r54; div.rn.f64 %r52,%r28,%r28; bra $L1; $L5: .loc 1 59 0 setp.gt.s32 %r67,%r42,2145386495; @ %r67 bra $L15; add.f64 %r70,%r54,%r54; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r53; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r70; call (%value_in),__ieee754_fmod,(%out_arg1,%out_arg2); ld.param.f64 %r71,[%value_in]; } mov.f64 %r37,%r71; bra $L6; $L14: mov.f64 %r37,%r53; bra $L6; $L15: mov.f64 %r37,%r53; $L6: .loc 1 60 0 sub.u32 %r72,%r43,%r42; mov.b64 %r73,%r53; cvt.u32.u64 %r75,%r73; sub.u32 %r74,%r75,%r49; or.b32 %r76,%r72,%r74; setp.ne.u32 %r77,%r76,0; @ %r77 bra $L7; mul.f64 %r52,%r37,0d0000000000000000; bra $L1; $L7: .loc 1 61 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r79,[%value_in]; } mov.f64 %r38,%r79; .loc 1 62 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r54; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r81,[%value_in]; } .loc 1 63 0 setp.gt.s32 %r82,%r42,2097151; @ %r82 bra $L8; .loc 1 64 0 add.f64 %r83,%r38,%r38; setp.gt.f64 %r84,%r83,%r81; @ ! %r84 bra $L9; .loc 1 65 0 sub.f64 %r38,%r38,%r81; .loc 1 66 0 add.f64 %r85,%r38,%r38; setp.ge.f64 %r86,%r85,%r81; @ ! %r86 bra $L9; sub.f64 %r38,%r38,%r81; bra $L9; $L8: .loc 1 69 0 mul.f64 %r45,%r81,0d3fe0000000000000; .loc 1 70 0 setp.gt.f64 %r87,%r38,%r45; @ ! %r87 bra $L9; .loc 1 71 0 sub.f64 %r38,%r38,%r81; .loc 1 72 0 setp.le.f64 %r88,%r45,%r38; @ ! %r88 bra $L9; sub.f64 %r38,%r38,%r81; $L9: .loc 1 76 0 mov.b64 %r51,%r38; .loc 1 47 0 and.b32 %r89,%r46,-2147483648; .loc 1 76 0 shr.u64 %r91,%r51,32; cvt.u32.u64 %r93,%r91; xor.b32 %r92,%r89,%r93; cvt.u64.u32 %r94,%r92; shl.b64 %r95,%r94,32; and.b64 %r96,%r51,4294967295; or.b64 %r97,%r96,%r95; mov.b64 %r52,%r97; $L1: .loc 1 78 0 mov.f64 %value,%r52; st.param.f64 [%value_out],%value; ret; } lib_a-e_scalb.o/0 0 0 644 3486 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalb .visible .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/e_scalb.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: __ieee754_scalb .visible .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r27; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r31; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f64 %r42; .reg .f64 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u32 %r48; .reg .f64 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .f64 %r53; .reg .u32 %r56; .reg .f64 %r57; mov.f64 %r30,%ar0; mov.f64 %r31,%ar1; .loc 1 43 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r33,[%value_in]; } setp.ne.u32 %r34,%r33,0; @ ! %r34 bra $L3; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r36,[%value_in]; } setp.eq.u32 %r37,%r36,0; @ ! %r37 bra $L18; $L3: mul.f64 %r29,%r30,%r31; bra $L1; $L18: .loc 1 44 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),finite,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.ne.u32 %r40,%r39,0; @ %r40 bra $L7; .loc 1 45 0 setp.gt.f64 %r41,%r31,0d0000000000000000; @ %r41 bra $L3; .loc 1 46 0 neg.f64 %r42,%r31; div.rn.f64 %r29,%r30,%r42; bra $L1; $L7: .loc 1 48 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),rint,(%out_arg1); ld.param.f64 %r44,[%value_in]; } setp.eq.f64 %r45,%r44,%r31; @ %r45 bra $L8; sub.f64 %r27,%r31,%r31; div.rn.f64 %r29,%r27,%r27; bra $L1; $L8: .loc 1 49 0 setp.gt.f64 %r46,%r31,0d40efbd0000000000; @ ! %r46 bra $L19; mov.u32 %r48,65000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r49,[%value_in]; } mov.f64 %r29,%r49; bra $L1; $L19: .loc 1 50 0 setp.lt.f64 %r50,%r31,0dc0efbd0000000000; @ ! %r50 bra $L20; mov.u32 %r52,-65000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r52; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r53,[%value_in]; } mov.f64 %r29,%r53; bra $L1; $L20: .loc 1 51 0 cvt.rzi.s32.f64 %r56,%r31; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r56; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r57,[%value_in]; } mov.f64 %r29,%r57; $L1: .loc 1 53 0 mov.f64 %value,%r29; st.param.f64 [%value_out],%value; ret; } lib_a-e_sinh.o/ 0 0 0 644 4553 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinh .visible .func (.param .f64 %value_out) __ieee754_sinh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_sinh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_sinh .visible .func (.param .f64 %value_out) __ieee754_sinh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .f64 %r56; .reg .pred %r57; .reg .f64 %r59; .reg .f64 %r61; .reg .pred %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .pred %r71; .reg .f64 %r73; .reg .f64 %r75; .reg .pred %r76; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u32 %r88; .reg .u16 %r89; .reg .pred %r90; .reg .f64 %r92; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r99; .reg .f64 %r101; mov.f64 %r49,%ar0; .loc 1 54 0 mov.b64 %r50,%r49; shr.u64 %r51,%r50,32; cvt.u32.u64 %r39,%r51; .loc 1 55 0 and.b32 %r40,%r39,2147483647; .loc 1 58 0 setp.le.s32 %r52,%r40,2146435071; @ %r52 bra $L2; add.f64 %r48,%r49,%r49; bra $L1; $L2: .loc 1 61 0 setp.ge.s32 %r53,%r39,0; selp.f64 %r38,0d3fe0000000000000,0dbfe0000000000000,%r53; .loc 1 63 0 setp.gt.s32 %r54,%r40,1077280767; @ %r54 bra $L5; .loc 1 64 0 setp.gt.s32 %r55,%r40,1043333119; @ %r55 bra $L6; .loc 1 65 0 add.f64 %r56,%r49,0d7fac7b1f3cac7433; setp.gt.f64 %r57,%r56,0d3ff0000000000000; @ %r57 bra $L14; bra $L15; $L6: .loc 1 66 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r59,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r61,[%value_in]; } mov.f64 %r47,%r61; .loc 1 67 0 setp.gt.s32 %r62,%r40,1072693247; @ %r62 bra $L8; $L12: mul.f64 %r63,%r47,%r47; add.f64 %r64,%r47,0d3ff0000000000000; div.rn.f64 %r65,%r63,%r64; neg.f64 %r66,%r65; fma.rn.f64 %r67,%r47,0d4000000000000000,%r66; mul.f64 %r48,%r67,%r38; bra $L1; $L8: .loc 1 68 0 add.f64 %r68,%r61,0d3ff0000000000000; div.rn.f64 %r69,%r61,%r68; add.f64 %r70,%r69,%r61; mul.f64 %r48,%r70,%r38; bra $L1; $L5: .loc 1 72 0 setp.gt.s32 %r71,%r40,1082535489; @ %r71 bra $L9; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r73,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r75,[%value_in]; } mul.f64 %r48,%r75,%r38; bra $L1; $L9: .loc 1 76 0 setp.le.s32 %r76,%r40,1082536909; @ %r76 bra $L10; set.u32.eq.u32 %r78,%r40,1082536910; neg.s32 %r79,%r78; cvt.u32.u64 %r82,%r50; set.u32.le.u32 %r83,%r82,-1883637635; neg.s32 %r84,%r83; cvt.u16.u32 %r86,%r79; cvt.u16.u32 %r87,%r84; and.b16 %r85,%r86,%r87; cvt.u32.u16 %r88,%r85; cvt.u16.u8 %r89,%r88; setp.eq.u16 %r90,%r89,0; @ %r90 bra $L11; $L10: .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r92,[%value_in]; } mul.f64 %r94,%r92,0d3fe0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r94; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r95,[%value_in]; } .loc 1 78 0 mul.f64 %r96,%r38,%r95; .loc 1 79 0 mul.f64 %r48,%r96,%r95; bra $L1; $L11: .loc 1 83 0 mul.f64 %r48,%r49,0d7fac7b1f3cac7433; bra $L1; $L14: .loc 1 65 0 mov.f64 %r48,%r49; bra $L1; $L15: .loc 1 66 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r99,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r99; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r101,[%value_in]; } mov.f64 %r47,%r101; bra $L12; $L1: .loc 1 84 0 mov.f64 %value,%r48; st.param.f64 [%value_out],%value; ret; } lib_a-e_sqrt.o/ 0 0 0 644 6397 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .visible .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/e_sqrt.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_sqrt .visible .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r38; .reg .u32 %r44; .reg .u32 %r49; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r85; .reg .u32 %r87; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r102; .reg .f64 %r106; .reg .f64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u32 %r110; .reg .pred %r111; .reg .pred %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r121; .reg .pred %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r129; .reg .pred %r130; .reg .u32 %r132; .reg .u32 %r133; .reg .pred %r134; .reg .u32 %r135; .reg .u32 %r136; .reg .pred %r138; .reg .pred %r139; .reg .u32 %r141; .reg .u32 %r142; .reg .u32 %r144; .reg .u32 %r145; .reg .u16 %r146; .reg .u16 %r147; .reg .u16 %r148; .reg .u32 %r149; .reg .u16 %r150; .reg .pred %r151; .reg .pred %r152; .reg .pred %r153; .reg .pred %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .pred %r158; .reg .u32 %r159; .reg .pred %r160; .reg .pred %r161; .reg .u32 %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .pred %r165; .reg .u32 %r166; .reg .u32 %r167; .reg .u64 %r168; .reg .u64 %r172; .reg .u64 %r173; .reg .u64 %r174; .reg .pred %r176; mov.f64 %r107,%ar0; .loc 1 106 0 mov.b64 %r108,%r107; shr.u64 %r109,%r108,32; cvt.u32.u64 %r68,%r109; .loc 1 109 0 and.b32 %r110,%r68,2146435072; setp.ne.u32 %r111,%r110,2146435072; @ %r111 bra $L2; .loc 1 110 0 fma.rn.f64 %r106,%r107,%r107,%r107; bra $L1; $L2: cvt.u32.u64 %r67,%r108; .loc 1 114 0 setp.gt.s32 %r113,%r68,0; @ %r113 bra $L4; .loc 1 115 0 and.b32 %r114,%r68,2147483647; or.b32 %r115,%r114,%r67; setp.eq.u32 %r116,%r115,0; @ %r116 bra $L22; .loc 1 116 0 setp.eq.u32 %r117,%r68,0; @ %r117 bra $L23; .loc 1 117 0 sub.f64 %r38,%r107,%r107; div.rn.f64 %r106,%r38,%r38; bra $L1; $L23: .loc 1 106 0 cvt.u32.u64 %r82,%r108; $L5: .loc 1 123 0 add.u32 %r68,%r68,-21; .loc 1 124 0 shr.u32 %r80,%r82,11; shl.b32 %r82,%r82,21; .loc 1 122 0 setp.eq.u32 %r118,%r80,0; @ %r118 bra $L5; bra $L20; $L28: .loc 1 121 0 cvt.u32.u64 %r80,%r109; .loc 1 120 0 mov.u32 %r68,%r77; .loc 1 106 0 cvt.u32.u64 %r82,%r108; $L20: .loc 1 126 0 and.b32 %r74,%r80,1048576; setp.ne.u32 %r119,%r74,0; @ ! %r119 bra $L7; bra $L24; $L25: mov.u32 %r74,%r81; $L7: add.u32 %r80,%r80,%r80; add.u32 %r81,%r74,1; and.b32 %r121,%r80,1048576; setp.eq.u32 %r122,%r121,0; @ %r122 bra $L25; mov.u32 %r123,32; sub.u32 %r102,%r123,%r81; shl.b32 %r67,%r82,%r81; bra $L6; $L24: mov.u32 %r67,%r82; mov.u32 %r102,32; mov.u32 %r74,-1; $L6: .loc 1 127 0 sub.u32 %r77,%r68,%r74; .loc 1 128 0 shr.u32 %r124,%r82,%r102; or.b32 %r68,%r124,%r80; $L21: .loc 1 131 0 add.u32 %r83,%r77,-1023; .loc 1 132 0 and.b32 %r44,%r68,1048575; or.b32 %r125,%r44,1048576; add.u32 %r126,%r125,%r125; shr.u32 %r127,%r67,31; add.u32 %r72,%r126,%r127; add.u32 %r69,%r67,%r67; .loc 1 133 0 and.b32 %r129,%r83,1; setp.eq.u32 %r130,%r129,0; @ %r130 bra $L8; add.u32 %r132,%r72,%r72; shr.u32 %r133,%r69,31; add.u32 %r72,%r132,%r133; shl.b32 %r69,%r69,1; $L8: .loc 1 137 0 shr.s32 %r85,%r83,1; mov.u32 %r94,22; .loc 1 142 0 mov.u32 %r76,0; mov.u32 %r73,%r76; .loc 1 143 0 mov.u32 %r92,2097152; $L10: .loc 1 146 0 add.u32 %r49,%r73,%r92; .loc 1 147 0 setp.gt.s32 %r134,%r49,%r72; @ %r134 bra $L9; .loc 1 148 0 add.u32 %r73,%r49,%r92; .loc 1 149 0 sub.u32 %r72,%r72,%r49; .loc 1 150 0 add.u32 %r76,%r76,%r92; $L9: .loc 1 152 0 add.u32 %r135,%r72,%r72; shr.u32 %r136,%r69,31; add.u32 %r72,%r135,%r136; .loc 1 153 0 add.u32 %r69,%r69,%r69; .loc 1 154 0 shr.u32 %r92,%r92,1; add.u32 %r94,%r94,-1; .loc 1 145 0 setp.ne.u32 %r138,%r94,0; @ %r138 bra $L10; mov.u32 %r95,32; .loc 1 142 0 mov.u32 %r71,%r94; mov.u32 %r66,%r71; .loc 1 157 0 mov.u32 %r90,-2147483648; $L15: .loc 1 159 0 add.u32 %r89,%r90,%r66; .loc 1 161 0 setp.gt.s32 %r139,%r72,%r73; @ %r139 bra $L11; set.u32.eq.u32 %r141,%r72,%r73; neg.s32 %r142,%r141; set.u32.le.u32 %r144,%r89,%r69; neg.s32 %r145,%r144; cvt.u16.u32 %r147,%r142; cvt.u16.u32 %r148,%r145; and.b16 %r146,%r147,%r148; cvt.u32.u16 %r149,%r146; cvt.u16.u8 %r150,%r149; setp.eq.u16 %r151,%r150,0; @ %r151 bra $L12; $L11: .loc 1 162 0 add.u32 %r66,%r89,%r90; .loc 1 163 0 setp.ge.s32 %r152,%r89,0; @ %r152 bra $L26; setp.lt.s32 %r153,%r66,0; @ %r153 bra $L27; add.u32 %r75,%r73,1; bra $L13; $L26: mov.u32 %r75,%r73; bra $L13; $L27: mov.u32 %r75,%r73; $L13: .loc 1 164 0 sub.u32 %r72,%r72,%r73; .loc 1 165 0 setp.le.u32 %r154,%r89,%r69; @ %r154 bra $L14; add.u32 %r72,%r72,-1; $L14: .loc 1 166 0 sub.u32 %r69,%r69,%r89; .loc 1 167 0 add.u32 %r71,%r71,%r90; mov.u32 %r73,%r75; $L12: .loc 1 169 0 shr.u32 %r155,%r69,31; add.u32 %r156,%r72,%r72; add.u32 %r72,%r155,%r156; .loc 1 170 0 add.u32 %r69,%r69,%r69; .loc 1 171 0 shr.u32 %r90,%r90,1; add.u32 %r95,%r95,-1; .loc 1 158 0 setp.ne.u32 %r158,%r95,0; @ %r158 bra $L15; .loc 1 175 0 or.b32 %r159,%r72,%r69; setp.ne.u32 %r160,%r159,0; @ %r160 bra $L16; shr.u32 %r70,%r71,1; bra $L17; $L16: .loc 1 179 0 setp.ne.u32 %r161,%r71,-1; @ %r161 bra $L18; add.u32 %r76,%r76,1; mov.u32 %r70,%r95; bra $L17; $L18: .loc 1 184 0 add.u32 %r162,%r71,1; shr.u32 %r70,%r162,1; $L17: .loc 1 187 0 shr.s32 %r163,%r76,1; add.u32 %r87,%r163,1071644672; .loc 1 189 0 and.b32 %r164,%r76,1; setp.eq.u32 %r165,%r164,0; @ %r165 bra $L19; or.b32 %r70,%r70,-2147483648; $L19: .loc 1 190 0 shl.b32 %r166,%r85,20; add.u32 %r167,%r166,%r87; .loc 1 191 0 cvt.u64.u32 %r168,%r167; cvt.u64.u32 %r172,%r70; shl.b64 %r173,%r168,32; or.b64 %r174,%r173,%r172; mov.b64 %r106,%r174; .loc 1 192 0 bra $L1; $L22: .loc 1 115 0 mov.f64 %r106,%r107; bra $L1; $L4: .loc 1 120 0 shr.s32 %r77,%r68,20; .loc 1 121 0 setp.eq.u32 %r176,%r77,0; @ ! %r176 bra $L21; bra $L28; $L1: .loc 1 193 0 mov.f64 %value,%r106; st.param.f64 [%value_out],%value; ret; } lib_a-ef_acos.o/0 0 0 644 4979 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosf .visible .func (.param .f32 %value_out) __ieee754_acosf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_acos.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acosf .visible .func (.param .f32 %value_out) __ieee754_acosf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .u32 %r57; .reg .u32 %r58; .reg .f32 %r59; .reg .f32 %r62; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r74; .reg .f32 %r94; .reg .f32 %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r113; .reg .f32 %r114; .reg .f32 %r115; .reg .pred %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .f32 %r127; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .f32 %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r152; .reg .f32 %r153; .reg .f32 %r154; mov.f32 %r95,%ar0; .loc 1 47 0 mov.b32 %r57,%r95; .loc 1 48 0 and.b32 %r58,%r57,2147483647; .loc 1 49 0 setp.ne.u32 %r96,%r58,1065353216; @ %r96 bra $L2; .loc 1 50 0 setp.gt.s32 %r97,%r57,0; .loc 1 51 0 selp.f32 %r94,0f00000000,0f40490fdb,%r97; bra $L1; $L2: .loc 1 52 0 setp.le.s32 %r98,%r58,1065353216; @ %r98 bra $L4; .loc 1 53 0 sub.f32 %r22,%r95,%r95; div.rn.f32 %r94,%r22,%r22; bra $L1; $L4: .loc 1 55 0 setp.gt.s32 %r99,%r58,1056964607; @ %r99 bra $L5; .loc 1 56 0 setp.le.s32 %r100,%r58,587202560; @ %r100 bra $L8; .loc 1 57 0 mul.f32 %r74,%r95,%r95; .loc 1 61 0 neg.f32 %r101,%r95; .loc 1 58 0 fma.rn.f32 %r102,%r74,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r103,%r102,%r74,0fbd241146; fma.rn.f32 %r104,%r103,%r74,0f3e4e0aa8; fma.rn.f32 %r105,%r104,%r74,0fbea6b090; fma.rn.f32 %r106,%r105,%r74,0f3e2aaaab; mul.f32 %r107,%r106,%r74; .loc 1 59 0 fma.rn.f32 %r108,%r74,0f3d9dc62e,0fbf303361; fma.rn.f32 %r109,%r108,%r74,0f4001572d; fma.rn.f32 %r110,%r109,%r74,0fc019d139; fma.rn.f32 %r111,%r110,%r74,0f3f800000; .loc 1 60 0 div.rn.f32 %r112,%r107,%r111; .loc 1 61 0 fma.rn.f32 %r113,%r101,%r112,0f33a22168; sub.f32 %r114,%r95,%r113; mov.f32 %r115,0f3fc90fda; sub.f32 %r94,%r115,%r114; bra $L1; $L5: .loc 1 62 0 setp.ge.s32 %r116,%r57,0; @ %r116 bra $L6; .loc 1 63 0 add.f32 %r117,%r95,0f3f800000; mul.f32 %r68,%r117,0f3f000000; .loc 1 64 0 fma.rn.f32 %r118,%r68,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r119,%r118,%r68,0fbd241146; fma.rn.f32 %r120,%r119,%r68,0f3e4e0aa8; fma.rn.f32 %r121,%r120,%r68,0fbea6b090; fma.rn.f32 %r122,%r121,%r68,0f3e2aaaab; mul.f32 %r69,%r122,%r68; .loc 1 65 0 fma.rn.f32 %r123,%r68,0f3d9dc62e,0fbf303361; fma.rn.f32 %r124,%r123,%r68,0f4001572d; fma.rn.f32 %r125,%r124,%r68,0fc019d139; fma.rn.f32 %r70,%r125,%r68,0f3f800000; .loc 1 66 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r127,[%value_in]; } .loc 1 67 0 div.rn.f32 %r128,%r69,%r70; .loc 1 68 0 fma.rn.f32 %r129,%r127,%r128,0fb3a22168; .loc 1 69 0 add.f32 %r130,%r129,%r127; fma.rn.f32 %r94,%r130,0fc0000000,0f40490fda; bra $L1; $L6: .loc 1 72 0 mov.f32 %r133,0f3f800000; sub.f32 %r132,%r133,%r95; mul.f32 %r59,%r132,0f3f000000; .loc 1 73 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r59; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r135,[%value_in]; } .loc 1 76 0 mov.b32 %r137,%r135; and.b32 %r136,%r137,-4096; mov.b32 %r62,%r136; .loc 1 77 0 neg.f32 %r138,%r62; fma.rn.f32 %r139,%r138,%r62,%r59; add.f32 %r140,%r135,%r62; div.rn.f32 %r141,%r139,%r140; .loc 1 78 0 fma.rn.f32 %r142,%r59,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r143,%r142,%r59,0fbd241146; fma.rn.f32 %r144,%r143,%r59,0f3e4e0aa8; fma.rn.f32 %r145,%r144,%r59,0fbea6b090; fma.rn.f32 %r146,%r145,%r59,0f3e2aaaab; mul.f32 %r147,%r146,%r59; .loc 1 79 0 fma.rn.f32 %r148,%r59,0f3d9dc62e,0fbf303361; fma.rn.f32 %r149,%r148,%r59,0f4001572d; fma.rn.f32 %r150,%r149,%r59,0fc019d139; fma.rn.f32 %r151,%r150,%r59,0f3f800000; .loc 1 80 0 div.rn.f32 %r152,%r147,%r151; .loc 1 81 0 fma.rn.f32 %r153,%r135,%r152,%r141; .loc 1 82 0 add.f32 %r154,%r153,%r62; add.f32 %r94,%r154,%r154; bra $L1; $L8: .loc 1 56 0 mov.f32 %r94,0f3fc90fdb; $L1: .loc 1 84 0 mov.f32 %value,%r94; st.param.f32 [%value_out],%value; ret; } /103 0 0 0 644 3056 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acoshf .visible .func (.param .f32 %value_out) __ieee754_acoshf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_acosh.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1pf .extern .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acoshf .visible .func (.param .f32 %value_out) __ieee754_acoshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .u32 %r33; .reg .f32 %r34; .reg .f32 %r38; .reg .f32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r63; .reg .f32 %r64; mov.f32 %r39,%ar0; .loc 1 36 0 mov.b32 %r33,%r39; .loc 1 37 0 setp.gt.s32 %r40,%r33,1065353215; @ %r40 bra $L2; .loc 1 38 0 sub.f32 %r22,%r39,%r39; div.rn.f32 %r38,%r22,%r22; bra $L1; $L2: .loc 1 39 0 setp.le.s32 %r41,%r33,1300234239; @ %r41 bra $L4; .loc 1 40 0 setp.le.s32 %r42,%r33,2139095039; @ %r42 bra $L5; .loc 1 41 0 add.f32 %r38,%r39,%r39; bra $L1; $L5: .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } add.f32 %r38,%r44,0f3f317218; bra $L1; $L4: .loc 1 44 0 setp.eq.u32 %r45,%r33,1065353216; @ %r45 bra $L7; .loc 1 46 0 setp.le.s32 %r46,%r33,1073741824; @ %r46 bra $L6; .loc 1 48 0 fma.rn.f32 %r48,%r39,%r39,0fbf800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r48; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } add.f32 %r51,%r49,%r39; mov.f32 %r53,0f3f800000; div.rn.f32 %r52,%r53,%r51; neg.f32 %r54,%r52; fma.rn.f32 %r55,%r39,0f40000000,%r54; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r55; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r56,[%value_in]; } mov.f32 %r38,%r56; bra $L1; $L6: .loc 1 50 0 mov.f32 %r57,0f3f800000; sub.f32 %r34,%r39,%r57; .loc 1 51 0 mul.f32 %r59,%r34,%r34; fma.rn.f32 %r60,%r34,0f40000000,%r59; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r60; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r61,[%value_in]; } add.f32 %r63,%r61,%r34; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r63; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } mov.f32 %r38,%r64; bra $L1; $L7: .loc 1 45 0 mov.f32 %r38,0f00000000; $L1: .loc 1 53 0 mov.f32 %value,%r38; st.param.f32 [%value_out],%value; ret; } lib_a-ef_asin.o/0 0 0 644 4680 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_asinf .visible .func (.param .f32 %value_out) __ieee754_asinf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_asin.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_asinf .visible .func (.param .f32 %value_out) __ieee754_asinf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .f32 %r52; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r63; .reg .f32 %r65; .reg .f32 %r81; .reg .f32 %r82; .reg .pred %r83; .reg .f32 %r84; .reg .pred %r85; .reg .pred %r86; .reg .pred %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r114; .reg .pred %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .f32 %r126; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r132; .reg .f32 %r133; .reg .pred %r134; mov.f32 %r82,%ar0; .loc 1 49 0 mov.b32 %r50,%r82; .loc 1 50 0 and.b32 %r51,%r50,2147483647; .loc 1 51 0 setp.ne.u32 %r83,%r51,1065353216; @ %r83 bra $L2; .loc 1 53 0 mul.f32 %r84,%r82,0fb33bbd2e; fma.rn.f32 %r81,%r82,0f3fc90fdb,%r84; bra $L1; $L2: .loc 1 54 0 setp.le.s32 %r85,%r51,1065353216; @ %r85 bra $L4; .loc 1 55 0 sub.f32 %r23,%r82,%r82; div.rn.f32 %r81,%r23,%r23; bra $L1; $L4: .loc 1 56 0 setp.gt.s32 %r86,%r51,1056964607; @ %r86 bra $L5; .loc 1 57 0 setp.gt.s32 %r87,%r51,838860799; @ %r87 bra $L6; .loc 1 58 0 add.f32 %r88,%r82,0f7149f2ca; setp.gt.f32 %r89,%r88,0f3f800000; @ %r89 bra $L9; bra $L5; $L6: .loc 1 60 0 mul.f32 %r52,%r82,%r82; .loc 1 61 0 fma.rn.f32 %r90,%r52,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r91,%r90,%r52,0fbd241146; fma.rn.f32 %r92,%r91,%r52,0f3e4e0aa8; fma.rn.f32 %r93,%r92,%r52,0fbea6b090; fma.rn.f32 %r94,%r93,%r52,0f3e2aaaab; mul.f32 %r95,%r94,%r52; .loc 1 62 0 fma.rn.f32 %r96,%r52,0f3d9dc62e,0fbf303361; fma.rn.f32 %r97,%r96,%r52,0f4001572d; fma.rn.f32 %r98,%r97,%r52,0fc019d139; fma.rn.f32 %r99,%r98,%r52,0f3f800000; .loc 1 63 0 div.rn.f32 %r100,%r95,%r99; .loc 1 64 0 fma.rn.f32 %r81,%r82,%r100,%r82; bra $L1; $L5: .loc 1 68 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r82; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r102,[%value_in]; } mov.f32 %r104,0f3f800000; sub.f32 %r103,%r104,%r102; .loc 1 69 0 mul.f32 %r58,%r103,0f3f000000; .loc 1 70 0 fma.rn.f32 %r105,%r58,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r106,%r105,%r58,0fbd241146; fma.rn.f32 %r107,%r106,%r58,0f3e4e0aa8; fma.rn.f32 %r108,%r107,%r58,0fbea6b090; fma.rn.f32 %r109,%r108,%r58,0f3e2aaaab; mul.f32 %r59,%r109,%r58; .loc 1 71 0 fma.rn.f32 %r110,%r58,0f3d9dc62e,0fbf303361; fma.rn.f32 %r111,%r110,%r58,0f4001572d; fma.rn.f32 %r112,%r111,%r58,0fc019d139; fma.rn.f32 %r60,%r112,%r58,0f3f800000; .loc 1 72 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r114,[%value_in]; } .loc 1 73 0 setp.le.s32 %r115,%r51,1064933785; @ %r115 bra $L7; .loc 1 74 0 div.rn.f32 %r116,%r59,%r60; .loc 1 75 0 fma.rn.f32 %r117,%r114,%r116,%r114; fma.rn.f32 %r118,%r117,0f40000000,0f333bbd2e; mov.f32 %r119,0f3fc90fdb; sub.f32 %r81,%r119,%r118; bra $L8; $L7: .loc 1 80 0 mov.b32 %r121,%r114; and.b32 %r120,%r121,-4096; mov.b32 %r63,%r120; .loc 1 82 0 div.rn.f32 %r65,%r59,%r60; .loc 1 83 0 add.f32 %r122,%r114,%r114; .loc 1 81 0 neg.f32 %r123,%r63; fma.rn.f32 %r124,%r123,%r63,%r58; add.f32 %r125,%r114,%r63; div.rn.f32 %r126,%r124,%r125; .loc 1 83 0 fma.rn.f32 %r128,%r126,0fc0000000,0fb33bbd2e; neg.f32 %r129,%r128; fma.rn.f32 %r130,%r122,%r65,%r129; .loc 1 84 0 fma.rn.f32 %r132,%r123,0f40000000,0f3f490fdb; .loc 1 85 0 sub.f32 %r49,%r130,%r132; mov.f32 %r133,0f3f490fdb; sub.f32 %r81,%r133,%r49; $L8: .loc 1 87 0 setp.gt.s32 %r134,%r50,0; @ %r134 bra $L1; neg.f32 %r81,%r81; bra $L1; $L9: .loc 1 58 0 mov.f32 %r81,%r82; $L1: .loc 1 88 0 mov.f32 %value,%r81; st.param.f32 [%value_out],%value; ret; } /121 0 0 0 644 5264 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2f .visible .func (.param .f32 %value_out) __ieee754_atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_atan2.c" // BEGIN GLOBAL FUNCTION DECL: atanf .extern .func (.param .f32 %value_out) atanf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atan2f .visible .func (.param .f32 %value_out) __ieee754_atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r36; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u16 %r56; .reg .u16 %r57; .reg .u16 %r58; .reg .u32 %r59; .reg .u16 %r60; .reg .pred %r61; .reg .pred %r62; .reg .f32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .pred %r73; .reg .pred %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u32 %r86; .reg .u32 %r88; .reg .u32 %r89; .reg .u16 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u32 %r94; .reg .u16 %r95; .reg .pred %r96; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .u32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; mov.f32 %r48,%ar0; mov.f32 %r49,%ar1; .loc 1 41 0 mov.b32 %r39,%r49; .loc 1 42 0 and.b32 %r40,%r39,2147483647; .loc 1 43 0 mov.b32 %r44,%r48; .loc 1 44 0 and.b32 %r42,%r44,2147483647; .loc 1 45 0 set.u32.gt.s32 %r51,%r40,2139095040; neg.s32 %r52,%r51; .loc 1 46 0 set.u32.gt.s32 %r54,%r42,2139095040; neg.s32 %r55,%r54; .loc 1 45 0 cvt.u16.u32 %r57,%r52; cvt.u16.u32 %r58,%r55; or.b16 %r56,%r57,%r58; cvt.u32.u16 %r59,%r56; cvt.u16.u8 %r60,%r59; setp.eq.u16 %r61,%r60,0; @ %r61 bra $L2; .loc 1 47 0 add.f32 %r47,%r49,%r48; bra $L1; $L2: .loc 1 48 0 setp.ne.u32 %r62,%r39,1065353216; @ %r62 bra $L4; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r48; call (%value_in),atanf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } mov.f32 %r47,%r64; bra $L1; $L4: .loc 1 49 0 shr.s32 %r65,%r39,30; and.b32 %r66,%r65,2; shr.u32 %r67,%r44,31; or.b32 %r43,%r66,%r67; .loc 1 52 0 setp.ne.u32 %r68,%r42,0; @ %r68 bra $L5; .loc 1 53 0 setp.eq.u32 %r69,%r43,2; @ %r69 bra $L22; setp.eq.u32 %r70,%r43,3; .loc 1 55 0 selp.f32 %r47,0fc0490fdb,%r48,%r70; bra $L1; $L5: .loc 1 61 0 setp.ne.u32 %r71,%r40,0; @ %r71 bra $L8; setp.ge.s32 %r72,%r44,0; selp.f32 %r47,0f3fc90fdb,0fbfc90fdb,%r72; bra $L1; $L8: .loc 1 64 0 setp.ne.u32 %r73,%r40,2139095040; @ %r73 bra $L9; .loc 1 65 0 setp.ne.u32 %r74,%r42,2139095040; @ %r74 bra $L10; .loc 1 66 0 setp.eq.u32 %r75,%r43,2; @ %r75 bra $L11; setp.eq.u32 %r76,%r43,3; @ %r76 bra $L12; setp.eq.u32 %r77,%r43,1; .loc 1 67 0 selp.f32 %r47,0fbf490fdb,0f3f490fdb,%r77; bra $L1; $L11: .loc 1 69 0 mov.f32 %r47,0f4016cbe4; bra $L1; $L12: .loc 1 70 0 mov.f32 %r47,0fc016cbe4; bra $L1; $L10: .loc 1 73 0 setp.eq.u32 %r78,%r43,2; @ %r78 bra $L25; setp.eq.u32 %r79,%r43,3; @ %r79 bra $L15; setp.eq.u32 %r80,%r43,1; .loc 1 74 0 selp.f32 %r47,0f80000000,0f00000000,%r80; bra $L1; $L15: .loc 1 57 0 mov.f32 %r47,0fc0490fdb; bra $L1; $L9: .loc 1 82 0 setp.ne.u32 %r81,%r42,2139095040; @ %r81 bra $L17; setp.ge.s32 %r82,%r44,0; .loc 1 61 0 selp.f32 %r47,0f3fc90fdb,0fbfc90fdb,%r82; bra $L1; $L17: .loc 1 85 0 sub.u32 %r83,%r42,%r40; shr.s32 %r46,%r83,23; .loc 1 86 0 setp.gt.s32 %r84,%r46,60; @ %r84 bra $L27; .loc 1 87 0 shr.u32 %r86,%r39,31; set.u32.lt.s32 %r88,%r46,-60; neg.s32 %r89,%r88; cvt.u16.u32 %r92,%r86; cvt.u16.u32 %r93,%r89; and.b16 %r91,%r92,%r93; cvt.u32.u16 %r94,%r91; cvt.u16.u8 %r95,%r94; setp.ne.u16 %r96,%r95,0; @ %r96 bra $L28; .loc 1 88 0 div.rn.f32 %r98,%r48,%r49; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r98; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r99,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r99; call (%value_in),atanf,(%out_arg1); ld.param.f32 %r101,[%value_in]; } mov.f32 %r47,%r101; bra $L18; $L27: .loc 1 86 0 mov.f32 %r47,0f3fc90fdb; bra $L18; $L28: .loc 1 87 0 mov.f32 %r47,0f00000000; $L18: .loc 1 89 0 setp.eq.u32 %r102,%r43,1; @ %r102 bra $L20; setp.eq.u32 %r103,%r43,2; @ %r103 bra $L21; setp.eq.u32 %r104,%r43,0; @ ! %r104 bra $L32; bra $L1; $L20: .loc 1 94 0 mov.b32 %r105,%r47; add.u32 %r36,%r105,-2147483648; mov.b32 %r47,%r36; .loc 1 96 0 bra $L1; $L21: .loc 1 97 0 add.f32 %r106,%r47,0f33bbbd2e; mov.f32 %r107,0f40490fdb; sub.f32 %r47,%r107,%r106; bra $L1; $L32: .loc 1 99 0 add.f32 %r108,%r47,0f33bbbd2e; mov.f32 %r109,0f40490fdb; sub.f32 %r47,%r108,%r109; bra $L1; $L22: .loc 1 56 0 mov.f32 %r47,0f40490fdb; bra $L1; $L25: mov.f32 %r47,0f40490fdb; $L1: .loc 1 101 0 mov.f32 %value,%r47; st.param.f32 [%value_out],%value; ret; } /139 0 0 0 644 2439 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanhf .visible .func (.param .f32 %value_out) __ieee754_atanhf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_atanh.c" // BEGIN GLOBAL FUNCTION DECL: log1pf .extern .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atanhf .visible .func (.param .f32 %value_out) __ieee754_atanhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .f32 %r24; .reg .u32 %r31; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .f32 %r41; .reg .pred %r42; .reg .f32 %r43; .reg .pred %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r51; .reg .f32 %r52; .reg .pred %r53; .reg .f32 %r55; mov.f32 %r37,%ar0; .loc 1 40 0 mov.b32 %r31,%r37; .loc 1 41 0 and.b32 %r32,%r31,2147483647; .loc 1 42 0 setp.le.s32 %r38,%r32,1065353216; @ %r38 bra $L2; .loc 1 43 0 sub.f32 %r22,%r37,%r37; div.rn.f32 %r36,%r22,%r22; bra $L1; $L2: .loc 1 44 0 setp.ne.u32 %r39,%r32,1065353216; @ %r39 bra $L4; .loc 1 45 0 div.rn.f32 %r36,%r37,0f00000000; bra $L1; $L4: .loc 1 46 0 setp.gt.s32 %r40,%r32,830472191; @ %r40 bra $L5; add.f32 %r41,%r37,0f7149f2ca; setp.gt.f32 %r42,%r41,0f00000000; @ %r42 bra $L10; bra $L11; $L5: .loc 1 47 0 mov.b32 %r34,%r32; add.f32 %r24,%r34,%r34; mov.f32 %r43,0f3f800000; sub.f32 %r35,%r43,%r34; .loc 1 48 0 setp.gt.s32 %r44,%r32,1056964607; @ %r44 bra $L7; $L9: .loc 1 50 0 mul.f32 %r46,%r24,%r34; div.rn.f32 %r47,%r46,%r35; add.f32 %r48,%r47,%r24; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r48; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } mul.f32 %r36,%r49,0f3f000000; bra $L8; $L7: .loc 1 52 0 div.rn.f32 %r51,%r24,%r35; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r52,[%value_in]; } mul.f32 %r36,%r52,0f3f000000; $L8: .loc 1 53 0 setp.ge.s32 %r53,%r31,0; @ %r53 bra $L1; neg.f32 %r36,%r36; bra $L1; $L10: .loc 1 46 0 mov.f32 %r36,%r37; bra $L1; $L11: .loc 1 47 0 mov.b32 %r34,%r32; add.f32 %r24,%r34,%r34; mov.f32 %r55,0f3f800000; sub.f32 %r35,%r55,%r34; bra $L9; $L1: .loc 1 54 0 mov.f32 %value,%r36; st.param.f32 [%value_out],%value; ret; } lib_a-ef_cosh.o/0 0 0 644 3564 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_coshf .visible .func (.param .f32 %value_out) __ieee754_coshf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_cosh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1f .extern .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_coshf .visible .func (.param .f32 %value_out) __ieee754_coshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r32; .reg .u32 %r33; .reg .f32 %r39; .reg .f32 %r40; .reg .pred %r41; .reg .pred %r42; .reg .f32 %r44; .reg .f32 %r46; .reg .pred %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .pred %r51; .reg .f32 %r53; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .pred %r58; .reg .f32 %r60; .reg .f32 %r62; .reg .pred %r63; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; mov.f32 %r40,%ar0; .loc 1 38 0 mov.b32 %r32,%r40; .loc 1 39 0 and.b32 %r33,%r32,2147483647; .loc 1 42 0 setp.le.s32 %r41,%r33,2139095039; @ %r41 bra $L2; mul.f32 %r39,%r40,%r40; bra $L1; $L2: .loc 1 45 0 setp.gt.s32 %r42,%r33,1051816471; @ %r42 bra $L4; .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r46,[%value_in]; } .loc 1 47 0 add.f32 %r39,%r46,0f3f800000; .loc 1 48 0 setp.le.s32 %r47,%r33,603979775; @ %r47 bra $L1; .loc 1 49 0 mul.f32 %r48,%r46,%r46; add.f32 %r49,%r39,%r39; div.rn.f32 %r50,%r48,%r49; add.f32 %r39,%r50,0f3f800000; bra $L1; $L4: .loc 1 53 0 setp.gt.s32 %r51,%r33,1102053375; @ %r51 bra $L5; .loc 1 54 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r53,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r53; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r55,[%value_in]; } .loc 1 55 0 mov.f32 %r57,0f3f000000; div.rn.f32 %r56,%r57,%r55; fma.rn.f32 %r39,%r55,0f3f000000,%r56; bra $L1; $L5: .loc 1 59 0 setp.gt.s32 %r58,%r33,1118925335; @ %r58 bra $L6; .loc 1 60 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r60,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r60; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r62,[%value_in]; } mul.f32 %r39,%r62,0f3f000000; bra $L1; $L6: .loc 1 63 0 setp.gt.s32 %r63,%r33,1119016188; @ %r63 bra $L7; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r65,[%value_in]; } mul.f32 %r67,%r65,0f3f000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } .loc 1 65 0 mul.f32 %r69,%r68,0f3f000000; .loc 1 66 0 mul.f32 %r39,%r69,%r68; bra $L1; $L7: .loc 1 70 0 mov.f32 %r70,0f7149f2ca; mul.f32 %r39,%r70,0f7149f2ca; $L1: .loc 1 71 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } lib_a-ef_exp.o/ 0 0 0 644 4887 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .visible .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_exp.c" // BEGIN VAR DEF: ln2LO .const .align 4 .u32 ln2LO[2] = {924317649,3071801297 }; // BEGIN VAR DEF: halF .const .align 4 .u32 halF[2] = {1056964608,3204448256 }; // BEGIN VAR DEF: ln2HI .const .align 4 .u32 ln2HI[2] = {1060204928,3207688576 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_expf .visible .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f32 %r49; .reg .f32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r65; .reg .u32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .f32 %r73; .reg .u32 %r77; .reg .u32 %r78; .reg .u16 %r80; .reg .u16 %r81; .reg .u16 %r82; .reg .u32 %r83; .reg .u16 %r84; .reg .pred %r85; .reg .pred %r86; .reg .pred %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .f32 %r92; .reg .u64 %r93; .reg .u64 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .pred %r106; .reg .f32 %r107; .reg .pred %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .f32 %r126; .reg .pred %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .f32 %r133; mov.f32 %r68,%ar0; .loc 1 53 0 mov.b32 %r52,%r68; .loc 1 55 0 and.b32 %r55,%r52,2147483647; .loc 1 58 0 setp.le.u32 %r69,%r55,2139095040; @ %r69 bra $L2; .loc 1 59 0 add.f32 %r67,%r68,%r68; bra $L1; $L2: .loc 1 54 0 shr.u32 %r22,%r52,31; .loc 1 60 0 setp.ne.u32 %r70,%r55,2139095040; @ %r70 bra $L4; .loc 1 61 0 setp.ne.u32 %r71,%r22,0; selp.f32 %r67,0f00000000,%r68,%r71; bra $L1; $L4: .loc 1 62 0 setp.le.s32 %r72,%r52,1118925335; @ %r72 bra $L5; .loc 1 63 0 mov.f32 %r73,0f7149f2ca; mul.f32 %r67,%r73,0f7149f2ca; bra $L1; $L5: .loc 1 64 0 set.u32.gt.u32 %r77,%r55,1120924085; neg.s32 %r78,%r77; cvt.u16.u32 %r81,%r22; cvt.u16.u32 %r82,%r78; and.b16 %r80,%r81,%r82; cvt.u32.u16 %r83,%r80; cvt.u16.u8 %r84,%r83; setp.ne.u16 %r85,%r84,0; @ %r85 bra $L14; .loc 1 68 0 setp.le.u32 %r86,%r55,1051816472; @ %r86 bra $L6; .loc 1 69 0 setp.gt.u32 %r87,%r55,1065686417; @ %r87 bra $L7; .loc 1 70 0 cvta.const.u64 %r88,ln2HI; cvt.s64.s32 %r89,%r22; shl.b64 %r90,%r89,2; add.u64 %r91,%r88,%r90; ld.f32 %r92,[%r91]; sub.f32 %r49,%r68,%r92; cvta.const.u64 %r93,ln2LO; add.u64 %r96,%r93,%r90; ld.f32 %r50,[%r96]; mov.u32 %r98,1; sub.u32 %r97,%r98,%r22; sub.u32 %r51,%r97,%r22; bra $L8; $L7: .loc 1 72 0 cvta.const.u64 %r99,halF; cvt.s64.s32 %r100,%r22; shl.b64 %r101,%r100,2; add.u64 %r102,%r99,%r101; ld.f32 %r104,[%r102]; fma.rn.f32 %r103,%r68,0f3fb8aa3b,%r104; cvt.rzi.s32.f32 %r51,%r103; .loc 1 73 0 cvt.rn.f32.s32 %r56,%r51; .loc 1 74 0 fma.rn.f32 %r49,%r56,0fbf317180,%r68; .loc 1 75 0 mul.f32 %r50,%r56,0f3717f7d1; $L8: .loc 1 77 0 sub.f32 %r68,%r49,%r50; bra $L9; $L6: .loc 1 79 0 setp.gt.u32 %r106,%r55,830472191; @ %r106 bra $L15; .loc 1 80 0 add.f32 %r107,%r68,0f7149f2ca; setp.gt.f32 %r108,%r107,0f3f800000; @ ! %r108 bra $L18; add.f32 %r67,%r68,0f3f800000; bra $L1; $L15: .loc 1 50 0 mov.u32 %r51,0; bra $L9; $L18: mov.u32 %r51,0; $L9: .loc 1 84 0 mul.f32 %r57,%r68,%r68; .loc 1 85 0 fma.rn.f32 %r109,%r57,0f3331bb4c,0fb5ddea0e; fma.rn.f32 %r110,%r109,%r57,0f388ab355; fma.rn.f32 %r111,%r110,%r57,0fbb360b61; fma.rn.f32 %r112,%r111,%r57,0f3e2aaaab; neg.f32 %r113,%r112; fma.rn.f32 %r58,%r113,%r57,%r68; mul.f32 %r65,%r68,%r58; .loc 1 86 0 setp.ne.u32 %r114,%r51,0; @ %r114 bra $L11; mov.f32 %r116,0f40000000; sub.f32 %r115,%r58,%r116; div.rn.f32 %r117,%r65,%r115; sub.f32 %r118,%r117,%r68; mov.f32 %r119,0f3f800000; sub.f32 %r67,%r119,%r118; bra $L1; $L11: .loc 1 87 0 mov.f32 %r121,0f40000000; sub.f32 %r120,%r121,%r58; div.rn.f32 %r122,%r65,%r120; sub.f32 %r123,%r50,%r122; sub.f32 %r124,%r123,%r49; mov.f32 %r126,0f3f800000; sub.f32 %r125,%r126,%r124; mov.b32 %r66,%r125; .loc 1 88 0 setp.lt.s32 %r127,%r51,-125; @ %r127 bra $L12; .loc 1 91 0 shl.b32 %r128,%r51,23; add.u32 %r129,%r128,%r66; mov.b32 %r67,%r129; .loc 1 92 0 bra $L1; $L12: .loc 1 96 0 add.u32 %r130,%r51,100; shl.b32 %r131,%r130,23; add.u32 %r132,%r131,%r66; .loc 1 97 0 mov.b32 %r133,%r132; mul.f32 %r67,%r133,0f0d800000; bra $L1; $L14: .loc 1 61 0 mov.f32 %r67,0f00000000; $L1: .loc 1 99 0 mov.f32 %value,%r67; st.param.f32 [%value_out],%value; ret; } lib_a-ef_fmod.o/0 0 0 644 5848 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmodf .visible .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_fmod.c" // BEGIN VAR DEF: Zero .const .align 4 .u32 Zero[2] = {0,2147483648 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_fmodf .visible .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r33; .reg .u32 %r36; .reg .f32 %r37; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r53; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r65; .reg .u32 %r69; .reg .u32 %r73; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u32 %r89; .reg .u32 %r90; .reg .u16 %r92; .reg .u16 %r94; .reg .u32 %r95; .reg .u16 %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .u64 %r100; .reg .u32 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .u32 %r108; .reg .pred %r110; .reg .u32 %r111; .reg .pred %r112; .reg .pred %r114; .reg .u32 %r115; .reg .pred %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r120; .reg .u32 %r121; .reg .pred %r122; .reg .pred %r124; .reg .u64 %r125; .reg .u32 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r131; .reg .pred %r132; .reg .pred %r133; .reg .pred %r134; .reg .u64 %r135; .reg .u32 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r139; .reg .pred %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .u32 %r146; .reg .u32 %r147; .reg .u32 %r148; .reg .u32 %r149; .reg .u32 %r150; .reg .u32 %r151; .reg .pred %r153; mov.f32 %r77,%ar0; mov.f32 %r78,%ar1; .loc 1 39 0 mov.b32 %r57,%r77; .loc 1 40 0 mov.b32 %r58,%r78; .loc 1 42 0 and.b32 %r60,%r57,2147483647; .loc 1 43 0 and.b32 %r61,%r58,2147483647; .loc 1 46 0 set.u32.eq.u32 %r80,%r61,0; neg.s32 %r81,%r80; .loc 1 47 0 set.u32.gt.s32 %r83,%r61,2139095040; neg.s32 %r84,%r83; cvt.u16.u32 %r86,%r81; cvt.u16.u32 %r87,%r84; or.b16 %r85,%r86,%r87; set.u32.gt.s32 %r89,%r60,2139095039; neg.s32 %r90,%r89; cvt.u16.u32 %r94,%r90; or.b16 %r92,%r85,%r94; cvt.u32.u16 %r95,%r92; cvt.u16.u8 %r96,%r95; setp.eq.u16 %r97,%r96,0; @ %r97 bra $L2; .loc 1 49 0 mul.f32 %r37,%r77,%r78; div.rn.f32 %r76,%r37,%r37; bra $L1; $L2: .loc 1 50 0 setp.lt.s32 %r98,%r60,%r61; @ %r98 bra $L27; .loc 1 41 0 and.b32 %r59,%r57,-2147483648; .loc 1 51 0 setp.ne.u32 %r99,%r60,%r61; @ %r99 bra $L4; .loc 1 52 0 cvta.const.u64 %r100,Zero; shr.u32 %r101,%r59,31; cvt.u64.u32 %r102,%r101; shl.b64 %r103,%r102,2; add.u64 %r104,%r100,%r103; ld.f32 %r76,[%r104]; bra $L1; $L4: .loc 1 57 0 setp.gt.s32 %r105,%r60,8388607; @ %r105 bra $L5; .loc 1 58 0 shl.b32 %r63,%r60,8; setp.ne.u32 %r106,%r63,0; @ %r106 bra $L28; .loc 1 62 0 setp.le.s32 %r107,%r61,8388607; @ %r107 bra $L29; .loc 1 64 0 shr.s32 %r108,%r61,23; add.u32 %r73,%r108,-127; .loc 1 58 0 mov.u32 %r33,-126; bra $L8; $L28: mov.u32 %r33,-126; $L6: add.u32 %r33,%r33,-1; add.u32 %r63,%r63,%r63; setp.gt.s32 %r110,%r63,0; @ %r110 bra $L6; bra $L9; $L5: .loc 1 59 0 shr.s32 %r111,%r60,23; add.u32 %r33,%r111,-127; $L9: .loc 1 62 0 setp.gt.s32 %r112,%r61,8388607; @ %r112 bra $L10; bra $L7; $L29: .loc 1 58 0 mov.u32 %r33,-126; $L7: .loc 1 63 0 shl.b32 %r65,%r61,8; mov.u32 %r73,-126; $L11: add.u32 %r73,%r73,-1; add.u32 %r65,%r65,%r65; setp.ge.s32 %r114,%r65,0; @ %r114 bra $L11; bra $L12; $L10: .loc 1 64 0 shr.s32 %r115,%r61,23; add.u32 %r73,%r115,-127; $L12: .loc 1 67 0 setp.lt.s32 %r116,%r33,-126; @ %r116 bra $L13; $L8: .loc 1 68 0 and.b32 %r42,%r57,8388607; or.b32 %r53,%r42,8388608; bra $L14; $L13: .loc 1 70 0 mov.u32 %r118,-126; sub.u32 %r117,%r118,%r33; .loc 1 71 0 shl.b32 %r53,%r60,%r117; $L14: .loc 1 73 0 setp.lt.s32 %r153,%r73,-126; @ %r153 bra $L15; .loc 1 74 0 and.b32 %r43,%r58,8388607; or.b32 %r55,%r43,8388608; bra $L16; $L15: .loc 1 76 0 mov.u32 %r121,-126; sub.u32 %r120,%r121,%r73; .loc 1 77 0 shl.b32 %r55,%r61,%r120; $L16: .loc 1 81 0 sub.u32 %r36,%r33,%r73; .loc 1 82 0 bra $L17; $L21: .loc 1 84 0 setp.ge.s32 %r122,%r69,0; @ %r122 bra $L18; add.u32 %r53,%r53,%r53; bra $L19; $L18: .loc 1 86 0 setp.ne.u32 %r124,%r69,0; @ %r124 bra $L20; .loc 1 87 0 cvta.const.u64 %r125,Zero; shr.u32 %r126,%r59,31; cvt.u64.u32 %r127,%r126; shl.b64 %r128,%r127,2; add.u64 %r129,%r125,%r128; ld.f32 %r76,[%r129]; bra $L1; $L20: .loc 1 88 0 add.u32 %r53,%r69,%r69; $L19: add.u32 %r36,%r36,-1; $L17: sub.u32 %r69,%r53,%r55; .loc 1 82 0 setp.ne.u32 %r131,%r36,0; @ %r131 bra $L21; .loc 1 92 0 setp.ge.s32 %r132,%r69,0; selp.u32 %r69,%r69,%r53,%r132; .loc 1 95 0 setp.eq.u32 %r133,%r69,0; @ %r133 bra $L23; .loc 1 97 0 setp.le.s32 %r134,%r69,8388607; @ %r134 bra $L24; bra $L25; $L23: .loc 1 96 0 cvta.const.u64 %r135,Zero; shr.u32 %r136,%r59,31; cvt.u64.u32 %r137,%r136; shl.b64 %r138,%r137,2; add.u64 %r139,%r135,%r138; ld.f32 %r76,[%r139]; bra $L1; $L24: .loc 1 98 0 add.u32 %r69,%r69,%r69; .loc 1 99 0 add.u32 %r73,%r73,-1; .loc 1 97 0 setp.le.s32 %r141,%r69,8388607; @ %r141 bra $L24; setp.lt.s32 %r153,%r73,-126; $L25: .loc 1 101 0 @ %r153 bra $L26; .loc 1 102 0 add.u32 %r143,%r73,127; shl.b32 %r144,%r143,23; add.u32 %r145,%r69,-8388608; .loc 1 103 0 or.b32 %r146,%r145,%r59; or.b32 %r147,%r144,%r146; mov.b32 %r76,%r147; bra $L1; $L26: .loc 1 107 0 mov.u32 %r149,-126; sub.u32 %r148,%r149,%r73; .loc 1 108 0 shr.s32 %r150,%r69,%r148; .loc 1 109 0 or.b32 %r151,%r150,%r59; mov.b32 %r76,%r151; bra $L1; $L27: .loc 1 50 0 mov.f32 %r76,%r77; $L1: .loc 1 113 0 mov.f32 %value,%r76; st.param.f32 [%value_out],%value; ret; } /157 0 0 0 644 4522 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypotf .visible .func (.param .f32 %value_out) __ieee754_hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_hypot.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_hypotf .visible .func (.param .f32 %value_out) __ieee754_hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r42; .reg .f32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r52; .reg .u32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .pred %r72; .reg .pred %r73; .reg .pred %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .u32 %r81; .reg .f32 %r83; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r104; .reg .pred %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .f32 %r108; mov.f32 %r67,%ar0; mov.f32 %r68,%ar1; .loc 1 28 0 mov.b32 %r52,%r67; .loc 1 29 0 and.b32 %r49,%r52,2147483647; .loc 1 30 0 mov.b32 %r53,%r68; .loc 1 31 0 and.b32 %r48,%r53,2147483647; .loc 1 32 0 setp.lt.s32 %r70,%r49,%r48; @ %r70 bra $L2; mov.u32 %r69,%r48; mov.u32 %r48,%r49; mov.u32 %r49,%r69; $L2: .loc 1 33 0 mov.b32 %r66,%r48; .loc 1 34 0 mov.b32 %r46,%r49; .loc 1 35 0 sub.u32 %r71,%r48,%r49; setp.le.s32 %r72,%r71,251658240; @ %r72 bra $L3; add.f32 %r66,%r66,%r46; bra $L1; $L3: .loc 1 37 0 setp.le.s32 %r73,%r48,1484783616; @ %r73 bra $L13; .loc 1 38 0 setp.le.s32 %r74,%r48,2139095039; @ %r74 bra $L6; .loc 1 40 0 setp.eq.u32 %r75,%r48,2139095040; @ %r75 bra $L14; .loc 1 39 0 add.f32 %r66,%r66,%r46; bra $L7; $L14: .loc 1 40 0 mov.f32 %r66,0f7f800000; $L7: .loc 1 41 0 setp.eq.u32 %r76,%r49,2139095040; selp.f32 %r66,0f7f800000,%r66,%r76; bra $L1; $L6: .loc 1 45 0 add.u32 %r48,%r48,-570425344; add.u32 %r49,%r49,-570425344; .loc 1 46 0 mov.b32 %r66,%r48; .loc 1 47 0 mov.b32 %r46,%r49; .loc 1 45 0 mov.u32 %r47,68; bra $L5; $L13: .loc 1 36 0 mov.u32 %r47,0; $L5: .loc 1 49 0 setp.gt.s32 %r77,%r49,645922815; @ %r77 bra $L8; .loc 1 50 0 setp.eq.u32 %r78,%r49,0; @ %r78 bra $L1; .loc 1 52 0 setp.gt.s32 %r79,%r49,8388607; @ %r79 bra $L9; .loc 1 54 0 mul.f32 %r46,%r46,0f7e800000; .loc 1 55 0 mul.f32 %r66,%r66,0f7e800000; .loc 1 56 0 add.u32 %r47,%r47,-126; bra $L8; $L9: .loc 1 58 0 add.u32 %r48,%r48,570425344; .loc 1 59 0 add.u32 %r49,%r49,570425344; .loc 1 60 0 add.u32 %r47,%r47,-68; .loc 1 61 0 mov.b32 %r66,%r48; .loc 1 62 0 mov.b32 %r46,%r49; $L8: .loc 1 66 0 sub.f32 %r54,%r66,%r46; .loc 1 67 0 setp.lt.f32 %r80,%r46,%r54; @ ! %r80 bra $L23; .loc 1 68 0 and.b32 %r81,%r48,-4096; mov.b32 %r59,%r81; .loc 1 70 0 neg.f32 %r83,%r46; add.f32 %r84,%r66,%r59; .loc 1 69 0 sub.f32 %r85,%r66,%r59; .loc 1 70 0 mul.f32 %r86,%r84,%r85; neg.f32 %r87,%r86; fma.rn.f32 %r88,%r83,%r46,%r87; neg.f32 %r89,%r88; fma.rn.f32 %r90,%r59,%r59,%r89; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r90; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } mov.f32 %r66,%r91; bra $L12; $L23: .loc 1 73 0 and.b32 %r92,%r49,-4096; mov.b32 %r55,%r92; .loc 1 75 0 add.u32 %r93,%r48,8388608; mov.b32 %r57,%r93; .loc 1 77 0 neg.f32 %r94,%r54; .loc 1 74 0 sub.f32 %r95,%r46,%r55; .loc 1 76 0 neg.f32 %r96,%r57; fma.rn.f32 %r97,%r66,0f40000000,%r96; .loc 1 77 0 mul.f32 %r98,%r97,%r46; fma.rn.f32 %r99,%r95,%r57,%r98; neg.f32 %r100,%r99; fma.rn.f32 %r101,%r94,%r54,%r100; neg.f32 %r102,%r101; fma.rn.f32 %r42,%r55,%r57,%r102; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r104,[%value_in]; } mov.f32 %r66,%r104; $L12: .loc 1 79 0 setp.eq.u32 %r105,%r47,0; @ %r105 bra $L1; .loc 1 80 0 shl.b32 %r106,%r47,23; add.u32 %r107,%r106,1065353216; .loc 1 81 0 mov.b32 %r108,%r107; mul.f32 %r66,%r66,%r108; $L1: .loc 1 83 0 mov.f32 %value,%r66; st.param.f32 [%value_out],%value; ret; } lib_a-ef_j0.o/ 0 0 0 644 14758 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: pzerof .func (.param .f32 %value_out) pzerof (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_j0.c" // BEGIN FUNCTION DECL: qzerof .func (.param .f32 %value_out) qzerof (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0f .visible .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0f .visible .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN FUNCTION DEF: pzerof .func (.param .f32 %value_out) pzerof (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; mov.f32 %r50,%ar0; .loc 1 293 0 mov.b32 %r35,%r50; .loc 1 294 0 and.b32 %r36,%r35,2147483647; .loc 1 295 0 setp.gt.s32 %r51,%r36,1090519039; @ %r51 bra $L3; .loc 1 296 0 setp.gt.s32 %r52,%r36,1089936471; @ %r52 bra $L4; .loc 1 297 0 setp.gt.s32 %r53,%r36,1077336935; selp.f32 %r48,0f432d94b8,0f416a859a,%r53; selp.f32 %r47,0f448cffe6,0f4319e01a,%r53; selp.f32 %r46,0f44953373,0f43873c32,%r53; selp.f32 %r45,0f43b4c1ca,0f430834f0,%r53; selp.f32 %r44,0fc1fb9565,0fc04ef40d,%r53; selp.f32 %r43,0fc2685112,0fc1331736,%r53; selp.f32 %r42,0fc1afba52,0fc0f4579f,%r53; selp.f32 %r41,0fc01a2d95,0fbfb9b1cc,%r53; selp.f32 %r40,0fbd8fffb8,0fbd8ffb12,%r53; selp.f32 %r28,0f420f6c94,0f41b1c32d,%r53; selp.f32 %r23,0fb12f081b,0fb3be98b7,%r53; bra $L2; $L3: mov.f32 %r48,0f473a0bba; mov.f32 %r47,0f47e4087c; mov.f32 %r46,0f471e95db; mov.f32 %r45,0f456f9beb; mov.f32 %r44,0fc5a4285a; mov.f32 %r43,0fc51b5376; mov.f32 %r42,0fc3808814; mov.f32 %r41,0fc1014e86; mov.f32 %r40,0fbd900000; .loc 1 295 0 mov.f32 %r28,0f42e91198; mov.f32 %r23,0f00000000; bra $L2; $L4: mov.f32 %r48,0f451660ee; mov.f32 %r47,0f461665c8; mov.f32 %r46,0f45bad7c4; mov.f32 %r45,0f44836813; mov.f32 %r44,0fc3ad3779; mov.f32 %r43,0fc3a59d9b; mov.f32 %r42,0fc287597b; mov.f32 %r41,0fc0851b88; mov.f32 %r40,0fbd8fffff; .loc 1 296 0 mov.f32 %r28,0f42730408; mov.f32 %r23,0fad48c58a; $L2: .loc 1 299 0 mul.f32 %r54,%r50,%r50; mov.f32 %r55,0f3f800000; div.rn.f32 %r37,%r55,%r54; .loc 1 300 0 fma.rn.f32 %r57,%r37,%r44,%r43; fma.rn.f32 %r58,%r57,%r37,%r42; fma.rn.f32 %r59,%r58,%r37,%r41; fma.rn.f32 %r60,%r59,%r37,%r40; fma.rn.f32 %r61,%r60,%r37,%r23; .loc 1 301 0 fma.rn.f32 %r62,%r37,%r48,%r47; fma.rn.f32 %r63,%r62,%r37,%r46; fma.rn.f32 %r64,%r63,%r37,%r45; fma.rn.f32 %r65,%r64,%r37,%r28; fma.rn.f32 %r66,%r65,%r37,0f3f800000; .loc 1 302 0 div.rn.f32 %r67,%r61,%r66; add.f32 %value,%r67,0f3f800000; .loc 1 303 0 st.param.f32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qzerof .func (.param .f32 %value_out) qzerof (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r37; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; mov.f32 %r53,%ar0; .loc 1 429 0 mov.b32 %r37,%r53; .loc 1 430 0 and.b32 %r38,%r37,2147483647; .loc 1 431 0 setp.gt.s32 %r54,%r38,1090519039; @ %r54 bra $L8; .loc 1 432 0 setp.gt.s32 %r55,%r38,1089936471; @ %r55 bra $L9; .loc 1 433 0 setp.gt.s32 %r56,%r38,1077336935; selp.f32 %r51,0fc3153f59,0fc0a9f358,%r56; selp.f32 %r50,0f451d4557,0f4354aa98,%r56; selp.f32 %r49,0f45c9e367,0f445cbbe5,%r56; selp.f32 %r48,0f4567825f,0f44533229,%r56; selp.f32 %r47,0f44316c1c,0f4386ac8f,%r56; selp.f32 %r46,0f4326bbe4,0f4182058c,%r56; selp.f32 %r45,0f432acedf,0f41fd5471,%r56; selp.f32 %r44,0f422a7cc5,0f4167edfd,%r56; selp.f32 %r43,0f405607e3,0f3fffc4bf,%r56; selp.f32 %r42,0f3d95ff70,0f3d95f62a,%r56; selp.f32 %r28,0f42430916,0f41f2ecb8,%r56; selp.f32 %r23,0f3196681b,0f342189db,%r56; bra $L7; $L8: mov.f32 %r51,0fc8a7eb69; mov.f32 %r50,0f494d3359; mov.f32 %r49,0f49441ed4; mov.f32 %r48,0f480b3293; mov.f32 %r47,0f45fd12c2; mov.f32 %r46,0f471096a0; mov.f32 %r45,0f460a6cca; mov.f32 %r44,0f440b6b19; mov.f32 %r43,0f413c4a93; mov.f32 %r42,0f3d960000; .loc 1 431 0 mov.f32 %r28,0f4323c6aa; mov.f32 %r23,0f00000000; bra $L7; $L9: mov.f32 %r51,0fc5a752be; mov.f32 %r50,0f470c88c1; mov.f32 %r49,0f475daf1d; mov.f32 %r48,0f46933e94; mov.f32 %r47,0f4501dd07; mov.f32 %r46,0f44f8bf4b; mov.f32 %r45,0f448067cd; mov.f32 %r44,0f43071c90; mov.f32 %r43,0f40babd86; mov.f32 %r42,0f3d95ffff; .loc 1 432 0 mov.f32 %r28,0f42a58da0; mov.f32 %r23,0f2da1ec79; $L7: .loc 1 435 0 mul.f32 %r57,%r53,%r53; mov.f32 %r58,0f3f800000; div.rn.f32 %r39,%r58,%r57; .loc 1 436 0 fma.rn.f32 %r60,%r39,%r46,%r45; fma.rn.f32 %r61,%r60,%r39,%r44; fma.rn.f32 %r62,%r61,%r39,%r43; fma.rn.f32 %r63,%r62,%r39,%r42; fma.rn.f32 %r64,%r63,%r39,%r23; .loc 1 437 0 fma.rn.f32 %r65,%r39,%r51,%r50; fma.rn.f32 %r66,%r65,%r39,%r49; fma.rn.f32 %r67,%r66,%r39,%r48; fma.rn.f32 %r68,%r67,%r39,%r47; fma.rn.f32 %r69,%r68,%r39,%r28; fma.rn.f32 %r70,%r69,%r39,0f3f800000; .loc 1 438 0 div.rn.f32 %r71,%r64,%r70; mov.f32 %r73,0f3e000000; sub.f32 %r72,%r71,%r73; div.rn.f32 %value,%r72,%r53; .loc 1 439 0 st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j0f .visible .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r42; .reg .f32 %r43; .reg .u32 %r46; .reg .f32 %r48; .reg .f32 %r53; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r68; .reg .pred %r69; .reg .f32 %r71; .reg .f32 %r73; .reg .pred %r74; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .pred %r79; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .pred %r90; .reg .f32 %r91; .reg .pred %r92; .reg .pred %r93; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r103; .reg .pred %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r110; mov.f32 %r62,%ar0; .loc 1 60 0 mov.b32 %r63,%r62; and.b32 %r46,%r63,2147483647; .loc 1 61 0 setp.le.s32 %r64,%r46,2139095039; @ %r64 bra $L12; mul.f32 %r65,%r62,%r62; mov.f32 %r66,0f3f800000; div.rn.f32 %r61,%r66,%r65; bra $L11; $L12: .loc 1 62 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } .loc 1 63 0 setp.le.s32 %r69,%r46,1073741823; @ %r69 bra $L14; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 65 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r73,[%value_in]; } .loc 1 66 0 sub.f32 %r42,%r71,%r73; .loc 1 67 0 add.f32 %r43,%r71,%r73; .loc 1 68 0 setp.gt.s32 %r74,%r46,2130706431; @ %r74 bra $L15; .loc 1 69 0 add.f32 %r76,%r68,%r68; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r76; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r77,[%value_in]; } neg.f32 %r53,%r77; .loc 1 70 0 mul.f32 %r78,%r71,%r73; setp.lt.f32 %r79,%r78,0f00000000; @ ! %r79 bra $L24; div.rn.f32 %r43,%r53,%r42; bra $L15; $L24: .loc 1 71 0 div.rn.f32 %r42,%r53,%r43; $L15: .loc 1 79 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),pzerof,(%out_arg1); ld.param.f32 %r81,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),qzerof,(%out_arg1); ld.param.f32 %r83,[%value_in]; } .loc 1 80 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r85,[%value_in]; } mul.f32 %r86,%r42,%r83; neg.f32 %r87,%r86; fma.rn.f32 %r88,%r43,%r81,%r87; mul.f32 %r89,%r88,0f3f106ebb; div.rn.f32 %r61,%r89,%r85; .loc 1 82 0 bra $L11; $L14: .loc 1 84 0 setp.gt.s32 %r90,%r46,956301311; @ %r90 bra $L18; .loc 1 85 0 add.f32 %r91,%r68,0f7149f2ca; setp.gt.f32 %r92,%r91,0f3f800000; @ ! %r92 bra $L18; .loc 1 86 0 setp.le.s32 %r93,%r46,838860799; @ %r93 bra $L21; .loc 1 87 0 mul.f32 %r95,%r68,0fbe800000; fma.rn.f32 %r61,%r95,%r68,0f3f800000; bra $L11; $L18: .loc 1 90 0 mul.f32 %r48,%r68,%r68; .loc 1 91 0 fma.rn.f32 %r96,%r48,0fb19eaf3c,0f35f58e88; fma.rn.f32 %r97,%r96,%r48,0fb947352e; fma.rn.f32 %r98,%r97,%r48,0f3c800000; mul.f32 %r99,%r98,%r48; .loc 1 92 0 fma.rn.f32 %r100,%r48,0f30a045e8,0f3509daa6; fma.rn.f32 %r101,%r100,%r48,0f38f53697; fma.rn.f32 %r102,%r101,%r48,0f3c7fe744; fma.rn.f32 %r103,%r102,%r48,0f3f800000; div.rn.f32 %r60,%r99,%r103; .loc 1 93 0 setp.gt.s32 %r104,%r46,1065353215; @ %r104 bra $L20; .loc 1 94 0 mov.f32 %r106,0f3e800000; sub.f32 %r105,%r60,%r106; fma.rn.f32 %r61,%r105,%r48,0f3f800000; bra $L11; $L20: .loc 1 97 0 fma.rn.f32 %r107,%r68,0f3f000000,0f3f800000; mul.f32 %r108,%r48,%r60; fma.rn.f32 %r110,%r68,0fbf000000,0f3f800000; fma.rn.f32 %r61,%r107,%r110,%r108; bra $L11; $L21: .loc 1 86 0 mov.f32 %r61,0f3f800000; $L11: .loc 1 99 0 mov.f32 %value,%r61; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y0f .visible .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r39; .reg .f32 %r43; .reg .f32 %r44; .reg .u32 %r46; .reg .u32 %r47; .reg .f32 %r48; .reg .f32 %r53; .reg .f32 %r60; .reg .f32 %r61; .reg .pred %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .pred %r65; .reg .f32 %r66; .reg .pred %r67; .reg .f32 %r68; .reg .pred %r69; .reg .f32 %r71; .reg .f32 %r73; .reg .pred %r74; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .pred %r79; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r103; .reg .f32 %r105; .reg .f32 %r106; mov.f32 %r61,%ar0; .loc 1 128 0 mov.b32 %r46,%r61; .loc 1 129 0 and.b32 %r47,%r46,2147483647; .loc 1 131 0 setp.le.s32 %r62,%r47,2139095039; @ %r62 bra $L26; fma.rn.f32 %r63,%r61,%r61,%r61; mov.f32 %r64,0f3f800000; div.rn.f32 %r60,%r64,%r63; bra $L25; $L26: .loc 1 132 0 setp.ne.u32 %r65,%r47,0; @ %r65 bra $L28; mov.f32 %r66,0fbf800000; div.rn.f32 %r60,%r66,0f00000000; bra $L25; $L28: .loc 1 133 0 setp.ge.s32 %r67,%r46,0; @ %r67 bra $L29; mov.f32 %r68,0f00000000; div.rn.f32 %r60,%r68,0f00000000; bra $L25; $L29: .loc 1 134 0 setp.le.s32 %r69,%r47,1073741823; @ %r69 bra $L30; .loc 1 146 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 147 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r73,[%value_in]; } .loc 1 148 0 sub.f32 %r43,%r71,%r73; .loc 1 149 0 add.f32 %r44,%r71,%r73; .loc 1 154 0 setp.gt.s32 %r74,%r47,2130706431; @ %r74 bra $L31; .loc 1 155 0 add.f32 %r76,%r61,%r61; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r76; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r77,[%value_in]; } neg.f32 %r53,%r77; .loc 1 156 0 mul.f32 %r78,%r71,%r73; setp.lt.f32 %r79,%r78,0f00000000; @ ! %r79 bra $L36; div.rn.f32 %r44,%r53,%r43; bra $L31; $L36: .loc 1 157 0 div.rn.f32 %r43,%r53,%r44; $L31: .loc 1 161 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),pzerof,(%out_arg1); ld.param.f32 %r81,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),qzerof,(%out_arg1); ld.param.f32 %r83,[%value_in]; } .loc 1 162 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r85,[%value_in]; } mul.f32 %r86,%r44,%r83; fma.rn.f32 %r87,%r43,%r81,%r86; mul.f32 %r88,%r87,0f3f106ebb; div.rn.f32 %r60,%r88,%r85; .loc 1 164 0 bra $L25; $L30: .loc 1 166 0 setp.gt.s32 %r89,%r47,838860800; @ %r89 bra $L34; .loc 1 167 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } fma.rn.f32 %r60,%r91,0f3f22f983,0fbd9726b5; bra $L25; $L34: .loc 1 169 0 mul.f32 %r48,%r61,%r61; .loc 1 170 0 fma.rn.f32 %r92,%r48,0fae2f21eb,0f32a802ba; fma.rn.f32 %r93,%r92,%r48,0fb67ff53c; fma.rn.f32 %r94,%r93,%r48,0f39b62a69; fma.rn.f32 %r95,%r94,%r48,0fbc626746; fma.rn.f32 %r96,%r95,%r48,0f3e34e80d; fma.rn.f32 %r97,%r96,%r48,0fbd9726b5; .loc 1 171 0 fma.rn.f32 %r98,%r48,0f2ff280c2,0f348b216c; fma.rn.f32 %r99,%r98,%r48,0f389f65e0; fma.rn.f32 %r100,%r99,%r48,0f3c509385; fma.rn.f32 %r101,%r100,%r48,0f3f800000; .loc 1 172 0 div.rn.f32 %r39,%r97,%r101; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r103,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r105,[%value_in]; } mul.f32 %r106,%r103,%r105; fma.rn.f32 %r60,%r106,0f3f22f983,%r39; $L25: .loc 1 173 0 mov.f32 %value,%r60; st.param.f32 [%value_out],%value; ret; } lib_a-ef_j1.o/ 0 0 0 644 13727 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: ponef .func (.param .f32 %value_out) ponef (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_j1.c" // BEGIN FUNCTION DECL: qonef .func (.param .f32 %value_out) qonef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1f .visible .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1f .visible .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN FUNCTION DEF: ponef .func (.param .f32 %value_out) ponef (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; mov.f32 %r50,%ar0; .loc 1 292 0 mov.b32 %r35,%r50; .loc 1 293 0 and.b32 %r36,%r35,2147483647; .loc 1 294 0 setp.gt.s32 %r51,%r36,1090519039; @ %r51 bra $L3; .loc 1 295 0 setp.gt.s32 %r52,%r36,1089936471; @ %r52 bra $L4; .loc 1 296 0 setp.gt.s32 %r53,%r36,1077336935; selp.f32 %r48,0f42cf936c,0f4105d590,%r53; selp.f32 %r47,0f445eb3ed,0f42eb5bd7,%r53; selp.f32 %r46,0f4482dbe3,0f436846c7,%r53; selp.f32 %r45,0f43a86198,0f42fa9499,%r53; selp.f32 %r44,0f42423c7c,0f40a25a4d,%r53; selp.f32 %r43,0f42b61c2a,0f418d8d41,%r53; selp.f32 %r42,0f420c7a45,0f4143e1bc,%r53; selp.f32 %r41,0f407bb5e7,0f401795c0,%r53; selp.f32 %r40,0f3defffab,0f3deffa16,%r53; selp.f32 %r28,0f420b2a4d,0f41ab7dec,%r53; selp.f32 %r23,0f314fe10d,0f33e74ea8,%r53; bra $L2; $L3: mov.f32 %r48,0f46f0a88b; mov.f32 %r47,0f47bea166; mov.f32 %r46,0f47105c35; mov.f32 %r45,0f45642ee5; mov.f32 %r44,0f45f753d6; mov.f32 %r43,0f45722bed; mov.f32 %r42,0f43ce06a3; mov.f32 %r41,0f4153d4ea; mov.f32 %r40,0f3df00000; .loc 1 294 0 mov.f32 %r28,0f42e46a2c; mov.f32 %r23,0f00000000; bra $L2; $L4: mov.f32 %r48,0f44bc0180; mov.f32 %r47,0f45f52586; mov.f32 %r46,0f45a74a23; mov.f32 %r45,0f4477d9b1; mov.f32 %r44,0f44042dc6; mov.f32 %r43,0f440168b7; mov.f32 %r42,0f42d89dca; mov.f32 %r41,0f40d9b023; mov.f32 %r40,0f3defffff; .loc 1 295 0 mov.f32 %r28,0f426d1f55; mov.f32 %r23,0f2d68333f; $L2: .loc 1 298 0 mul.f32 %r54,%r50,%r50; mov.f32 %r55,0f3f800000; div.rn.f32 %r37,%r55,%r54; .loc 1 299 0 fma.rn.f32 %r57,%r37,%r44,%r43; fma.rn.f32 %r58,%r57,%r37,%r42; fma.rn.f32 %r59,%r58,%r37,%r41; fma.rn.f32 %r60,%r59,%r37,%r40; fma.rn.f32 %r61,%r60,%r37,%r23; .loc 1 300 0 fma.rn.f32 %r62,%r37,%r48,%r47; fma.rn.f32 %r63,%r62,%r37,%r46; fma.rn.f32 %r64,%r63,%r37,%r45; fma.rn.f32 %r65,%r64,%r37,%r28; fma.rn.f32 %r66,%r65,%r37,0f3f800000; .loc 1 301 0 div.rn.f32 %r67,%r61,%r66; add.f32 %value,%r67,0f3f800000; .loc 1 302 0 st.param.f32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qonef .func (.param .f32 %value_out) qonef (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r37; .reg .f32 %r39; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; mov.f32 %r53,%ar0; .loc 1 429 0 mov.b32 %r37,%r53; .loc 1 430 0 and.b32 %r54,%r37,2147483647; .loc 1 431 0 setp.gt.s32 %r55,%r54,1075838975; selp.f32 %r51,0fc88fcb48,0fc09eb437,%r55; selp.f32 %r50,0f4922be94,0f431bf2f2,%r55; selp.f32 %r49,0f492fb29c,0f4438d92a,%r55; selp.f32 %r48,0f4802bcd6,0f443d602e,%r55; selp.f32 %r47,0f45f48b17,0f437cfb47,%r55; selp.f32 %r46,0fc73d3683,0fc1aaf9b2,%r55; selp.f32 %r45,0fc639273a,0fc2294d1f,%r55; selp.f32 %r44,0fc43de683,0fc19d4f16,%r55; selp.f32 %r43,0fc1822c8d,0fc0302423,%r55; selp.f32 %r42,0fbdd20000,0fbdd1f475,%r55; selp.f32 %r28,0f43216537,0f41ec4454,%r55; selp.f32 %r23,0f00000000,0fb43f8932,%r55; .loc 1 435 0 mul.f32 %r56,%r53,%r53; mov.f32 %r57,0f3f800000; div.rn.f32 %r39,%r57,%r56; .loc 1 436 0 fma.rn.f32 %r59,%r39,%r46,%r45; fma.rn.f32 %r60,%r59,%r39,%r44; fma.rn.f32 %r61,%r60,%r39,%r43; fma.rn.f32 %r62,%r61,%r39,%r42; fma.rn.f32 %r63,%r62,%r39,%r23; .loc 1 437 0 fma.rn.f32 %r64,%r39,%r51,%r50; fma.rn.f32 %r65,%r64,%r39,%r49; fma.rn.f32 %r66,%r65,%r39,%r48; fma.rn.f32 %r67,%r66,%r39,%r47; fma.rn.f32 %r68,%r67,%r39,%r28; fma.rn.f32 %r69,%r68,%r39,0f3f800000; .loc 1 438 0 div.rn.f32 %r70,%r63,%r69; add.f32 %r71,%r70,0f3ec00000; div.rn.f32 %value,%r71,%r53; .loc 1 439 0 st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j1f .visible .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r38; .reg .f32 %r39; .reg .u32 %r41; .reg .u32 %r42; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r56; .reg .f32 %r57; .reg .pred %r58; .reg .f32 %r59; .reg .f32 %r61; .reg .pred %r62; .reg .f32 %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .pred %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .pred %r73; .reg .f32 %r75; .reg .f32 %r77; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r83; .reg .pred %r84; .reg .pred %r85; .reg .f32 %r86; .reg .pred %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; mov.f32 %r57,%ar0; .loc 1 60 0 mov.b32 %r41,%r57; .loc 1 61 0 and.b32 %r42,%r41,2147483647; .loc 1 62 0 setp.le.s32 %r58,%r42,2139095039; @ %r58 bra $L10; mov.f32 %r59,0f3f800000; div.rn.f32 %r56,%r59,%r57; bra $L9; $L10: .loc 1 63 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r57; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r61,[%value_in]; } .loc 1 64 0 setp.le.s32 %r62,%r42,1073741823; @ %r62 bra $L12; .loc 1 65 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } .loc 1 66 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r66,[%value_in]; } .loc 1 67 0 neg.f32 %r67,%r64; sub.f32 %r38,%r67,%r66; .loc 1 68 0 sub.f32 %r39,%r64,%r66; .loc 1 69 0 setp.gt.s32 %r68,%r42,2130706431; @ %r68 bra $L13; .loc 1 70 0 add.f32 %r70,%r61,%r61; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 71 0 mul.f32 %r72,%r64,%r66; setp.gt.f32 %r73,%r72,0f00000000; @ ! %r73 bra $L18; div.rn.f32 %r39,%r71,%r38; bra $L13; $L18: .loc 1 72 0 div.rn.f32 %r38,%r71,%r39; $L13: .loc 1 80 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),ponef,(%out_arg1); ld.param.f32 %r75,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),qonef,(%out_arg1); ld.param.f32 %r77,[%value_in]; } .loc 1 81 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r79,[%value_in]; } mul.f32 %r80,%r38,%r77; neg.f32 %r81,%r80; fma.rn.f32 %r82,%r39,%r75,%r81; mul.f32 %r83,%r82,0f3f106ebb; div.rn.f32 %r56,%r83,%r79; .loc 1 83 0 setp.ge.s32 %r84,%r41,0; @ %r84 bra $L9; neg.f32 %r56,%r56; bra $L9; $L12: mul.f32 %r56,%r57,0f3f000000; .loc 1 86 0 setp.gt.s32 %r85,%r42,838860799; @ %r85 bra $L16; .loc 1 87 0 add.f32 %r86,%r57,0f7149f2ca; setp.gt.f32 %r87,%r86,0f3f800000; @ %r87 bra $L9; $L16: .loc 1 89 0 mul.f32 %r44,%r57,%r57; .loc 1 90 0 fma.rn.f32 %r88,%r44,0f335557d2,0fb7862e36; fma.rn.f32 %r89,%r88,%r44,0f3ab86cfd; fma.rn.f32 %r90,%r89,%r44,0fbd800000; mul.f32 %r45,%r90,%r44; .loc 1 92 0 mul.f32 %r91,%r57,%r45; .loc 1 91 0 fma.rn.f32 %r92,%r44,0f2d59567e,0f31ad6446; fma.rn.f32 %r93,%r92,%r44,0f359dffc2; fma.rn.f32 %r94,%r93,%r44,0f3942fab6; fma.rn.f32 %r95,%r94,%r44,0f3c9ce859; fma.rn.f32 %r96,%r95,%r44,0f3f800000; .loc 1 93 0 div.rn.f32 %r97,%r91,%r96; add.f32 %r56,%r56,%r97; $L9: .loc 1 94 0 mov.f32 %value,%r56; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y1f .visible .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r40; .reg .f32 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .f32 %r50; .reg .f32 %r61; .reg .f32 %r62; .reg .pred %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .pred %r66; .reg .f32 %r67; .reg .pred %r68; .reg .f32 %r69; .reg .pred %r70; .reg .f32 %r72; .reg .f32 %r74; .reg .f32 %r75; .reg .pred %r76; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .pred %r81; .reg .pred %r82; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r87; .reg .f32 %r89; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .pred %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r107; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r113; .reg .f32 %r114; mov.f32 %r62,%ar0; .loc 1 129 0 mov.b32 %r48,%r62; .loc 1 130 0 and.b32 %r49,%r48,2147483647; .loc 1 132 0 setp.le.s32 %r63,%r49,2139095039; @ %r63 bra $L20; fma.rn.f32 %r64,%r62,%r62,%r62; mov.f32 %r65,0f3f800000; div.rn.f32 %r61,%r65,%r64; bra $L19; $L20: .loc 1 133 0 setp.ne.u32 %r66,%r49,0; @ %r66 bra $L22; mov.f32 %r67,0fbf800000; div.rn.f32 %r61,%r67,0f00000000; bra $L19; $L22: .loc 1 134 0 setp.ge.s32 %r68,%r48,0; @ %r68 bra $L23; mov.f32 %r69,0f00000000; div.rn.f32 %r61,%r69,0f00000000; bra $L19; $L23: .loc 1 135 0 setp.le.s32 %r70,%r49,1073741823; @ %r70 bra $L24; .loc 1 136 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r72,[%value_in]; } .loc 1 137 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r74,[%value_in]; } .loc 1 138 0 neg.f32 %r75,%r72; sub.f32 %r46,%r75,%r74; .loc 1 139 0 sub.f32 %r47,%r72,%r74; .loc 1 140 0 setp.gt.s32 %r76,%r49,2130706431; @ %r76 bra $L25; .loc 1 141 0 add.f32 %r78,%r62,%r62; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r78; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r79,[%value_in]; } .loc 1 142 0 mul.f32 %r80,%r72,%r74; setp.gt.f32 %r81,%r80,0f00000000; @ ! %r81 bra $L31; div.rn.f32 %r47,%r79,%r46; bra $L25; $L31: .loc 1 143 0 div.rn.f32 %r46,%r79,%r47; $L25: .loc 1 156 0 setp.le.s32 %r82,%r49,1207959552; @ %r82 bra $L28; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r84,[%value_in]; } mul.f32 %r85,%r46,0f3f106ebb; div.rn.f32 %r61,%r85,%r84; bra $L19; $L28: .loc 1 158 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),ponef,(%out_arg1); ld.param.f32 %r87,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),qonef,(%out_arg1); ld.param.f32 %r89,[%value_in]; } .loc 1 159 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } mul.f32 %r92,%r47,%r89; fma.rn.f32 %r93,%r46,%r87,%r92; mul.f32 %r94,%r93,0f3f106ebb; div.rn.f32 %r61,%r94,%r91; bra $L19; $L24: .loc 1 163 0 setp.gt.s32 %r95,%r49,612368384; @ %r95 bra $L29; .loc 1 164 0 mov.f32 %r96,0fbf22f983; div.rn.f32 %r61,%r96,%r62; bra $L19; $L29: .loc 1 166 0 mul.f32 %r50,%r62,%r62; .loc 1 167 0 fma.rn.f32 %r97,%r50,0fb3c56003,0f37c5581c; fma.rn.f32 %r98,%r97,%r50,0fbafaaf2a; fma.rn.f32 %r99,%r98,%r50,0f3d4e9e3c; fma.rn.f32 %r100,%r99,%r50,0fbe48c331; .loc 1 168 0 fma.rn.f32 %r101,%r50,0f2d9281cf,0f31d5f8eb; fma.rn.f32 %r102,%r101,%r50,0f35b602d4; fma.rn.f32 %r103,%r102,%r50,0f3954644b; fma.rn.f32 %r104,%r103,%r50,0f3ca3286a; fma.rn.f32 %r105,%r104,%r50,0f3f800000; .loc 1 169 0 div.rn.f32 %r40,%r100,%r105; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r107,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r109,[%value_in]; } mov.f32 %r111,0f3f800000; div.rn.f32 %r110,%r111,%r62; neg.f32 %r112,%r110; fma.rn.f32 %r113,%r107,%r109,%r112; mul.f32 %r114,%r113,0f3f22f983; fma.rn.f32 %r61,%r40,%r62,%r114; $L19: .loc 1 170 0 mov.f32 %value,%r61; st.param.f32 [%value_out],%value; ret; } lib_a-ef_jn.o/ 0 0 0 644 12198 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_jnf .visible .func (.param .f32 %value_out) __ieee754_jnf (.param .u32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_jn.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_ynf .visible .func (.param .f32 %value_out) __ieee754_ynf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0f .extern .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1f .extern .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0f .extern .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1f .extern .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_jnf .visible .func (.param .f32 %value_out) __ieee754_jnf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r45; .reg .f32 %r53; .reg .f32 %r57; .reg .u32 %r59; .reg .f32 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .f32 %r66; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r77; .reg .f32 %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .u32 %r98; .reg .f32 %r99; .reg .u32 %r100; .reg .u32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .u32 %r107; .reg .f32 %r108; .reg .pred %r109; .reg .pred %r110; .reg .pred %r111; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r116; .reg .u32 %r118; .reg .f32 %r120; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r125; .reg .u32 %r126; .reg .u16 %r127; .reg .u16 %r128; .reg .u16 %r129; .reg .u32 %r130; .reg .u16 %r131; .reg .pred %r132; .reg .pred %r133; .reg .f32 %r135; .reg .f32 %r137; .reg .u32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .pred %r142; .reg .pred %r143; .reg .pred %r144; .reg .f32 %r145; .reg .pred %r146; .reg .f32 %r148; .reg .f32 %r149; .reg .pred %r150; .reg .f32 %r151; .reg .pred %r152; .reg .pred %r154; .reg .f32 %r155; .reg .f32 %r156; .reg .f32 %r157; .reg .pred %r158; .reg .f32 %r160; .reg .f32 %r161; .reg .f32 %r163; .reg .f32 %r164; .reg .pred %r165; .reg .f32 %r166; .reg .f32 %r167; .reg .pred %r168; .reg .f32 %r169; .reg .f32 %r170; .reg .pred %r171; .reg .pred %r172; .reg .f32 %r174; .reg .f32 %r175; .reg .pred %r176; .reg .f32 %r178; mov.u32 %r107,%ar0; mov.f32 %r108,%ar1; .loc 1 47 0 mov.b32 %r80,%r108; .loc 1 48 0 and.b32 %r81,%r80,2147483647; .loc 1 50 0 setp.le.s32 %r109,%r81,2139095040; @ %r109 bra $L2; add.f32 %r106,%r108,%r108; bra $L1; $L2: .loc 1 51 0 setp.ge.s32 %r110,%r107,0; @ %r110 bra $L4; .loc 1 52 0 neg.s32 %r107,%r107; .loc 1 53 0 neg.f32 %r108,%r108; .loc 1 54 0 add.u32 %r80,%r80,-2147483648; bra $L5; $L4: .loc 1 56 0 setp.ne.u32 %r111,%r107,0; @ %r111 bra $L5; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r108; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r113,[%value_in]; } mov.f32 %r106,%r113; bra $L1; $L5: .loc 1 57 0 setp.ne.u32 %r114,%r107,1; @ %r114 bra $L6; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r108; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r116,[%value_in]; } mov.f32 %r106,%r116; bra $L1; $L6: .loc 1 58 0 shr.u32 %r118,%r80,31; and.b32 %r82,%r118,%r107; .loc 1 59 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r108; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r120,[%value_in]; } .loc 1 60 0 set.u32.eq.u32 %r122,%r81,0; neg.s32 %r123,%r122; set.u32.eq.u32 %r125,%r81,2139095040; neg.s32 %r126,%r125; cvt.u16.u32 %r128,%r123; cvt.u16.u32 %r129,%r126; or.b16 %r127,%r128,%r129; cvt.u32.u16 %r130,%r127; cvt.u16.u8 %r131,%r130; setp.ne.u16 %r132,%r131,0; @ %r132 bra $L25; .loc 1 62 0 cvt.rn.f32.s32 %r53,%r107; setp.le.f32 %r133,%r53,%r120; @ ! %r133 bra $L40; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r120; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r135,[%value_in]; } mov.f32 %r62,%r135; .loc 1 65 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r120; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r137,[%value_in]; } mov.f32 %r99,%r137; .loc 1 66 0 mov.u32 %r100,1; bra $L10; $L26: .loc 1 68 0 mov.f32 %r99,%r106; $L10: add.u32 %r138,%r100,%r100; cvt.rn.f32.s32 %r139,%r138; div.rn.f32 %r140,%r139,%r120; neg.f32 %r141,%r62; fma.rn.f32 %r106,%r140,%r99,%r141; .loc 1 66 0 add.u32 %r100,%r100,1; mov.f32 %r62,%r99; setp.lt.s32 %r142,%r100,%r107; @ %r142 bra $L26; bra $L7; $L40: .loc 1 72 0 setp.gt.s32 %r143,%r81,813694975; @ %r143 bra $L11; .loc 1 76 0 setp.gt.s32 %r144,%r107,33; @ %r144 bra $L27; .loc 1 79 0 mul.f32 %r95,%r120,0f3f000000; mov.f32 %r97,%r95; .loc 1 80 0 mov.f32 %r96,0f3f800000; mov.u32 %r98,2; $L12: .loc 1 81 0 cvt.rn.f32.s32 %r145,%r98; mul.f32 %r96,%r96,%r145; .loc 1 82 0 mul.f32 %r97,%r97,%r95; .loc 1 80 0 add.u32 %r98,%r98,1; setp.le.s32 %r146,%r98,%r107; @ %r146 bra $L12; .loc 1 84 0 div.rn.f32 %r106,%r97,%r96; bra $L7; $L11: .loc 1 118 0 add.u32 %r59,%r107,%r107; cvt.rn.f32.s32 %r148,%r59; div.rn.f32 %r61,%r148,%r120; mov.f32 %r149,0f40000000; div.rn.f32 %r84,%r149,%r120; .loc 1 119 0 add.f32 %r85,%r61,%r84; fma.rn.f32 %r57,%r61,%r85,0fbf800000; .loc 1 120 0 setp.lt.f32 %r150,%r57,0f4e6e6b28; @ ! %r150 bra $L41; .loc 1 119 0 mov.u32 %r93,1; $L15: .loc 1 121 0 add.u32 %r93,%r93,1; add.f32 %r85,%r85,%r84; .loc 1 122 0 neg.f32 %r151,%r61; mov.f32 %r61,%r57; .loc 1 124 0 fma.rn.f32 %r57,%r85,%r57,%r151; .loc 1 120 0 setp.lt.f32 %r152,%r57,0f4e6e6b28; @ %r152 bra $L15; bra $L13; $L41: .loc 1 119 0 mov.u32 %r93,1; $L13: .loc 1 127 0 add.u32 %r63,%r93,%r107; add.u32 %r45,%r63,%r63; setp.lt.s32 %r154,%r63,%r107; @ %r154 bra $L29; mov.f32 %r78,0f00000000; mov.f32 %r157,0f3f800000; $L17: cvt.rn.f32.s32 %r155,%r45; div.rn.f32 %r156,%r155,%r120; sub.f32 %r66,%r156,%r78; div.rn.f32 %r78,%r157,%r66; add.u32 %r45,%r45,-2; setp.le.s32 %r158,%r59,%r45; @ %r158 bra $L17; bra $L16; $L29: mov.f32 %r78,0f00000000; $L16: .loc 1 140 0 mul.f32 %r160,%r53,%r84; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r160; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r161,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r161; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r163,[%value_in]; } add.u32 %r92,%r107,-1; add.u32 %r104,%r59,-2; mul.f32 %r164,%r53,%r163; .loc 1 141 0 setp.lt.f32 %r165,%r164,0f42b17180; @ ! %r165 bra $L42; .loc 1 142 0 cvt.rn.f32.s32 %r91,%r104; mov.f32 %r77,%r78; .loc 1 129 0 mov.f32 %r105,0f3f800000; .loc 1 147 0 mov.f32 %r167,0f40000000; bra $L20; $L30: .loc 1 145 0 mov.f32 %r105,%r75; $L20: .loc 1 144 0 mul.f32 %r166,%r105,%r91; .loc 1 145 0 div.rn.f32 %r70,%r166,%r120; sub.f32 %r75,%r70,%r77; .loc 1 147 0 sub.f32 %r91,%r91,%r167; .loc 1 142 0 add.u32 %r92,%r92,-1; mov.f32 %r77,%r105; setp.ne.u32 %r168,%r92,0; @ %r168 bra $L30; bra $L21; $L42: .loc 1 150 0 cvt.rn.f32.s32 %r89,%r104; mov.f32 %r74,%r78; .loc 1 129 0 mov.f32 %r75,0f3f800000; .loc 1 155 0 mov.f32 %r170,0f40000000; .loc 1 160 0 mov.f32 %r178,%r75; $L24: .loc 1 152 0 mul.f32 %r169,%r75,%r89; .loc 1 153 0 div.rn.f32 %r71,%r169,%r120; sub.f32 %r88,%r71,%r74; .loc 1 155 0 sub.f32 %r89,%r89,%r170; .loc 1 157 0 setp.gt.f32 %r171,%r88,0f501502f9; @ ! %r171 bra $L43; .loc 1 158 0 div.rn.f32 %r74,%r75,%r88; .loc 1 159 0 div.rn.f32 %r78,%r78,%r88; .loc 1 160 0 mov.f32 %r75,%r178; bra $L22; $L43: mov.f32 %r74,%r75; .loc 1 153 0 mov.f32 %r75,%r88; $L22: .loc 1 150 0 add.u32 %r92,%r92,-1; setp.ne.u32 %r172,%r92,0; @ %r172 bra $L24; $L21: .loc 1 164 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r120; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r174,[%value_in]; } mul.f32 %r175,%r174,%r78; div.rn.f32 %r106,%r175,%r75; bra $L7; $L25: .loc 1 61 0 mov.f32 %r106,0f00000000; bra $L7; $L27: mov.f32 %r106,0f00000000; $L7: .loc 1 167 0 setp.ne.u32 %r176,%r82,1; @ %r176 bra $L1; neg.f32 %r106,%r106; $L1: .loc 1 168 0 mov.f32 %value,%r106; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_ynf .visible .func (.param .f32 %value_out) __ieee754_ynf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .f32 %r41; .reg .u32 %r45; .reg .f32 %r47; .reg .f32 %r49; .reg .u32 %r50; .reg .f32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .f32 %r63; .reg .pred %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .pred %r68; .reg .f32 %r70; .reg .f32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .u32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .u32 %r89; .reg .u16 %r90; .reg .pred %r91; .reg .pred %r92; mov.u32 %r50,%ar0; mov.f32 %r51,%ar1; .loc 1 181 0 mov.b32 %r37,%r51; .loc 1 182 0 and.b32 %r38,%r37,2147483647; .loc 1 184 0 setp.le.s32 %r52,%r38,2139095040; @ %r52 bra $L45; add.f32 %r49,%r51,%r51; bra $L44; $L45: .loc 1 185 0 setp.ne.u32 %r53,%r38,0; @ %r53 bra $L47; mov.f32 %r54,0fbf800000; div.rn.f32 %r49,%r54,0f00000000; bra $L44; $L47: .loc 1 186 0 setp.ge.s32 %r55,%r37,0; @ %r55 bra $L48; mov.f32 %r56,0f00000000; div.rn.f32 %r49,%r56,0f00000000; bra $L44; $L48: .loc 1 188 0 setp.ge.s32 %r57,%r50,0; @ %r57 bra $L49; .loc 1 189 0 neg.s32 %r50,%r50; .loc 1 190 0 add.u32 %r58,%r50,%r50; and.b32 %r59,%r58,2; mov.u32 %r60,1; sub.u32 %r40,%r60,%r59; bra $L50; $L49: .loc 1 192 0 setp.ne.u32 %r61,%r50,0; @ %r61 bra $L54; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y0f,(%out_arg1); ld.param.f32 %r63,[%value_in]; } mov.f32 %r49,%r63; bra $L44; $L54: .loc 1 187 0 mov.u32 %r40,1; $L50: .loc 1 193 0 setp.ne.u32 %r64,%r50,1; @ %r64 bra $L51; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y1f,(%out_arg1); ld.param.f32 %r66,[%value_in]; } cvt.rn.f32.s32 %r67,%r40; mul.f32 %r49,%r67,%r66; bra $L44; $L51: .loc 1 194 0 setp.eq.u32 %r68,%r38,2139095040; @ %r68 bra $L55; .loc 1 196 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y0f,(%out_arg1); ld.param.f32 %r70,[%value_in]; } mov.f32 %r47,%r70; .loc 1 197 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y1f,(%out_arg1); ld.param.f32 %r72,[%value_in]; } mov.f32 %r41,%r72; .loc 1 200 0 mov.b32 %r73,%r41; setp.eq.u32 %r74,%r73,-8388608; @ %r74 bra $L56; mov.u32 %r45,1; bra $L53; $L57: .loc 1 202 0 mov.f32 %r41,%r49; $L53: add.u32 %r75,%r45,%r45; cvt.rn.f32.s32 %r76,%r75; div.rn.f32 %r77,%r76,%r51; neg.f32 %r78,%r47; fma.rn.f32 %r49,%r77,%r41,%r78; .loc 1 200 0 add.u32 %r45,%r45,1; mov.f32 %r47,%r41; set.u32.lt.s32 %r80,%r45,%r50; neg.s32 %r81,%r80; mov.b32 %r83,%r49; set.u32.ne.u32 %r84,%r83,-8388608; neg.s32 %r85,%r84; cvt.u16.u32 %r87,%r81; cvt.u16.u32 %r88,%r85; and.b16 %r86,%r87,%r88; cvt.u32.u16 %r89,%r86; cvt.u16.u8 %r90,%r89; setp.ne.u16 %r91,%r90,0; @ %r91 bra $L57; bra $L52; $L56: .loc 1 197 0 mov.f32 %r49,%r72; $L52: .loc 1 206 0 setp.eq.u32 %r92,%r40,1; @ %r92 bra $L44; neg.f32 %r49,%r49; bra $L44; $L55: .loc 1 194 0 mov.f32 %r49,0f00000000; $L44: .loc 1 207 0 mov.f32 %value,%r49; st.param.f32 [%value_out],%value; ret; } lib_a-ef_log.o/ 0 0 0 644 4933 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .visible .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_log.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_logf .visible .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .u32 %r64; .reg .f32 %r65; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r84; .reg .f32 %r85; .reg .u32 %r86; .reg .pred %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r90; .reg .pred %r91; .reg .pred %r92; .reg .f32 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .u32 %r102; .reg .u32 %r103; .reg .pred %r104; .reg .pred %r105; .reg .pred %r106; .reg .f32 %r107; .reg .f32 %r109; .reg .f32 %r110; .reg .pred %r111; .reg .f32 %r113; .reg .f32 %r114; .reg .f32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u32 %r125; .reg .pred %r126; .reg .f32 %r127; .reg .f32 %r128; .reg .pred %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .f32 %r135; .reg .pred %r136; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; mov.f32 %r85,%ar0; .loc 1 50 0 mov.b32 %r51,%r85; .loc 1 53 0 and.b32 %r86,%r51,2147483647; setp.ne.u32 %r87,%r86,0; @ %r87 bra $L2; .loc 1 54 0 mov.f32 %r88,0fcc000000; div.rn.f32 %r84,%r88,0f00000000; bra $L1; $L2: .loc 1 55 0 setp.ge.s32 %r89,%r51,0; @ %r89 bra $L4; sub.f32 %r90,%r85,%r85; div.rn.f32 %r84,%r90,0f00000000; bra $L1; $L4: .loc 1 56 0 setp.le.s32 %r91,%r51,2139095039; @ %r91 bra $L5; add.f32 %r84,%r85,%r85; bra $L1; $L5: .loc 1 57 0 setp.gt.s32 %r92,%r51,8388607; @ %r92 bra $L13; .loc 1 58 0 mul.f32 %r93,%r85,0f4c000000; .loc 1 59 0 mov.b32 %r51,%r93; .loc 1 58 0 mov.u32 %r50,-25; bra $L6; $L13: .loc 1 52 0 mov.u32 %r50,0; $L6: .loc 1 61 0 shr.s32 %r94,%r51,23; add.u32 %r95,%r94,-127; add.u32 %r55,%r95,%r50; .loc 1 62 0 and.b32 %r56,%r51,8388607; .loc 1 63 0 add.u32 %r96,%r56,4913952; and.b32 %r57,%r96,8388608; .loc 1 65 0 shr.s32 %r97,%r57,23; add.u32 %r59,%r97,%r55; .loc 1 64 0 xor.b32 %r98,%r57,1065353216; or.b32 %r99,%r98,%r56; .loc 1 66 0 mov.b32 %r100,%r99; mov.f32 %r101,0f3f800000; sub.f32 %r60,%r100,%r101; .loc 1 67 0 add.u32 %r102,%r56,15; and.b32 %r103,%r102,8388607; setp.gt.s32 %r104,%r103,15; @ %r104 bra $L7; .loc 1 68 0 setp.neu.f32 %r105,%r60,0f00000000; @ %r105 bra $L8; setp.eq.u32 %r106,%r59,0; @ %r106 bra $L14; cvt.rn.f32.s32 %r73,%r59; .loc 1 69 0 mul.f32 %r107,%r73,0f3717f7d1; fma.rn.f32 %r84,%r73,0f3f317180,%r107; bra $L1; $L8: .loc 1 70 0 fma.rn.f32 %r109,%r60,0fbeaaaaab,0f3f000000; mul.f32 %r110,%r60,%r60; mul.f32 %r71,%r109,%r110; .loc 1 71 0 setp.ne.u32 %r111,%r59,0; @ %r111 bra $L9; sub.f32 %r84,%r60,%r71; bra $L1; $L9: cvt.rn.f32.s32 %r72,%r59; .loc 1 72 0 fma.rn.f32 %r113,%r72,0fb717f7d1,%r71; sub.f32 %r114,%r113,%r60; neg.f32 %r115,%r114; fma.rn.f32 %r84,%r72,0f3f317180,%r115; bra $L1; $L7: .loc 1 74 0 add.f32 %r116,%r60,0f40000000; div.rn.f32 %r61,%r60,%r116; .loc 1 75 0 cvt.rn.f32.s32 %r62,%r59; .loc 1 76 0 mul.f32 %r63,%r61,%r61; .loc 1 77 0 add.u32 %r64,%r56,-3187664; .loc 1 78 0 mul.f32 %r65,%r63,%r63; .loc 1 80 0 fma.rn.f32 %r117,%r65,0f3e1cd04f,0f3e638e29; fma.rn.f32 %r118,%r117,%r65,0f3ecccccd; .loc 1 81 0 fma.rn.f32 %r119,%r65,0f3e178897,0f3e3a3325; fma.rn.f32 %r120,%r119,%r65,0f3e924925; fma.rn.f32 %r121,%r120,%r65,0f3f2aaaab; mul.f32 %r122,%r121,%r63; .loc 1 83 0 fma.rn.f32 %r69,%r118,%r65,%r122; .loc 1 79 0 mov.u32 %r124,3523208; sub.u32 %r123,%r124,%r56; .loc 1 82 0 or.b32 %r125,%r123,%r64; .loc 1 84 0 setp.le.s32 %r126,%r125,0; @ %r126 bra $L10; .loc 1 85 0 mul.f32 %r127,%r60,0f3f000000; mul.f32 %r70,%r127,%r60; add.f32 %r128,%r69,%r70; mul.f32 %r83,%r128,%r61; .loc 1 86 0 setp.ne.u32 %r129,%r59,0; @ %r129 bra $L11; sub.f32 %r130,%r70,%r83; sub.f32 %r84,%r60,%r130; bra $L1; $L11: .loc 1 87 0 fma.rn.f32 %r131,%r62,0f3717f7d1,%r83; sub.f32 %r132,%r70,%r131; sub.f32 %r133,%r132,%r60; neg.f32 %r134,%r133; fma.rn.f32 %r84,%r62,0f3f317180,%r134; bra $L1; $L10: sub.f32 %r135,%r60,%r69; mul.f32 %r81,%r135,%r61; .loc 1 89 0 setp.ne.u32 %r136,%r59,0; @ %r136 bra $L12; sub.f32 %r84,%r60,%r81; bra $L1; $L12: .loc 1 90 0 fma.rn.f32 %r138,%r62,0fb717f7d1,%r81; sub.f32 %r139,%r138,%r60; neg.f32 %r140,%r139; fma.rn.f32 %r84,%r62,0f3f317180,%r140; bra $L1; $L14: .loc 1 68 0 mov.f32 %r84,0f00000000; $L1: .loc 1 92 0 mov.f32 %value,%r84; st.param.f32 [%value_out],%value; ret; } /175 0 0 0 644 2360 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10f .visible .func (.param .f32 %value_out) __ieee754_log10f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_log10.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_log10f .visible .func (.param .f32 %value_out) __ieee754_log10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r28; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r39; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r45; .reg .f32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .f32 %r49; .reg .pred %r50; .reg .f32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .f32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; mov.f32 %r46,%ar0; .loc 1 44 0 mov.b32 %r35,%r46; .loc 1 47 0 and.b32 %r47,%r35,2147483647; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L2; .loc 1 48 0 mov.f32 %r49,0fcc000000; div.rn.f32 %r45,%r49,0f00000000; bra $L1; $L2: .loc 1 49 0 setp.ge.s32 %r50,%r35,0; @ %r50 bra $L4; sub.f32 %r51,%r46,%r46; div.rn.f32 %r45,%r51,0f00000000; bra $L1; $L4: .loc 1 50 0 setp.le.s32 %r52,%r35,2139095039; @ %r52 bra $L5; add.f32 %r45,%r46,%r46; bra $L1; $L5: .loc 1 51 0 setp.gt.s32 %r53,%r35,8388607; @ %r53 bra $L7; .loc 1 52 0 mul.f32 %r54,%r46,0f4c000000; .loc 1 53 0 mov.b32 %r35,%r54; .loc 1 52 0 mov.u32 %r34,-25; bra $L6; $L7: .loc 1 46 0 mov.u32 %r34,0; $L6: .loc 1 55 0 shr.s32 %r55,%r35,23; add.u32 %r56,%r55,-127; add.u32 %r39,%r56,%r34; .loc 1 56 0 shr.u32 %r40,%r39,31; .loc 1 57 0 and.b32 %r28,%r35,8388607; .loc 1 58 0 add.u32 %r57,%r39,%r40; cvt.rn.f32.s32 %r42,%r57; .loc 1 57 0 mov.u32 %r60,127; sub.u32 %r59,%r60,%r40; shl.b32 %r61,%r59,23; or.b32 %r62,%r61,%r28; .loc 1 60 0 mov.b32 %r58,%r62; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r63,[%value_in]; } mul.f32 %r64,%r63,0f3ede5bd9; fma.rn.f32 %r65,%r42,0f355427db,%r64; .loc 1 61 0 fma.rn.f32 %r45,%r42,0f3e9a2080,%r65; $L1: .loc 1 62 0 mov.f32 %value,%r45; st.param.f32 [%value_out],%value; ret; } lib_a-ef_pow.o/ 0 0 0 644 17099 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __ieee754_powf .visible .func (.param .f32 %value_out) __ieee754_powf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_pow.c" // BEGIN GLOBAL FUNCTION DECL: nanf .extern .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_powf .visible .func (.param .f32 %value_out) __ieee754_powf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r26; .reg .f32 %r32; .reg .u32 %r35; .reg .f32 %r38; .reg .u32 %r43; .reg .u32 %r49; .reg .u32 %r67; .reg .u32 %r72; .reg .u32 %r78; .reg .u32 %r103; .reg .f32 %r118; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u32 %r134; .reg .u32 %r135; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r142; .reg .f32 %r146; .reg .f32 %r147; .reg .f32 %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r153; .reg .f32 %r154; .reg .f32 %r155; .reg .f32 %r157; .reg .f32 %r159; .reg .f32 %r161; .reg .f32 %r163; .reg .f32 %r164; .reg .f32 %r166; .reg .f32 %r168; .reg .f32 %r170; .reg .f32 %r171; .reg .f32 %r172; .reg .u32 %r174; .reg .u32 %r175; .reg .u32 %r176; .reg .f32 %r177; .reg .f32 %r178; .reg .f32 %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r182; .reg .f32 %r183; .reg .f32 %r185; .reg .u32 %r186; .reg .u32 %r187; .reg .u32 %r189; .reg .u32 %r207; .reg .f32 %r208; .reg .u32 %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r212; .reg .f32 %r213; .reg .f32 %r214; .reg .pred %r215; .reg .u32 %r217; .reg .u32 %r218; .reg .u32 %r220; .reg .u32 %r221; .reg .u16 %r222; .reg .u16 %r223; .reg .u16 %r224; .reg .u32 %r225; .reg .u16 %r226; .reg .pred %r227; .reg .pred %r228; .reg .u64 %r229; .reg .f32 %r230; .reg .pred %r232; .reg .pred %r233; .reg .u32 %r234; .reg .u32 %r236; .reg .u32 %r237; .reg .pred %r238; .reg .u32 %r239; .reg .u32 %r240; .reg .pred %r241; .reg .pred %r242; .reg .pred %r243; .reg .pred %r244; .reg .pred %r245; .reg .pred %r246; .reg .pred %r247; .reg .f32 %r248; .reg .pred %r249; .reg .u32 %r251; .reg .u32 %r252; .reg .u32 %r254; .reg .u32 %r255; .reg .u16 %r257; .reg .u16 %r258; .reg .u16 %r259; .reg .u32 %r260; .reg .u16 %r261; .reg .pred %r262; .reg .f32 %r264; .reg .f32 %r266; .reg .u32 %r267; .reg .u32 %r269; .reg .u32 %r270; .reg .u32 %r272; .reg .u32 %r273; .reg .u16 %r274; .reg .u16 %r275; .reg .u16 %r276; .reg .u32 %r277; .reg .u16 %r278; .reg .pred %r279; .reg .pred %r280; .reg .f32 %r281; .reg .u32 %r283; .reg .u32 %r284; .reg .pred %r285; .reg .pred %r286; .reg .u32 %r288; .reg .pred %r289; .reg .pred %r290; .reg .pred %r291; .reg .pred %r292; .reg .f32 %r293; .reg .pred %r294; .reg .pred %r295; .reg .f32 %r296; .reg .f32 %r297; .reg .f32 %r298; .reg .f32 %r299; .reg .f32 %r300; .reg .f32 %r301; .reg .f32 %r302; .reg .f32 %r304; .reg .f32 %r305; .reg .u32 %r306; .reg .f32 %r308; .reg .pred %r309; .reg .f32 %r310; .reg .u32 %r311; .reg .u32 %r312; .reg .pred %r313; .reg .pred %r314; .reg .f32 %r315; .reg .f32 %r316; .reg .u32 %r317; .reg .u32 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .f32 %r323; .reg .f32 %r325; .reg .f32 %r326; .reg .f32 %r327; .reg .f32 %r328; .reg .f32 %r329; .reg .f32 %r330; .reg .f32 %r331; .reg .f32 %r332; .reg .f32 %r333; .reg .f32 %r334; .reg .f32 %r335; .reg .f32 %r336; .reg .f32 %r337; .reg .f32 %r338; .reg .u32 %r339; .reg .f32 %r341; .reg .f32 %r342; .reg .f32 %r343; .reg .f32 %r344; .reg .f32 %r345; .reg .f32 %r346; .reg .u32 %r347; .reg .f32 %r349; .reg .f32 %r350; .reg .f32 %r351; .reg .f32 %r352; .reg .f32 %r353; .reg .f32 %r354; .reg .f32 %r355; .reg .u32 %r356; .reg .f32 %r358; .reg .f32 %r359; .reg .f32 %r360; .reg .u32 %r361; .reg .u32 %r362; .reg .pred %r363; .reg .u32 %r364; .reg .f32 %r365; .reg .f32 %r366; .reg .pred %r367; .reg .pred %r368; .reg .f32 %r369; .reg .pred %r370; .reg .f32 %r371; .reg .f32 %r372; .reg .pred %r373; .reg .f32 %r374; .reg .pred %r375; .reg .f32 %r376; .reg .pred %r377; .reg .f32 %r378; .reg .pred %r379; .reg .f32 %r380; .reg .pred %r381; .reg .u32 %r382; .reg .u32 %r383; .reg .u32 %r384; .reg .u32 %r385; .reg .u32 %r386; .reg .u32 %r387; .reg .u32 %r388; .reg .u32 %r389; .reg .u32 %r390; .reg .u32 %r391; .reg .u32 %r392; .reg .u32 %r393; .reg .pred %r394; .reg .f32 %r395; .reg .u32 %r396; .reg .f32 %r397; .reg .f32 %r398; .reg .f32 %r399; .reg .f32 %r401; .reg .f32 %r402; .reg .f32 %r403; .reg .f32 %r404; .reg .f32 %r405; .reg .f32 %r406; .reg .f32 %r407; .reg .f32 %r408; .reg .f32 %r409; .reg .f32 %r410; .reg .f32 %r411; .reg .f32 %r412; .reg .f32 %r413; .reg .pred %r415; .reg .f32 %r418; .reg .pred %r420; mov.f32 %r213,%ar0; mov.f32 %r214,%ar1; .loc 1 72 0 mov.b32 %r138,%r214; .loc 1 73 0 and.b32 %r134,%r138,2147483647; .loc 1 76 0 setp.eq.u32 %r215,%r134,0; @ %r215 bra $L35; .loc 1 71 0 mov.b32 %r135,%r213; .loc 1 73 0 and.b32 %r130,%r135,2147483647; .loc 1 79 0 set.u32.gt.s32 %r217,%r130,2139095040; neg.s32 %r218,%r217; .loc 1 80 0 set.u32.gt.s32 %r220,%r134,2139095040; neg.s32 %r221,%r220; .loc 1 79 0 cvt.u16.u32 %r223,%r218; cvt.u16.u32 %r224,%r221; or.b16 %r222,%r223,%r224; cvt.u32.u16 %r225,%r222; cvt.u16.u8 %r226,%r225; setp.eq.u16 %r227,%r226,0; @ %r227 bra $L3; .loc 1 81 0 setp.eq.u32 %r228,%r130,1065353216; @ %r228 bra $L36; .loc 1 82 0 cvta.const.u64 %r229,$LC0; { .param .f32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r229; call (%value_in),nanf,(%out_arg1); ld.param.f32 %r230,[%value_in]; } mov.f32 %r212,%r230; bra $L1; $L3: .loc 1 91 0 setp.ge.s32 %r420,%r135,0; @ %r420 bra $L37; .loc 1 92 0 setp.gt.s32 %r232,%r134,1266679807; @ %r232 bra $L38; .loc 1 93 0 setp.le.s32 %r233,%r134,1065353215; @ %r233 bra $L39; .loc 1 94 0 shr.s32 %r234,%r134,23; .loc 1 95 0 mov.u32 %r236,150; sub.u32 %r26,%r236,%r234; shr.s32 %r137,%r134,%r26; .loc 1 96 0 shl.b32 %r237,%r137,%r26; setp.ne.u32 %r238,%r237,%r134; @ %r238 bra $L40; and.b32 %r239,%r137,1; mov.u32 %r240,2; sub.u32 %r126,%r240,%r239; bra $L5; $L37: .loc 1 90 0 mov.u32 %r126,0; bra $L4; $L38: .loc 1 92 0 mov.u32 %r126,2; $L4: .loc 1 101 0 setp.ne.u32 %r241,%r134,2139095040; @ %r241 bra $L5; .loc 1 102 0 setp.eq.u32 %r242,%r130,1065353216; @ %r242 bra $L41; .loc 1 104 0 setp.le.s32 %r243,%r130,1065353216; @ %r243 bra $L6; .loc 1 105 0 setp.ge.s32 %r244,%r138,0; @ %r244 bra $L42; $L7: mov.f32 %r212,0f00000000; bra $L1; $L6: .loc 1 107 0 setp.ge.s32 %r245,%r138,0; @ %r245 bra $L7; neg.f32 %r212,%r214; bra $L1; $L39: .loc 1 90 0 mov.u32 %r126,0; bra $L5; $L40: mov.u32 %r126,0; $L5: .loc 1 109 0 setp.ne.u32 %r246,%r134,1065353216; @ %r246 bra $L8; .loc 1 110 0 setp.ge.s32 %r247,%r138,0; @ %r247 bra $L43; mov.f32 %r248,0f3f800000; div.rn.f32 %r212,%r248,%r213; bra $L1; $L8: .loc 1 112 0 setp.ne.u32 %r249,%r138,1073741824; @ %r249 bra $L9; mul.f32 %r212,%r213,%r213; bra $L1; $L9: .loc 1 114 0 not.b32 %r251,%r135; shr.u32 %r252,%r251,31; .loc 1 113 0 set.u32.eq.u32 %r254,%r138,1056964608; neg.s32 %r255,%r254; .loc 1 114 0 cvt.u16.u32 %r258,%r252; cvt.u16.u32 %r259,%r255; and.b16 %r257,%r258,%r259; cvt.u32.u16 %r260,%r257; cvt.u16.u8 %r261,%r260; setp.eq.u16 %r262,%r261,0; @ %r262 bra $L10; .loc 1 115 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r213; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r264,[%value_in]; } mov.f32 %r212,%r264; bra $L1; $L10: .loc 1 118 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r213; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r266,[%value_in]; } mov.f32 %r212,%r266; .loc 1 120 0 and.b32 %r267,%r135,1073741823; set.u32.eq.u32 %r269,%r267,1065353216; neg.s32 %r270,%r269; set.u32.eq.u32 %r272,%r130,0; neg.s32 %r273,%r272; cvt.u16.u32 %r275,%r270; cvt.u16.u32 %r276,%r273; or.b16 %r274,%r275,%r276; cvt.u32.u16 %r277,%r274; cvt.u16.u8 %r278,%r277; setp.eq.u16 %r279,%r278,0; @ %r279 bra $L11; .loc 1 122 0 setp.ge.s32 %r280,%r138,0; @ %r280 bra $L12; mov.f32 %r281,0f3f800000; div.rn.f32 %r212,%r281,%r212; $L12: .loc 1 123 0 @ %r420 bra $L1; .loc 1 124 0 add.u32 %r283,%r130,-1065353216; or.b32 %r284,%r283,%r126; setp.ne.u32 %r285,%r284,0; @ %r285 bra $L13; .loc 1 125 0 sub.f32 %r32,%r212,%r212; div.rn.f32 %r212,%r32,%r32; bra $L1; $L13: .loc 1 126 0 setp.ne.u32 %r286,%r126,1; @ %r286 bra $L1; .loc 1 127 0 neg.f32 %r212,%r212; bra $L1; $L11: .loc 1 133 0 set.u32.ge.s32 %r35,%r135,0; or.b32 %r288,%r126,%r35; setp.ne.u32 %r289,%r288,0; @ %r289 bra $L14; sub.f32 %r38,%r213,%r213; div.rn.f32 %r212,%r38,%r38; bra $L1; $L14: .loc 1 136 0 setp.le.s32 %r290,%r134,1291845632; @ %r290 bra $L15; .loc 1 138 0 setp.gt.s32 %r291,%r130,1065353207; @ %r291 bra $L16; setp.ge.s32 %r292,%r138,0; @ %r292 bra $L7; $L18: mov.f32 %r293,0f7149f2ca; mul.f32 %r212,%r293,0f7149f2ca; bra $L1; $L16: .loc 1 139 0 setp.le.s32 %r294,%r130,1065353223; @ %r294 bra $L17; setp.gt.s32 %r295,%r138,0; @ %r295 bra $L18; bra $L7; $L17: .loc 1 142 0 mov.f32 %r296,0f3f800000; sub.f32 %r166,%r266,%r296; .loc 1 143 0 neg.f32 %r297,%r166; fma.rn.f32 %r298,%r297,0f3e800000,0f3eaaaaab; neg.f32 %r299,%r298; fma.rn.f32 %r300,%r299,%r166,0f3f000000; mul.f32 %r301,%r166,%r166; mul.f32 %r302,%r300,%r301; .loc 1 145 0 mul.f32 %r304,%r302,0fbfb8aa3b; fma.rn.f32 %r168,%r166,0f36eca570,%r304; .loc 1 146 0 fma.rn.f32 %r305,%r166,0f3fb8aa00,%r168; .loc 1 148 0 mov.b32 %r306,%r305; and.b32 %r43,%r306,-4096; mov.b32 %r123,%r43; .loc 1 149 0 fma.rn.f32 %r308,%r297,0f3fb8aa00,%r123; sub.f32 %r124,%r168,%r308; bra $L19; $L15: .loc 1 154 0 setp.gt.s32 %r309,%r130,8388607; @ %r309 bra $L44; .loc 1 155 0 mul.f32 %r310,%r266,0f4b800000; mov.b32 %r130,%r310; mov.u32 %r127,-24; bra $L20; $L44: .loc 1 152 0 mov.u32 %r127,0; $L20: .loc 1 156 0 shr.s32 %r311,%r130,23; add.u32 %r312,%r311,-127; add.u32 %r128,%r312,%r127; .loc 1 157 0 and.b32 %r142,%r130,8388607; .loc 1 159 0 or.b32 %r131,%r142,1065353216; .loc 1 160 0 setp.le.s32 %r313,%r142,1885297; @ %r313 bra $L45; .loc 1 161 0 setp.le.s32 %r314,%r142,6140886; @ %r314 bra $L46; .loc 1 162 0 add.u32 %r128,%r128,1; add.u32 %r131,%r131,-8388608; mov.f32 %r211,0f00000000; mov.f32 %r210,%r211; mov.u32 %r209,0; mov.f32 %r208,0f3f800000; bra $L21; $L45: mov.f32 %r211,0f00000000; mov.f32 %r210,%r211; mov.u32 %r209,0; mov.f32 %r208,0f3f800000; bra $L21; $L46: mov.f32 %r211,0f3f15c000; mov.f32 %r210,0f35d1cfdc; mov.u32 %r209,2097152; mov.f32 %r208,0f3fc00000; $L21: .loc 1 163 0 mov.b32 %r146,%r131; .loc 1 166 0 sub.f32 %r147,%r146,%r208; .loc 1 167 0 add.f32 %r315,%r146,%r208; mov.f32 %r316,0f3f800000; div.rn.f32 %r148,%r316,%r315; .loc 1 168 0 mul.f32 %r149,%r147,%r148; .loc 1 171 0 mov.b32 %r318,%r149; and.b32 %r317,%r318,-4096; mov.b32 %r150,%r317; .loc 1 173 0 shr.s32 %r319,%r131,1; or.b32 %r320,%r319,536870912; add.u32 %r321,%r320,262144; add.u32 %r322,%r321,%r209; mov.b32 %r151,%r322; .loc 1 175 0 neg.f32 %r323,%r150; fma.rn.f32 %r325,%r323,%r151,%r147; .loc 1 174 0 sub.f32 %r326,%r151,%r208; sub.f32 %r327,%r146,%r326; .loc 1 175 0 fma.rn.f32 %r328,%r323,%r327,%r325; mul.f32 %r153,%r328,%r148; .loc 1 177 0 mul.f32 %r154,%r149,%r149; .loc 1 178 0 mul.f32 %r329,%r154,%r154; .loc 1 179 0 add.f32 %r330,%r149,%r150; mul.f32 %r331,%r330,%r153; .loc 1 178 0 fma.rn.f32 %r332,%r154,0f3e53f142,0f3e6c3255; fma.rn.f32 %r333,%r332,%r154,0f3e8ba305; fma.rn.f32 %r334,%r333,%r154,0f3eaaaaab; fma.rn.f32 %r335,%r334,%r154,0f3edb6db7; fma.rn.f32 %r336,%r335,%r154,0f3f19999a; .loc 1 179 0 fma.rn.f32 %r155,%r329,%r336,%r331; .loc 1 181 0 fma.rn.f32 %r337,%r150,%r150,0f40400000; add.f32 %r338,%r337,%r155; .loc 1 183 0 mov.b32 %r339,%r338; and.b32 %r67,%r339,-4096; mov.b32 %r157,%r67; .loc 1 184 0 mov.f32 %r342,0f40400000; sub.f32 %r341,%r157,%r342; fma.rn.f32 %r343,%r323,%r150,%r341; sub.f32 %r344,%r155,%r343; .loc 1 187 0 mul.f32 %r345,%r344,%r149; fma.rn.f32 %r159,%r153,%r157,%r345; .loc 1 189 0 fma.rn.f32 %r346,%r150,%r157,%r159; .loc 1 191 0 mov.b32 %r347,%r346; and.b32 %r72,%r347,-4096; mov.b32 %r161,%r72; .loc 1 192 0 fma.rn.f32 %r349,%r323,%r157,%r161; sub.f32 %r350,%r159,%r349; .loc 1 194 0 mul.f32 %r351,%r350,0f3f76384f; fma.rn.f32 %r352,%r161,0f369dc3a0,%r351; add.f32 %r163,%r352,%r210; .loc 1 196 0 cvt.rn.f32.s32 %r164,%r128; .loc 1 197 0 fma.rn.f32 %r353,%r161,0f3f763800,%r163; add.f32 %r354,%r353,%r211; add.f32 %r355,%r354,%r164; .loc 1 199 0 mov.b32 %r356,%r355; and.b32 %r78,%r356,-4096; mov.b32 %r123,%r78; .loc 1 200 0 sub.f32 %r358,%r123,%r164; sub.f32 %r359,%r358,%r211; fma.rn.f32 %r360,%r161,0fbf763800,%r359; sub.f32 %r124,%r163,%r360; $L19: .loc 1 204 0 add.u32 %r361,%r126,-1; or.b32 %r362,%r361,%r35; setp.eq.u32 %r363,%r362,0; .loc 1 203 0 selp.f32 %r125,0fbf800000,0f3f800000,%r363; .loc 1 209 0 and.b32 %r364,%r138,-4096; mov.b32 %r170,%r364; .loc 1 210 0 sub.f32 %r365,%r214,%r170; mul.f32 %r366,%r124,%r214; fma.rn.f32 %r171,%r365,%r123,%r366; .loc 1 211 0 mul.f32 %r122,%r123,%r170; .loc 1 212 0 add.f32 %r172,%r171,%r122; .loc 1 213 0 mov.b32 %r49,%r172; .loc 1 214 0 and.b32 %r174,%r49,2147483647; .loc 1 215 0 setp.le.s32 %r367,%r49,0; @ %r367 bra $L23; .loc 1 216 0 setp.le.s32 %r368,%r174,1124073472; @ %r368 bra $L24; .loc 1 217 0 mul.f32 %r369,%r125,0f7149f2ca; mul.f32 %r212,%r369,0f7149f2ca; bra $L1; $L24: .loc 1 218 0 setp.ne.u32 %r370,%r174,1124073472; @ %r370 bra $L25; .loc 1 219 0 add.f32 %r371,%r171,0f3338aa3c; sub.f32 %r372,%r172,%r122; setp.gt.f32 %r373,%r371,%r372; @ ! %r373 bra $L26; mul.f32 %r374,%r125,0f7149f2ca; mul.f32 %r212,%r374,0f7149f2ca; bra $L1; $L23: .loc 1 221 0 setp.le.s32 %r375,%r174,1125515264; @ %r375 bra $L28; .loc 1 222 0 mul.f32 %r376,%r125,0f0da24260; mul.f32 %r212,%r376,0f0da24260; bra $L1; $L28: .loc 1 223 0 setp.ne.u32 %r377,%r174,1125515264; @ %r377 bra $L25; .loc 1 224 0 sub.f32 %r378,%r172,%r122; setp.ge.f32 %r379,%r378,%r171; @ ! %r379 bra $L26; mul.f32 %r380,%r125,0f0da24260; mul.f32 %r212,%r380,0f0da24260; bra $L1; $L25: .loc 1 231 0 setp.le.s32 %r381,%r174,1056964608; @ %r381 bra $L48; .loc 1 229 0 shr.s32 %r189,%r174,23; $L34: .loc 1 232 0 add.u32 %r382,%r189,-126; mov.u32 %r384,8388608; shr.s32 %r383,%r384,%r382; add.u32 %r175,%r383,%r49; .loc 1 233 0 shr.s32 %r385,%r175,23; and.b32 %r386,%r385,255; add.u32 %r176,%r386,-127; .loc 1 234 0 mov.u32 %r388,8388607; shr.s32 %r387,%r388,%r176; not.b32 %r389,%r387; and.b32 %r390,%r389,%r175; mov.b32 %r177,%r390; .loc 1 235 0 and.b32 %r391,%r175,8388607; or.b32 %r103,%r391,8388608; mov.u32 %r393,23; sub.u32 %r392,%r393,%r176; shr.s32 %r129,%r103,%r392; .loc 1 236 0 setp.ge.s32 %r394,%r49,0; @ %r394 bra $L31; neg.s32 %r129,%r129; $L31: .loc 1 237 0 sub.f32 %r122,%r122,%r177; add.f32 %r395,%r171,%r122; mov.b32 %r49,%r395; shl.b32 %r207,%r129,23; bra $L30; $L48: mov.u32 %r207,0; .loc 1 230 0 mov.u32 %r129,%r207; $L30: .loc 1 241 0 and.b32 %r396,%r49,-4096; mov.b32 %r178,%r396; .loc 1 243 0 sub.f32 %r397,%r178,%r122; sub.f32 %r398,%r171,%r397; mul.f32 %r399,%r178,0f35bfbe8c; fma.rn.f32 %r179,%r398,0f3f317218,%r399; .loc 1 244 0 fma.rn.f32 %r180,%r178,0f3f317200,%r179; .loc 1 245 0 fma.rn.f32 %r401,%r178,0fbf317200,%r180; sub.f32 %r181,%r179,%r401; .loc 1 246 0 mul.f32 %r182,%r180,%r180; .loc 1 247 0 fma.rn.f32 %r402,%r182,0f3331bb4c,0fb5ddea0e; fma.rn.f32 %r403,%r402,%r182,0f388ab355; fma.rn.f32 %r404,%r403,%r182,0fbb360b61; fma.rn.f32 %r405,%r404,%r182,0f3e2aaaab; neg.f32 %r406,%r405; fma.rn.f32 %r183,%r406,%r182,%r180; .loc 1 248 0 mul.f32 %r407,%r180,%r183; mov.f32 %r409,0f40000000; sub.f32 %r408,%r183,%r409; div.rn.f32 %r410,%r407,%r408; fma.rn.f32 %r411,%r180,%r181,%r181; sub.f32 %r412,%r410,%r411; .loc 1 249 0 sub.f32 %r118,%r412,%r180; mov.f32 %r413,0f3f800000; sub.f32 %r185,%r413,%r118; .loc 1 250 0 mov.b32 %r186,%r185; .loc 1 251 0 add.u32 %r187,%r186,%r207; .loc 1 252 0 setp.gt.s32 %r415,%r187,8388607; @ %r415 bra $L32; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r185; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r129; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r418,[%value_in]; } mov.f32 %r121,%r418; bra $L33; $L32: .loc 1 253 0 mov.b32 %r121,%r187; $L33: .loc 1 254 0 mul.f32 %r212,%r121,%r125; bra $L1; $L35: .loc 1 76 0 mov.f32 %r212,0f3f800000; bra $L1; $L36: mov.f32 %r212,0f3f800000; bra $L1; $L41: mov.f32 %r212,0f3f800000; bra $L1; $L42: .loc 1 105 0 mov.f32 %r212,%r214; bra $L1; $L43: .loc 1 110 0 mov.f32 %r212,%r213; bra $L1; $L26: .loc 1 229 0 shr.s32 %r189,%r174,23; bra $L34; $L1: .loc 1 255 0 mov.f32 %value,%r212; st.param.f32 [%value_out],%value; ret; } /193 0 0 0 644 9286 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .visible .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2f .extern .func (.param .u32 %value_out) __kernel_rem_pio2f (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); // BEGIN VAR DEF: npio2_hw .const .align 4 .u32 npio2_hw[32] = {1070141184,1078529792,1083624192,1086918400,1090212608,1092012800,1093659904,1095307008,1096954112,1098601216,1099577856,1100401408,1101224960,1102048512,1102872064,1103695616,1104519168,1105342720,1106166272,1106989824,1107554816,1107966464,1108378368,1108790016,1109201920,1109613568,1110025472,1110437120,1110849024,1111260672,1111672576,1112084224 }; // BEGIN VAR DEF: two_over_pi .const .align 4 .u32 two_over_pi[198] = {162,249,131,110,78,68,21,41,252,39,87,209,245,52,221,192,219,98,149,153,60,67,144,65,254,81,99,171,222,187,197,97,183,36,110,58,66,77,210,224,6,73,46,234,9,209,146,28,254,29,235,28,177,41,167,62,232,130,53,245,46,187,68,132,233,156,112,38,180,95,126,65,57,145,214,57,131,83,57,244,156,132,95,139,189,249,40,59,31,248,151,255,222,5,152,15,239,47,17,139,90,10,109,31,109,54,126,207,39,203,9,183,79,70,63,102,158,95,234,45,117,39,186,199,235,229,241,123,61,7,57,247,138,82,146,234,107,251,95,177,31,141,93,8,86,3,48,70,252,123,107,171,240,207,188,32,154,244,54,29,169,227,145,97,94,230,27,8,101,153,133,95,20,160,104,64,141,255,216,128,77,115,39,49,6,6,21,86,202,115,168,201,96,226,123,192,140,107 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_rem_pio2f .visible .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .f32 %r24; .reg .f32 %r28; .reg .f32 %r32; .reg .f32 %r35; .reg .u32 %r45; .reg .f32 %r58; .reg .f32 %r61; .reg .f32 %r65; .reg .f32 %r70; .reg .f32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .f32 %r75; .reg .f32 %r78; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r86; .reg .u32 %r89; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .u32 %r101; .reg .f32 %r102; .reg .u64 %r103; .reg .pred %r104; .reg .f32 %r105; .reg .pred %r106; .reg .pred %r107; .reg .f32 %r108; .reg .pred %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r114; .reg .f32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .pred %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .pred %r124; .reg .f32 %r126; .reg .f32 %r127; .reg .pred %r129; .reg .u32 %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u32 %r136; .reg .pred %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r141; .reg .pred %r142; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .u32 %r148; .reg .u32 %r149; .reg .u32 %r150; .reg .u32 %r151; .reg .pred %r152; .reg .f32 %r155; .reg .f32 %r156; .reg .f32 %r157; .reg .f32 %r158; .reg .pred %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .pred %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .u32 %r165; .reg .u32 %r166; .reg .u32 %r167; .reg .pred %r168; .reg .pred %r169; .reg .u32 %r174; .reg .u64 %r175; .reg .u32 %r176; .reg .pred %r177; .reg .f32 %r178; .reg .f32 %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r183; mov.f32 %r102,%ar0; mov.u64 %r103,%ar1; .loc 1 110 0 mov.b32 %r72,%r102; .loc 1 111 0 and.b32 %r73,%r72,2147483647; .loc 1 112 0 setp.gt.s32 %r104,%r73,1061752792; @ %r104 bra $L2; .loc 1 113 0 st.f32 [%r103],%r102; mov.f32 %r105,0f00000000; st.f32 [%r103+4],%r105; mov.u32 %r101,0; bra $L1; $L2: .loc 1 114 0 setp.gt.s32 %r106,%r73,1075235811; @ %r106 bra $L4; and.b32 %r89,%r72,2147483632; .loc 1 115 0 setp.le.s32 %r107,%r72,0; @ %r107 bra $L5; .loc 1 116 0 mov.f32 %r108,0f3fc90f80; sub.f32 %r85,%r102,%r108; .loc 1 117 0 setp.eq.u32 %r109,%r89,1070141392; @ %r109 bra $L6; .loc 1 118 0 mov.f32 %r110,0f37354443; sub.f32 %r24,%r85,%r110; st.f32 [%r103],%r24; .loc 1 119 0 sub.f32 %r111,%r85,%r24; sub.f32 %r112,%r111,%r110; st.f32 [%r103+4],%r112; .loc 1 125 0 mov.u32 %r101,1; bra $L1; $L6: .loc 1 121 0 mov.f32 %r114,0f37354400; sub.f32 %r86,%r85,%r114; .loc 1 122 0 mov.f32 %r115,0f2e85a308; sub.f32 %r28,%r86,%r115; st.f32 [%r103],%r28; .loc 1 123 0 sub.f32 %r116,%r86,%r28; sub.f32 %r117,%r116,%r115; st.f32 [%r103+4],%r117; .loc 1 125 0 mov.u32 %r101,1; bra $L1; $L5: .loc 1 127 0 add.f32 %r83,%r102,0f3fc90f80; .loc 1 128 0 setp.eq.u32 %r119,%r89,1070141392; @ %r119 bra $L7; .loc 1 129 0 add.f32 %r32,%r83,0f37354443; st.f32 [%r103],%r32; .loc 1 130 0 sub.f32 %r120,%r83,%r32; add.f32 %r121,%r120,0f37354443; st.f32 [%r103+4],%r121; .loc 1 136 0 mov.u32 %r101,-1; bra $L1; $L7: .loc 1 132 0 add.f32 %r84,%r83,0f37354400; .loc 1 133 0 add.f32 %r35,%r84,0f2e85a308; st.f32 [%r103],%r35; .loc 1 134 0 sub.f32 %r122,%r84,%r35; add.f32 %r123,%r122,0f2e85a308; st.f32 [%r103+4],%r123; .loc 1 136 0 mov.u32 %r101,-1; bra $L1; $L4: .loc 1 139 0 setp.gt.s32 %r124,%r73,1128861568; @ %r124 bra $L8; .loc 1 140 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r102; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r126,[%value_in]; } .loc 1 141 0 fma.rn.f32 %r127,%r126,0f3f22f984,0f3f000000; cvt.rzi.s32.f32 %r101,%r127; .loc 1 142 0 cvt.rn.f32.s32 %r78,%r101; .loc 1 143 0 neg.f32 %r183,%r78; fma.rn.f32 %r71,%r183,0f3fc90f80,%r126; .loc 1 144 0 mul.f32 %r70,%r78,0f37354443; .loc 1 145 0 setp.gt.s32 %r129,%r101,31; @ %r129 bra $L9; sub.f32 %r65,%r71,%r70; and.b32 %r130,%r72,2147483392; cvta.const.u64 %r131,npio2_hw; add.u32 %r132,%r101,-1; cvt.s64.s32 %r133,%r132; shl.b64 %r134,%r133,2; add.u64 %r135,%r131,%r134; ld.u32 %r136,[%r135]; setp.eq.u32 %r137,%r130,%r136; @ %r137 bra $L10; .loc 1 146 0 st.f32 [%r103],%r65; bra $L11; $L9: sub.f32 %r65,%r71,%r70; $L10: .loc 1 149 0 shr.s32 %r45,%r73,23; .loc 1 152 0 mov.b32 %r139,%r65; shr.u32 %r138,%r139,23; and.b32 %r140,%r138,255; sub.u32 %r141,%r45,%r140; .loc 1 153 0 setp.gt.s32 %r142,%r141,8; @ %r142 bra $L12; .loc 1 150 0 st.f32 [%r103],%r65; bra $L11; $L12: .loc 1 156 0 fma.rn.f32 %r81,%r183,0f37354400,%r71; .loc 1 157 0 sub.f32 %r145,%r71,%r81; fma.rn.f32 %r146,%r183,0f37354400,%r145; neg.f32 %r147,%r146; fma.rn.f32 %r70,%r78,0f2e85a308,%r147; .loc 1 158 0 sub.f32 %r65,%r81,%r70; .loc 1 160 0 mov.b32 %r149,%r65; shr.u32 %r148,%r149,23; and.b32 %r150,%r148,255; sub.u32 %r151,%r45,%r150; .loc 1 161 0 setp.gt.s32 %r152,%r151,25; @ %r152 bra $L13; .loc 1 158 0 st.f32 [%r103],%r65; .loc 1 156 0 mov.f32 %r71,%r81; bra $L11; $L13: .loc 1 164 0 fma.rn.f32 %r71,%r183,0f2e85a300,%r81; .loc 1 165 0 sub.f32 %r155,%r81,%r71; fma.rn.f32 %r156,%r183,0f2e85a300,%r155; neg.f32 %r157,%r156; fma.rn.f32 %r70,%r78,0f248d3132,%r157; .loc 1 166 0 sub.f32 %r65,%r71,%r70; st.f32 [%r103],%r65; $L11: .loc 1 170 0 sub.f32 %r158,%r71,%r65; sub.f32 %r58,%r158,%r70; st.f32 [%r103+4],%r58; .loc 1 171 0 setp.ge.s32 %r159,%r72,0; @ %r159 bra $L1; neg.f32 %r160,%r65; st.f32 [%r103],%r160; neg.f32 %r161,%r58; st.f32 [%r103+4],%r161; neg.s32 %r101,%r101; bra $L1; $L8: .loc 1 177 0 setp.le.s32 %r162,%r73,2139095039; @ %r162 bra $L14; .loc 1 178 0 sub.f32 %r61,%r102,%r102; st.f32 [%r103+4],%r61; st.f32 [%r103],%r61; mov.u32 %r101,0; bra $L1; $L14: .loc 1 181 0 shr.s32 %r163,%r73,23; add.u32 %r74,%r163,-134; .loc 1 182 0 shl.b32 %r164,%r74,23; sub.u32 %r165,%r73,%r164; mov.b32 %r75,%r165; .loc 1 184 0 cvt.rzi.s32.f32 %r166,%r75; cvt.rn.f32.s32 %r92,%r166; st.f32 [%frame],%r92; .loc 1 185 0 sub.f32 %r93,%r75,%r92; mul.f32 %r94,%r93,0f43800000; .loc 1 184 0 cvt.rzi.s32.f32 %r167,%r94; cvt.rn.f32.s32 %r97,%r167; st.f32 [%frame+4],%r97; .loc 1 185 0 sub.f32 %r98,%r94,%r97; mul.f32 %r99,%r98,0f43800000; .loc 1 187 0 st.f32 [%frame+8],%r99; .loc 1 189 0 setp.neu.f32 %r168,%r99,0f00000000; @ %r168 bra $L16; setp.eq.f32 %r169,%r97,0f00000000; selp.u32 %r22,1,2,%r169; bra $L15; $L16: .loc 1 188 0 mov.u32 %r22,3; $L15: .loc 1 190 0 cvta.const.u64 %r175,two_over_pi; mov.u32 %r174,2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r103; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r74; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r22; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r174; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r175; call (%value_in),__kernel_rem_pio2f,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u32 %r176,[%value_in]; } mov.u32 %r101,%r176; .loc 1 191 0 setp.ge.s32 %r177,%r72,0; @ %r177 bra $L1; ld.f32 %r179,[%r103]; neg.f32 %r178,%r179; st.f32 [%r103],%r178; ld.f32 %r181,[%r103+4]; neg.f32 %r180,%r181; st.f32 [%r103+4],%r180; neg.s32 %r101,%r101; $L1: .loc 1 193 0 mov.u32 %value,%r101; st.param.u32 [%value_out],%value; ret; } /214 0 0 0 644 3589 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainderf .visible .func (.param .f32 %value_out) __ieee754_remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_remainder.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmodf .extern .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_remainderf .visible .func (.param .f32 %value_out) __ieee754_remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .f32 %r25; .reg .u32 %r30; .reg .f32 %r31; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r38; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r50; .reg .u32 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .u16 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u16 %r59; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .pred %r65; .reg .f32 %r68; .reg .f32 %r69; .reg .pred %r70; .reg .f32 %r72; .reg .f32 %r74; .reg .pred %r75; .reg .f32 %r76; .reg .pred %r77; .reg .f32 %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .u32 %r82; .reg .u32 %r83; mov.f32 %r44,%ar0; mov.f32 %r45,%ar1; .loc 1 36 0 mov.b32 %r22,%r44; .loc 1 37 0 mov.b32 %r33,%r45; .loc 1 39 0 and.b32 %r35,%r33,2147483647; .loc 1 40 0 and.b32 %r36,%r22,2147483647; .loc 1 43 0 set.u32.eq.u32 %r47,%r35,0; neg.s32 %r48,%r47; .loc 1 44 0 set.u32.gt.s32 %r50,%r35,2139095040; neg.s32 %r51,%r50; cvt.u16.u32 %r53,%r48; cvt.u16.u32 %r54,%r51; or.b16 %r52,%r53,%r54; set.u32.gt.s32 %r56,%r36,2139095039; neg.s32 %r57,%r56; cvt.u16.u32 %r61,%r57; or.b16 %r59,%r52,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; .loc 1 46 0 mul.f32 %r25,%r44,%r45; div.rn.f32 %r43,%r25,%r25; bra $L1; $L2: .loc 1 49 0 setp.gt.s32 %r65,%r35,2130706431; @ %r65 bra $L4; add.f32 %r68,%r45,%r45; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r68; call (%value_in),__ieee754_fmodf,(%out_arg1,%out_arg2); ld.param.f32 %r69,[%value_in]; } mov.f32 %r44,%r69; $L4: .loc 1 50 0 setp.ne.u32 %r70,%r35,%r36; @ %r70 bra $L5; mul.f32 %r43,%r44,0f00000000; bra $L1; $L5: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r72,[%value_in]; } mov.f32 %r31,%r72; .loc 1 52 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r74,[%value_in]; } .loc 1 53 0 setp.gt.s32 %r75,%r35,16777215; @ %r75 bra $L6; .loc 1 54 0 add.f32 %r76,%r31,%r31; setp.gt.f32 %r77,%r76,%r74; @ ! %r77 bra $L7; .loc 1 55 0 sub.f32 %r31,%r31,%r74; .loc 1 56 0 add.f32 %r78,%r31,%r31; setp.ge.f32 %r79,%r78,%r74; @ ! %r79 bra $L7; sub.f32 %r31,%r31,%r74; bra $L7; $L6: .loc 1 59 0 mul.f32 %r38,%r74,0f3f000000; .loc 1 60 0 setp.gt.f32 %r80,%r31,%r38; @ ! %r80 bra $L7; .loc 1 61 0 sub.f32 %r31,%r31,%r74; .loc 1 62 0 setp.le.f32 %r81,%r38,%r31; @ ! %r81 bra $L7; sub.f32 %r31,%r31,%r74; $L7: .loc 1 38 0 and.b32 %r82,%r22,-2147483648; .loc 1 66 0 mov.b32 %r83,%r31; xor.b32 %r30,%r82,%r83; mov.b32 %r43,%r30; $L1: .loc 1 68 0 mov.f32 %value,%r43; st.param.f32 [%value_out],%value; ret; } /236 0 0 0 644 3478 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalbf .visible .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/ef_scalb.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rintf .extern .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: __ieee754_scalbf .visible .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r27; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r31; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f32 %r42; .reg .f32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u32 %r48; .reg .f32 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .f32 %r53; .reg .u32 %r56; .reg .f32 %r57; mov.f32 %r30,%ar0; mov.f32 %r31,%ar1; .loc 1 38 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r33,[%value_in]; } setp.ne.u32 %r34,%r33,0; @ ! %r34 bra $L3; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r36,[%value_in]; } setp.eq.u32 %r37,%r36,0; @ ! %r37 bra $L18; $L3: mul.f32 %r29,%r30,%r31; bra $L1; $L18: .loc 1 39 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.ne.u32 %r40,%r39,0; @ %r40 bra $L7; .loc 1 40 0 setp.gt.f32 %r41,%r31,0f00000000; @ %r41 bra $L3; .loc 1 41 0 neg.f32 %r42,%r31; div.rn.f32 %r29,%r30,%r42; bra $L1; $L7: .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),rintf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.eq.f32 %r45,%r44,%r31; @ %r45 bra $L8; sub.f32 %r27,%r31,%r31; div.rn.f32 %r29,%r27,%r27; bra $L1; $L8: .loc 1 45 0 setp.gt.f32 %r46,%r31,0f477de800; @ ! %r46 bra $L19; mov.u32 %r48,65000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r49,[%value_in]; } mov.f32 %r29,%r49; bra $L1; $L19: .loc 1 46 0 setp.lt.f32 %r50,%r31,0fc77de800; @ ! %r50 bra $L20; mov.u32 %r52,-65000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r52; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r53,[%value_in]; } mov.f32 %r29,%r53; bra $L1; $L20: .loc 1 51 0 cvt.rzi.s32.f32 %r56,%r31; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r56; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r57,[%value_in]; } mov.f32 %r29,%r57; $L1: .loc 1 53 0 mov.f32 %value,%r29; st.param.f32 [%value_out],%value; ret; } lib_a-ef_sinh.o/0 0 0 644 3943 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinhf .visible .func (.param .f32 %value_out) __ieee754_sinhf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_sinh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1f .extern .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_sinhf .visible .func (.param .f32 %value_out) __ieee754_sinhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .f32 %r50; .reg .pred %r51; .reg .f32 %r53; .reg .f32 %r55; .reg .pred %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .pred %r65; .reg .f32 %r67; .reg .f32 %r69; .reg .pred %r70; .reg .f32 %r72; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; .reg .f32 %r79; .reg .f32 %r81; mov.f32 %r45,%ar0; .loc 1 34 0 mov.b32 %r36,%r45; .loc 1 35 0 and.b32 %r37,%r36,2147483647; .loc 1 38 0 setp.le.s32 %r46,%r37,2139095039; @ %r46 bra $L2; add.f32 %r44,%r45,%r45; bra $L1; $L2: .loc 1 41 0 setp.ge.s32 %r47,%r36,0; selp.f32 %r35,0f3f000000,0fbf000000,%r47; .loc 1 43 0 setp.gt.s32 %r48,%r37,1102053375; @ %r48 bra $L5; .loc 1 44 0 setp.gt.s32 %r49,%r37,830472191; @ %r49 bra $L6; .loc 1 45 0 add.f32 %r50,%r45,0f7cf0bdc2; setp.gt.f32 %r51,%r50,0f3f800000; @ %r51 bra $L13; bra $L14; $L6: .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r53,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r53; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r55,[%value_in]; } mov.f32 %r43,%r55; .loc 1 47 0 setp.gt.s32 %r56,%r37,1065353215; @ %r56 bra $L8; $L11: mul.f32 %r57,%r43,%r43; add.f32 %r58,%r43,0f3f800000; div.rn.f32 %r59,%r57,%r58; neg.f32 %r60,%r59; fma.rn.f32 %r61,%r43,0f40000000,%r60; mul.f32 %r44,%r61,%r35; bra $L1; $L8: .loc 1 48 0 add.f32 %r62,%r55,0f3f800000; div.rn.f32 %r63,%r55,%r62; add.f32 %r64,%r63,%r55; mul.f32 %r44,%r64,%r35; bra $L1; $L5: .loc 1 52 0 setp.gt.s32 %r65,%r37,1118925335; @ %r65 bra $L9; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r67,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r69,[%value_in]; } mul.f32 %r44,%r69,%r35; bra $L1; $L9: .loc 1 55 0 setp.gt.s32 %r70,%r37,1119016188; @ %r70 bra $L10; .loc 1 56 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r72,[%value_in]; } mul.f32 %r74,%r72,0f3f000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r74; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r75,[%value_in]; } .loc 1 57 0 mul.f32 %r76,%r35,%r75; .loc 1 58 0 mul.f32 %r44,%r76,%r75; bra $L1; $L10: .loc 1 62 0 mul.f32 %r44,%r45,0f7cf0bdc2; bra $L1; $L13: .loc 1 45 0 mov.f32 %r44,%r45; bra $L1; $L14: .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r79,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r79; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r81,[%value_in]; } mov.f32 %r43,%r81; bra $L11; $L1: .loc 1 63 0 mov.f32 %value,%r44; st.param.f32 [%value_out],%value; ret; } lib_a-ef_sqrt.o/0 0 0 644 2973 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .visible .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/ef_sqrt.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_sqrtf .visible .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .f32 %r28; .reg .u32 %r29; .reg .u32 %r32; .reg .u32 %r36; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .pred %r60; .reg .pred %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u32 %r68; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r73; .reg .pred %r75; .reg .pred %r76; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; mov.f32 %r59,%ar0; .loc 1 35 0 mov.b32 %r27,%r59; .loc 1 36 0 and.b32 %r44,%r27,2147483647; .loc 1 39 0 setp.le.u32 %r60,%r44,2139095039; @ %r60 bra $L2; .loc 1 40 0 fma.rn.f32 %r58,%r59,%r59,%r59; bra $L1; $L2: .loc 1 43 0 setp.eq.u32 %r61,%r44,0; @ %r61 bra $L12; .loc 1 35 0 mov.u32 %r45,%r27; .loc 1 44 0 setp.ge.s32 %r62,%r27,0; @ %r62 bra $L4; sub.f32 %r28,%r59,%r59; div.rn.f32 %r58,%r28,%r28; bra $L1; $L4: .loc 1 47 0 shr.s32 %r43,%r45,23; .loc 1 48 0 setp.gt.u32 %r63,%r44,8388607; @ %r63 bra $L5; and.b32 %r56,%r45,8388608; .loc 1 49 0 setp.ne.u32 %r64,%r56,0; @ ! %r64 bra $L7; bra $L13; $L14: mov.u32 %r56,%r46; $L7: add.u32 %r45,%r45,%r45; add.u32 %r46,%r56,1; and.b32 %r66,%r45,8388608; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L14; bra $L6; $L13: mov.u32 %r56,-1; $L6: .loc 1 50 0 sub.u32 %r43,%r43,%r56; $L5: .loc 1 52 0 add.u32 %r47,%r43,-127; .loc 1 53 0 and.b32 %r29,%r45,8388607; or.b32 %r68,%r29,8388608; add.u32 %r54,%r68,%r68; .loc 1 54 0 and.b32 %r70,%r47,1; setp.eq.u32 %r71,%r70,0; @ %r71 bra $L8; add.u32 %r54,%r54,%r54; $L8: .loc 1 56 0 shr.s32 %r49,%r47,1; mov.u32 %r57,25; .loc 1 60 0 mov.u32 %r42,0; mov.u32 %r41,%r42; .loc 1 61 0 mov.u32 %r55,16777216; $L10: .loc 1 64 0 add.u32 %r32,%r41,%r55; .loc 1 65 0 setp.gt.s32 %r73,%r32,%r54; @ %r73 bra $L9; .loc 1 66 0 add.u32 %r41,%r32,%r55; .loc 1 67 0 sub.u32 %r54,%r54,%r32; .loc 1 68 0 add.u32 %r42,%r42,%r55; $L9: .loc 1 70 0 add.u32 %r54,%r54,%r54; .loc 1 71 0 shr.u32 %r55,%r55,1; add.u32 %r57,%r57,-1; .loc 1 63 0 setp.ne.u32 %r75,%r57,0; @ %r75 bra $L10; .loc 1 75 0 setp.eq.u32 %r76,%r54,0; @ %r76 bra $L11; .loc 1 82 0 add.u32 %r36,%r42,1; and.b32 %r42,%r36,-2; $L11: .loc 1 85 0 shr.s32 %r77,%r42,1; add.u32 %r51,%r77,1056964608; .loc 1 86 0 shl.b32 %r78,%r49,23; add.u32 %r79,%r78,%r51; .loc 1 87 0 mov.b32 %r58,%r79; .loc 1 88 0 bra $L1; $L12: .loc 1 43 0 mov.f32 %r58,%r59; $L1: .loc 1 89 0 mov.f32 %value,%r58; st.param.f32 [%value_out],%value; ret; } /254 0 0 0 644 1383 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .visible .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/er_gamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .extern .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_gamma_r .visible .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .u64 %r25; .reg .f64 %r28; .reg .f64 %r30; mov.f64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 31 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),__ieee754_lgamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r30,[%value_in]; } .loc 1 32 0 mov.f64 %value,%r30; st.param.f64 [%value_out],%value; ret; } /272 0 0 0 644 18251 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .visible .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/er_lgamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .extern .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .extern .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_lgamma_r .visible .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r77; .reg .f64 %r91; .reg .f64 %r92; .reg .f64 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .f64 %r98; .reg .f64 %r99; .reg .u32 %r101; .reg .f64 %r102; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r120; .reg .f64 %r124; .reg .f64 %r126; .reg .f64 %r128; .reg .f64 %r131; .reg .u32 %r133; .reg .u32 %r134; .reg .f64 %r135; .reg .u32 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r140; .reg .f64 %r142; .reg .f64 %r147; .reg .f64 %r148; .reg .f64 %r170; .reg .f64 %r171; .reg .u64 %r172; .reg .u64 %r173; .reg .u64 %r174; .reg .u32 %r175; .reg .pred %r176; .reg .u32 %r178; .reg .pred %r179; .reg .f64 %r180; .reg .pred %r181; .reg .pred %r182; .reg .u32 %r183; .reg .f64 %r185; .reg .f64 %r186; .reg .f64 %r188; .reg .pred %r190; .reg .pred %r191; .reg .f64 %r193; .reg .u32 %r194; .reg .f64 %r195; .reg .f64 %r196; .reg .f64 %r198; .reg .pred %r199; .reg .f64 %r201; .reg .f64 %r202; .reg .f64 %r203; .reg .f64 %r204; .reg .u64 %r205; .reg .pred %r206; .reg .pred %r207; .reg .pred %r208; .reg .pred %r209; .reg .pred %r210; .reg .f64 %r212; .reg .f64 %r214; .reg .f64 %r215; .reg .f64 %r216; .reg .f64 %r218; .reg .f64 %r219; .reg .f64 %r220; .reg .f64 %r221; .reg .f64 %r223; .reg .u32 %r224; .reg .f64 %r225; .reg .f64 %r227; .reg .f64 %r228; .reg .f64 %r229; .reg .f64 %r230; .reg .f64 %r231; .reg .f64 %r232; .reg .f64 %r233; .reg .f64 %r235; .reg .u32 %r236; .reg .f64 %r237; .reg .pred %r238; .reg .f64 %r240; .reg .f64 %r241; .reg .f64 %r243; .reg .f64 %r244; .reg .f64 %r245; .reg .pred %r246; .reg .u32 %r247; .reg .u32 %r248; .reg .u32 %r249; .reg .pred %r250; .reg .pred %r251; .reg .pred %r252; .reg .f64 %r254; .reg .pred %r255; .reg .f64 %r256; .reg .pred %r257; .reg .f64 %r258; .reg .pred %r259; .reg .f64 %r260; .reg .pred %r261; .reg .f64 %r262; .reg .f64 %r263; .reg .f64 %r265; .reg .f64 %r266; .reg .f64 %r267; .reg .f64 %r268; .reg .f64 %r269; .reg .f64 %r270; .reg .f64 %r271; .reg .f64 %r272; .reg .f64 %r273; .reg .f64 %r274; .reg .f64 %r275; .reg .f64 %r276; .reg .f64 %r277; .reg .f64 %r278; .reg .f64 %r279; .reg .f64 %r280; .reg .f64 %r281; .reg .f64 %r282; .reg .f64 %r283; .reg .f64 %r284; .reg .f64 %r285; .reg .f64 %r286; .reg .f64 %r287; .reg .f64 %r288; .reg .f64 %r289; .reg .f64 %r290; .reg .f64 %r291; .reg .f64 %r292; .reg .f64 %r293; .reg .f64 %r294; .reg .f64 %r295; .reg .f64 %r296; .reg .f64 %r297; .reg .f64 %r298; .reg .f64 %r299; .reg .f64 %r300; .reg .f64 %r301; .reg .f64 %r302; .reg .f64 %r303; .reg .f64 %r304; .reg .f64 %r305; .reg .f64 %r306; .reg .f64 %r307; .reg .f64 %r308; .reg .f64 %r309; .reg .pred %r310; .reg .f64 %r311; .reg .f64 %r312; .reg .f64 %r313; .reg .f64 %r314; .reg .f64 %r315; .reg .f64 %r316; .reg .f64 %r317; .reg .f64 %r318; .reg .f64 %r319; .reg .f64 %r320; .reg .f64 %r321; .reg .f64 %r322; .reg .f64 %r323; .reg .f64 %r324; .reg .f64 %r325; .reg .pred %r326; .reg .pred %r327; .reg .pred %r328; .reg .pred %r329; .reg .pred %r330; .reg .pred %r331; .reg .f64 %r332; .reg .f64 %r333; .reg .f64 %r334; .reg .f64 %r336; .reg .f64 %r337; .reg .f64 %r338; .reg .pred %r339; .reg .f64 %r341; .reg .f64 %r342; .reg .f64 %r343; .reg .f64 %r344; .reg .f64 %r345; .reg .f64 %r346; .reg .f64 %r347; .reg .f64 %r348; .reg .f64 %r349; .reg .f64 %r350; .reg .f64 %r351; .reg .f64 %r354; .reg .f64 %r355; .reg .f64 %r356; .reg .u32 %r359; .reg .u32 %r360; .reg .pred %r361; .reg .u32 %r362; .reg .u32 %r363; .reg .pred %r364; .reg .u32 %r365; .reg .u32 %r366; .reg .pred %r367; .reg .pred %r368; mov.f64 %r171,%ar0; mov.u64 %r172,%ar1; .loc 1 222 0 mov.b64 %r173,%r171; shr.u64 %r174,%r173,32; cvt.u32.u64 %r94,%r174; .loc 1 225 0 mov.u32 %r175,1; st.u32 [%r172],%r175; .loc 1 226 0 and.b32 %r96,%r94,2147483647; .loc 1 227 0 setp.le.s32 %r176,%r96,2146435071; @ %r176 bra $L2; mul.f64 %r170,%r171,%r171; bra $L1; $L2: .loc 1 222 0 cvt.u32.u64 %r95,%r173; .loc 1 228 0 or.b32 %r178,%r95,%r96; setp.ne.u32 %r179,%r178,0; @ %r179 bra $L4; $L8: mov.f64 %r180,0d3ff0000000000000; div.rn.f64 %r170,%r180,0d0000000000000000; bra $L1; $L4: .loc 1 229 0 setp.gt.s32 %r181,%r96,999292927; @ %r181 bra $L5; .loc 1 230 0 setp.ge.s32 %r182,%r94,0; @ %r182 bra $L6; .loc 1 231 0 mov.u32 %r183,-1; st.u32 [%r172],%r183; .loc 1 232 0 neg.f64 %r185,%r171; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r185; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r186,[%value_in]; } neg.f64 %r170,%r186; bra $L1; $L6: .loc 1 233 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r188,[%value_in]; } neg.f64 %r170,%r188; bra $L1; $L5: .loc 1 235 0 setp.ge.s32 %r368,%r94,0; @ %r368 bra $L7; .loc 1 236 0 setp.gt.s32 %r190,%r96,1127219199; @ %r190 bra $L8; .loc 1 175 0 setp.gt.s32 %r191,%r96,1070596095; @ %r191 bra $L9; mul.f64 %r195,%r171,0d400921fb54442d18; mov.u32 %r194,0; mov.f64 %r193,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r195; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r193; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r194; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r196,[%value_in]; } mov.f64 %r148,%r196; bra $L10; $L9: .loc 1 176 0 neg.f64 %r124,%r171; .loc 1 182 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r124; call (%value_in),floor,(%out_arg1); ld.param.f64 %r198,[%value_in]; } .loc 1 183 0 setp.eq.f64 %r199,%r124,%r198; @ %r199 bra $L11; .loc 1 184 0 mul.f64 %r126,%r124,0d3fe0000000000000; .loc 1 185 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r126; call (%value_in),floor,(%out_arg1); ld.param.f64 %r201,[%value_in]; } sub.f64 %r128,%r126,%r201; add.f64 %r135,%r128,%r128; .loc 1 186 0 mul.f64 %r202,%r135,0d4010000000000000; cvt.rzi.s32.f64 %r136,%r202; bra $L12; $L11: .loc 1 192 0 mov.f64 %r204,0d4330000000000000; sub.f64 %r203,%r204,%r171; mov.b64 %r205,%r203; cvt.u32.u64 %r133,%r205; .loc 1 193 0 and.b32 %r134,%r133,1; .loc 1 194 0 cvt.rn.f64.s32 %r135,%r134; .loc 1 195 0 shl.b32 %r136,%r134,2; $L12: .loc 1 198 0 setp.gt.s32 %r206,%r136,4; @ %r206 bra $L14; setp.ge.s32 %r207,%r136,3; @ %r207 bra $L15; setp.eq.u32 %r208,%r136,0; @ %r208 bra $L16; setp.lt.s32 %r209,%r136,0; @ ! %r209 bra $L52; bra $L13; $L14: setp.gt.s32 %r210,%r136,6; @ ! %r210 bra $L53; bra $L13; $L16: .loc 1 199 0 mul.f64 %r137,%r135,0d400921fb54442d18; mov.f64 %r212,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r137; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r212; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r136; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r214,[%value_in]; } mov.f64 %r138,%r214; bra $L19; $L52: .loc 1 201 0 mov.f64 %r216,0d3fe0000000000000; sub.f64 %r215,%r216,%r135; mul.f64 %r140,%r215,0d400921fb54442d18; mov.f64 %r218,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r140; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r218; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r219,[%value_in]; } mov.f64 %r138,%r219; bra $L19; $L15: .loc 1 203 0 mov.f64 %r221,0d3ff0000000000000; sub.f64 %r220,%r221,%r135; mul.f64 %r142,%r220,0d400921fb54442d18; mov.u32 %r224,0; mov.f64 %r223,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r142; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r223; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r224; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r225,[%value_in]; } mov.f64 %r138,%r225; bra $L19; $L53: .loc 1 205 0 mov.f64 %r229,0d3ff8000000000000; sub.f64 %r228,%r135,%r229; mul.f64 %r230,%r228,0d400921fb54442d18; mov.f64 %r227,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r230; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r227; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r231,[%value_in]; } neg.f64 %r138,%r231; bra $L19; $L13: .loc 1 206 0 mov.f64 %r233,0d4000000000000000; sub.f64 %r232,%r135,%r233; mul.f64 %r147,%r232,0d400921fb54442d18; mov.u32 %r236,0; mov.f64 %r235,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r147; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r235; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r236; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r237,[%value_in]; } mov.f64 %r138,%r237; $L19: .loc 1 208 0 neg.f64 %r148,%r138; $L10: .loc 1 239 0 setp.eq.f64 %r238,%r148,0d0000000000000000; @ %r238 bra $L8; .loc 1 240 0 mul.f64 %r240,%r171,%r148; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r240; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r241,[%value_in]; } mov.f64 %r244,0d400921fb54442d18; div.rn.f64 %r243,%r244,%r241; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r243; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r245,[%value_in]; } mov.f64 %r131,%r245; .loc 1 241 0 setp.lt.f64 %r246,%r148,0d0000000000000000; @ ! %r246 bra $L20; mov.u32 %r247,-1; st.u32 [%r172],%r247; $L20: .loc 1 242 0 neg.f64 %r171,%r171; .loc 1 246 0 add.u32 %r248,%r96,-1072693248; or.b32 %r249,%r248,%r95; setp.eq.u32 %r250,%r249,0; @ ! %r250 bra $L54; bra $L43; $L42: .loc 1 248 0 setp.gt.s32 %r251,%r96,1073741823; @ %r251 bra $L24; .loc 1 249 0 setp.gt.s32 %r252,%r96,1072483532; @ %r252 bra $L25; .loc 1 250 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r254,[%value_in]; } neg.f64 %r111,%r254; .loc 1 251 0 setp.le.s32 %r255,%r96,1072130371; @ %r255 bra $L26; mov.f64 %r256,0d3ff0000000000000; sub.f64 %r110,%r256,%r171; bra $L27; $L26: .loc 1 252 0 setp.le.s32 %r257,%r96,1070442080; @ %r257 bra $L28; mov.f64 %r258,0d3fdd8b618d5af8fc; sub.f64 %r109,%r171,%r258; bra $L29; $L25: .loc 1 256 0 setp.le.s32 %r259,%r96,1073460418; @ %r259 bra $L30; mov.f64 %r260,0d4000000000000000; sub.f64 %r110,%r260,%r171; .loc 1 255 0 mov.f64 %r111,0d0000000000000000; bra $L27; $L30: .loc 1 257 0 setp.le.s32 %r261,%r96,1072936131; @ %r261 bra $L31; mov.f64 %r262,0d3ff762d86356be3f; sub.f64 %r109,%r171,%r262; .loc 1 255 0 mov.f64 %r111,0d0000000000000000; bra $L29; $L31: .loc 1 258 0 mov.f64 %r263,0d3ff0000000000000; sub.f64 %r171,%r171,%r263; .loc 1 255 0 mov.f64 %r111,0d0000000000000000; bra $L28; $L27: .loc 1 262 0 mul.f64 %r120,%r110,%r110; .loc 1 264 0 fma.rn.f64 %r265,%r120,0d3f07858e90a45837,0d3f1c5088987dfb07; fma.rn.f64 %r266,%r265,%r120,0d3f40b6c689b99c00; fma.rn.f64 %r267,%r266,%r120,0d3f67add8ccb7926b; fma.rn.f64 %r268,%r267,%r120,0d3f951322ac92547b; fma.rn.f64 %r269,%r268,%r120,0d3fd4a34cc4a60fad; .loc 1 263 0 fma.rn.f64 %r270,%r120,0d3efa7074428cfa52,0d3f2cf2eced10e54d; fma.rn.f64 %r271,%r270,%r120,0d3f538a94116f3f5d; fma.rn.f64 %r272,%r271,%r120,0d3f7e404fb68fefe8; fma.rn.f64 %r273,%r272,%r120,0d3fb13e001a5562a7; fma.rn.f64 %r274,%r273,%r120,0d3fb3c467e37db0c8; .loc 1 265 0 mul.f64 %r275,%r274,%r110; fma.rn.f64 %r276,%r269,%r120,%r275; .loc 1 266 0 fma.rn.f64 %r277,%r110,0dbfe0000000000000,%r276; add.f64 %r170,%r277,%r111; bra $L32; $L29: .loc 1 268 0 mul.f64 %r114,%r109,%r109; .loc 1 269 0 mul.f64 %r115,%r114,%r109; .loc 1 272 0 fma.rn.f64 %r278,%r115,0d3f35fd3ee8c2d3f4,0dbf41a6109c73e0ec; fma.rn.f64 %r279,%r278,%r115,0d3f6282d32e15c915; fma.rn.f64 %r280,%r279,%r115,0dbf851f9fba91ec6a; fma.rn.f64 %r281,%r280,%r115,0d3fb08b4294d5419b; .loc 1 271 0 fma.rn.f64 %r282,%r115,0dbf347f24ecc38c38,0d3f4cdf0cef61a8e9; fma.rn.f64 %r283,%r282,%r115,0dbf6e2effb3e914d7; fma.rn.f64 %r284,%r283,%r115,0d3f9266e7970af9ec; fma.rn.f64 %r285,%r284,%r115,0dbfc2e4278dc6c509; .loc 1 273 0 fma.rn.f64 %r286,%r281,%r109,%r285; neg.f64 %r287,%r286; fma.rn.f64 %r288,%r287,%r115,0dbc50c7caa48a971f; neg.f64 %r289,%r288; .loc 1 270 0 fma.rn.f64 %r290,%r115,0d3f34af6d6c0ebbf7,0dbf56fe8ebf2d1af1; fma.rn.f64 %r291,%r290,%r115,0d3f78fce0e370e344; fma.rn.f64 %r292,%r291,%r115,0dbfa0c9a8df35b713; fma.rn.f64 %r293,%r292,%r115,0d3fdef72bc8ee38a2; .loc 1 273 0 fma.rn.f64 %r294,%r114,%r293,%r289; .loc 1 274 0 mov.f64 %r296,0d3fbf19b9bcc38a42; sub.f64 %r295,%r294,%r296; add.f64 %r170,%r295,%r111; bra $L32; $L28: .loc 1 276 0 fma.rn.f64 %r297,%r171,0d3f8b678bbf2bab09,0d3fcd4eaef6010924; fma.rn.f64 %r298,%r297,%r171,0d3fef497644ea8450; fma.rn.f64 %r299,%r298,%r171,0d3ff7475cd119bd6f; fma.rn.f64 %r300,%r299,%r171,0d3fe4401e8b005dff; fma.rn.f64 %r301,%r300,%r171,0dbfb3c467e37db0c8; mul.f64 %r302,%r301,%r171; .loc 1 277 0 fma.rn.f64 %r303,%r171,0d3f6a5abb57d0cf61,0d3fbaae55d6537c88; fma.rn.f64 %r304,%r303,%r171,0d3fe89dfbe45050af; fma.rn.f64 %r305,%r304,%r171,0d40010725a42b18f5; fma.rn.f64 %r306,%r305,%r171,0d4003a5d7c2bd619c; fma.rn.f64 %r307,%r306,%r171,0d3ff0000000000000; .loc 1 278 0 div.rn.f64 %r308,%r302,%r307; fma.rn.f64 %r309,%r171,0dbfe0000000000000,%r308; add.f64 %r170,%r309,%r111; bra $L32; $L24: .loc 1 281 0 setp.gt.s32 %r310,%r96,1075838975; @ %r310 bra $L33; .loc 1 282 0 cvt.rzi.s32.f64 %r101,%r171; .loc 1 284 0 cvt.rn.f64.s32 %r311,%r101; sub.f64 %r102,%r171,%r311; .loc 1 285 0 fma.rn.f64 %r312,%r102,0d3f00bfecdd17e945,0d3f5e26b67368f239; fma.rn.f64 %r313,%r312,%r102,0d3f9b481c7e939961; fma.rn.f64 %r314,%r313,%r102,0d3fc2bb9cbee5f2f7; fma.rn.f64 %r315,%r314,%r102,0d3fd4d98f4f139f59; fma.rn.f64 %r316,%r315,%r102,0d3fcb848b36e20878; fma.rn.f64 %r317,%r316,%r102,0dbfb3c467e37db0c8; mul.f64 %r318,%r317,%r102; .loc 1 286 0 fma.rn.f64 %r319,%r102,0d3edebaf7a5b38140,0d3f497ddaca41a95b; fma.rn.f64 %r320,%r319,%r102,0d3f9317ea742ed475; fma.rn.f64 %r321,%r320,%r102,0d3fc601edccfbdf27; fma.rn.f64 %r322,%r321,%r102,0d3fe71a1893d3dcdc; fma.rn.f64 %r323,%r322,%r102,0d3ff645a762c4ab74; fma.rn.f64 %r324,%r323,%r102,0d3ff0000000000000; .loc 1 287 0 div.rn.f64 %r325,%r318,%r324; fma.rn.f64 %r170,%r102,0d3fe0000000000000,%r325; .loc 1 289 0 setp.eq.u32 %r326,%r101,5; @ %r326 bra $L46; setp.gt.s32 %r327,%r101,5; @ %r327 bra $L35; setp.eq.u32 %r328,%r101,3; @ %r328 bra $L44; setp.eq.u32 %r329,%r101,4; @ %r329 bra $L45; bra $L32; $L35: setp.eq.u32 %r330,%r101,6; @ %r330 bra $L47; setp.eq.u32 %r331,%r101,7; @ ! %r331 bra $L32; .loc 1 290 0 add.f64 %r77,%r102,0d4018000000000000; bra $L38; $L47: .loc 1 288 0 mov.f64 %r77,0d3ff0000000000000; $L38: .loc 1 291 0 add.f64 %r332,%r102,0d4014000000000000; mul.f64 %r91,%r332,%r77; bra $L34; $L46: .loc 1 288 0 mov.f64 %r91,0d3ff0000000000000; $L34: .loc 1 292 0 add.f64 %r333,%r102,0d4010000000000000; mul.f64 %r92,%r333,%r91; bra $L37; $L45: .loc 1 288 0 mov.f64 %r92,0d3ff0000000000000; $L37: .loc 1 293 0 add.f64 %r334,%r102,0d4008000000000000; mul.f64 %r93,%r334,%r92; bra $L36; $L44: .loc 1 288 0 mov.f64 %r93,0d3ff0000000000000; $L36: .loc 1 294 0 add.f64 %r336,%r102,0d4000000000000000; mul.f64 %r337,%r336,%r93; .loc 1 295 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r337; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r338,[%value_in]; } add.f64 %r170,%r170,%r338; bra $L32; $L33: .loc 1 298 0 setp.gt.s32 %r339,%r96,1133510655; @ %r339 bra $L40; .loc 1 299 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r341,[%value_in]; } .loc 1 300 0 mov.f64 %r342,0d3ff0000000000000; div.rn.f64 %r98,%r342,%r171; .loc 1 301 0 mul.f64 %r99,%r98,%r98; .loc 1 303 0 mov.f64 %r344,0d3fe0000000000000; sub.f64 %r343,%r171,%r344; .loc 1 302 0 fma.rn.f64 %r345,%r99,0dbf5ab89d0b9e43e4,0d3f4b67ba4cdad5d1; fma.rn.f64 %r346,%r345,%r99,0dbf4380cb8c0fe741; fma.rn.f64 %r347,%r346,%r99,0d3f4a019f98cf38b6; fma.rn.f64 %r348,%r347,%r99,0dbf66c16c16b02e5c; fma.rn.f64 %r349,%r348,%r99,0d3fb555555555553b; fma.rn.f64 %r350,%r349,%r98,0d3fdacfe390c97d69; .loc 1 303 0 sub.f64 %r351,%r341,%r342; fma.rn.f64 %r170,%r343,%r351,%r350; bra $L32; $L40: .loc 1 306 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r354,[%value_in]; } mov.f64 %r356,0d3ff0000000000000; sub.f64 %r355,%r354,%r356; mul.f64 %r170,%r355,%r171; $L32: .loc 1 307 0 @ ! %r368 bra $L22; bra $L1; $L43: .loc 1 246 0 mov.f64 %r170,0d0000000000000000; bra $L22; $L49: mov.f64 %r170,0d0000000000000000; $L22: .loc 1 307 0 sub.f64 %r170,%r131,%r170; bra $L1; $L48: .loc 1 246 0 mov.f64 %r170,0d0000000000000000; bra $L1; $L50: mov.f64 %r170,0d0000000000000000; bra $L1; $L7: add.u32 %r359,%r96,-1072693248; or.b32 %r360,%r359,%r95; setp.eq.u32 %r361,%r360,0; @ %r361 bra $L48; bra $L55; $L54: add.u32 %r362,%r96,-1073741824; or.b32 %r363,%r362,%r95; setp.eq.u32 %r364,%r363,0; @ %r364 bra $L49; bra $L42; $L55: add.u32 %r365,%r96,-1073741824; or.b32 %r366,%r365,%r95; setp.eq.u32 %r367,%r366,0; @ %r367 bra $L50; .loc 1 219 0 mov.f64 %r131,0d0000000000000000; bra $L42; $L1: .loc 1 309 0 mov.f64 %value,%r170; st.param.f64 [%value_out],%value; ret; } /291 0 0 0 644 1394 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .visible .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/erf_gamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .extern .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_gammaf_r .visible .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r24; .reg .u64 %r25; .reg .f32 %r28; .reg .f32 %r30; mov.f32 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 33 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),__ieee754_lgammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r28,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r28; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r30,[%value_in]; } .loc 1 34 0 mov.f32 %value,%r30; st.param.f32 [%value_out],%value; ret; } /310 0 0 0 644 16725 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .visible .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/erf_lgamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .extern .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .extern .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_lgammaf_r .visible .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r76; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .f32 %r98; .reg .f32 %r99; .reg .u32 %r101; .reg .f32 %r102; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r112; .reg .f32 %r113; .reg .f32 %r118; .reg .f32 %r122; .reg .f32 %r124; .reg .f32 %r126; .reg .u32 %r130; .reg .u32 %r131; .reg .f32 %r132; .reg .u32 %r133; .reg .f32 %r135; .reg .f32 %r136; .reg .f32 %r138; .reg .f32 %r140; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r149; .reg .f32 %r165; .reg .f32 %r166; .reg .u64 %r167; .reg .u32 %r168; .reg .pred %r169; .reg .pred %r170; .reg .f32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .u32 %r174; .reg .f32 %r176; .reg .f32 %r177; .reg .f32 %r179; .reg .pred %r181; .reg .pred %r182; .reg .f32 %r184; .reg .u32 %r185; .reg .f32 %r186; .reg .f32 %r187; .reg .f32 %r189; .reg .pred %r190; .reg .f32 %r192; .reg .f32 %r193; .reg .f32 %r194; .reg .f32 %r195; .reg .pred %r196; .reg .pred %r197; .reg .pred %r198; .reg .pred %r199; .reg .pred %r200; .reg .f32 %r202; .reg .f32 %r204; .reg .f32 %r205; .reg .f32 %r206; .reg .f32 %r208; .reg .f32 %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r213; .reg .u32 %r214; .reg .f32 %r215; .reg .f32 %r217; .reg .f32 %r218; .reg .f32 %r219; .reg .f32 %r220; .reg .f32 %r221; .reg .f32 %r222; .reg .f32 %r223; .reg .f32 %r225; .reg .u32 %r226; .reg .f32 %r227; .reg .pred %r228; .reg .f32 %r230; .reg .f32 %r231; .reg .f32 %r233; .reg .f32 %r234; .reg .f32 %r235; .reg .pred %r236; .reg .u32 %r237; .reg .u32 %r238; .reg .u32 %r239; .reg .pred %r240; .reg .pred %r241; .reg .pred %r242; .reg .f32 %r244; .reg .pred %r245; .reg .f32 %r246; .reg .pred %r247; .reg .f32 %r248; .reg .pred %r249; .reg .f32 %r250; .reg .pred %r251; .reg .f32 %r252; .reg .f32 %r253; .reg .f32 %r255; .reg .f32 %r256; .reg .f32 %r257; .reg .f32 %r258; .reg .f32 %r259; .reg .f32 %r260; .reg .f32 %r261; .reg .f32 %r262; .reg .f32 %r263; .reg .f32 %r264; .reg .f32 %r265; .reg .f32 %r266; .reg .f32 %r267; .reg .f32 %r268; .reg .f32 %r269; .reg .f32 %r270; .reg .f32 %r271; .reg .f32 %r272; .reg .f32 %r273; .reg .f32 %r274; .reg .f32 %r275; .reg .f32 %r276; .reg .f32 %r277; .reg .f32 %r278; .reg .f32 %r279; .reg .f32 %r280; .reg .f32 %r281; .reg .f32 %r282; .reg .f32 %r283; .reg .f32 %r284; .reg .f32 %r285; .reg .f32 %r286; .reg .f32 %r287; .reg .f32 %r288; .reg .f32 %r289; .reg .f32 %r290; .reg .f32 %r291; .reg .f32 %r292; .reg .f32 %r293; .reg .f32 %r294; .reg .f32 %r295; .reg .f32 %r296; .reg .f32 %r297; .reg .f32 %r298; .reg .f32 %r299; .reg .pred %r300; .reg .f32 %r301; .reg .f32 %r302; .reg .f32 %r303; .reg .f32 %r304; .reg .f32 %r305; .reg .f32 %r306; .reg .f32 %r307; .reg .f32 %r308; .reg .f32 %r309; .reg .f32 %r310; .reg .f32 %r311; .reg .f32 %r312; .reg .f32 %r313; .reg .f32 %r314; .reg .f32 %r315; .reg .pred %r316; .reg .pred %r317; .reg .pred %r318; .reg .pred %r319; .reg .pred %r320; .reg .pred %r321; .reg .f32 %r322; .reg .f32 %r323; .reg .f32 %r324; .reg .f32 %r326; .reg .f32 %r327; .reg .f32 %r328; .reg .pred %r329; .reg .f32 %r331; .reg .f32 %r332; .reg .f32 %r333; .reg .f32 %r334; .reg .f32 %r335; .reg .f32 %r336; .reg .f32 %r337; .reg .f32 %r338; .reg .f32 %r339; .reg .f32 %r340; .reg .f32 %r341; .reg .f32 %r344; .reg .f32 %r345; .reg .f32 %r346; .reg .u32 %r349; .reg .u32 %r350; .reg .pred %r351; .reg .pred %r352; mov.f32 %r166,%ar0; mov.u64 %r167,%ar1; .loc 1 157 0 mov.b32 %r94,%r166; .loc 1 160 0 mov.u32 %r168,1; st.u32 [%r167],%r168; .loc 1 161 0 and.b32 %r95,%r94,2147483647; .loc 1 162 0 setp.le.s32 %r169,%r95,2139095039; @ %r169 bra $L2; mul.f32 %r165,%r166,%r166; bra $L1; $L2: .loc 1 163 0 setp.ne.u32 %r170,%r95,0; @ %r170 bra $L4; $L8: mov.f32 %r171,0f3f800000; div.rn.f32 %r165,%r171,0f00000000; bra $L1; $L4: .loc 1 164 0 setp.gt.s32 %r172,%r95,478150655; @ %r172 bra $L5; .loc 1 165 0 setp.ge.s32 %r173,%r94,0; @ %r173 bra $L6; .loc 1 166 0 mov.u32 %r174,-1; st.u32 [%r167],%r174; .loc 1 167 0 neg.f32 %r176,%r166; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r176; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r177,[%value_in]; } neg.f32 %r165,%r177; bra $L1; $L6: .loc 1 168 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r179,[%value_in]; } neg.f32 %r165,%r179; bra $L1; $L5: .loc 1 170 0 setp.ge.s32 %r352,%r94,0; @ %r352 bra $L7; .loc 1 171 0 setp.gt.s32 %r181,%r95,1258291199; @ %r181 bra $L8; .loc 1 110 0 setp.gt.s32 %r182,%r95,1048575999; @ %r182 bra $L9; mul.f32 %r186,%r166,0f40490fdb; mov.u32 %r185,0; mov.f32 %r184,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r186; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r184; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r185; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r187,[%value_in]; } mov.f32 %r146,%r187; bra $L10; $L9: .loc 1 111 0 neg.f32 %r122,%r166; .loc 1 117 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r122; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r189,[%value_in]; } .loc 1 118 0 setp.eq.f32 %r190,%r122,%r189; @ %r190 bra $L11; .loc 1 119 0 mul.f32 %r124,%r122,0f3f000000; .loc 1 120 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r124; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r192,[%value_in]; } sub.f32 %r126,%r124,%r192; add.f32 %r132,%r126,%r126; .loc 1 121 0 mul.f32 %r193,%r132,0f40800000; cvt.rzi.s32.f32 %r133,%r193; bra $L12; $L11: .loc 1 127 0 mov.f32 %r195,0f4b000000; sub.f32 %r194,%r195,%r166; mov.b32 %r130,%r194; .loc 1 128 0 and.b32 %r131,%r130,1; .loc 1 129 0 cvt.rn.f32.s32 %r132,%r131; .loc 1 130 0 shl.b32 %r133,%r131,2; $L12: .loc 1 133 0 setp.gt.s32 %r196,%r133,4; @ %r196 bra $L14; setp.ge.s32 %r197,%r133,3; @ %r197 bra $L15; setp.eq.u32 %r198,%r133,0; @ %r198 bra $L16; setp.lt.s32 %r199,%r133,0; @ ! %r199 bra $L48; bra $L13; $L14: setp.gt.s32 %r200,%r133,6; @ ! %r200 bra $L49; bra $L13; $L16: .loc 1 134 0 mul.f32 %r135,%r132,0f40490fdb; mov.f32 %r202,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r135; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r202; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r133; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r204,[%value_in]; } mov.f32 %r136,%r204; bra $L19; $L48: .loc 1 136 0 mov.f32 %r206,0f3f000000; sub.f32 %r205,%r206,%r132; mul.f32 %r138,%r205,0f40490fdb; mov.f32 %r208,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r138; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r208; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r209,[%value_in]; } mov.f32 %r136,%r209; bra $L19; $L15: .loc 1 138 0 mov.f32 %r211,0f3f800000; sub.f32 %r210,%r211,%r132; mul.f32 %r140,%r210,0f40490fdb; mov.u32 %r214,0; mov.f32 %r213,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r140; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r213; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r214; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r215,[%value_in]; } mov.f32 %r136,%r215; bra $L19; $L49: .loc 1 140 0 mov.f32 %r219,0f3fc00000; sub.f32 %r218,%r132,%r219; mul.f32 %r220,%r218,0f40490fdb; mov.f32 %r217,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r220; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r217; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r221,[%value_in]; } neg.f32 %r136,%r221; bra $L19; $L13: .loc 1 141 0 mov.f32 %r223,0f40000000; sub.f32 %r222,%r132,%r223; mul.f32 %r145,%r222,0f40490fdb; mov.u32 %r226,0; mov.f32 %r225,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r145; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r225; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r226; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r227,[%value_in]; } mov.f32 %r136,%r227; $L19: .loc 1 143 0 neg.f32 %r146,%r136; $L10: .loc 1 174 0 setp.eq.f32 %r228,%r146,0f00000000; @ %r228 bra $L8; .loc 1 175 0 mul.f32 %r230,%r166,%r146; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r230; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r231,[%value_in]; } mov.f32 %r234,0f40490fdb; div.rn.f32 %r233,%r234,%r231; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r233; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r235,[%value_in]; } mov.f32 %r149,%r235; .loc 1 176 0 setp.lt.f32 %r236,%r146,0f00000000; @ ! %r236 bra $L20; mov.u32 %r237,-1; st.u32 [%r167],%r237; $L20: .loc 1 177 0 neg.f32 %r166,%r166; .loc 1 181 0 add.u32 %r238,%r95,-1065353216; and.b32 %r239,%r238,-8388609; setp.eq.u32 %r240,%r239,0; @ %r240 bra $L41; $L40: .loc 1 183 0 setp.gt.s32 %r241,%r95,1073741823; @ %r241 bra $L23; .loc 1 184 0 setp.gt.s32 %r242,%r95,1063675494; @ %r242 bra $L24; .loc 1 185 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r244,[%value_in]; } neg.f32 %r109,%r244; .loc 1 186 0 setp.le.s32 %r245,%r95,1060850207; @ %r245 bra $L25; mov.f32 %r246,0f3f800000; sub.f32 %r108,%r246,%r166; bra $L26; $L25: .loc 1 187 0 setp.le.s32 %r247,%r95,1047343879; @ %r247 bra $L27; mov.f32 %r248,0f3eec5b0c; sub.f32 %r107,%r166,%r248; bra $L28; $L24: .loc 1 191 0 setp.le.s32 %r249,%r95,1071490583; @ %r249 bra $L29; mov.f32 %r250,0f40000000; sub.f32 %r108,%r250,%r166; .loc 1 190 0 mov.f32 %r109,0f00000000; bra $L26; $L29: .loc 1 192 0 setp.le.s32 %r251,%r95,1067296287; @ %r251 bra $L30; mov.f32 %r252,0f3fbb16c3; sub.f32 %r107,%r166,%r252; .loc 1 190 0 mov.f32 %r109,0f00000000; bra $L28; $L30: .loc 1 193 0 mov.f32 %r253,0f3f800000; sub.f32 %r166,%r166,%r253; .loc 1 190 0 mov.f32 %r109,0f00000000; bra $L27; $L26: .loc 1 197 0 mul.f32 %r118,%r108,%r108; .loc 1 199 0 fma.rn.f32 %r255,%r118,0f383c2c75,0f38e28445; fma.rn.f32 %r256,%r255,%r118,0f3a05b634; fma.rn.f32 %r257,%r256,%r118,0f3b3d6ec6; fma.rn.f32 %r258,%r257,%r118,0f3ca89915; fma.rn.f32 %r259,%r258,%r118,0f3ea51a66; .loc 1 198 0 fma.rn.f32 %r260,%r118,0f37d383a2,0f39679767; fma.rn.f32 %r261,%r260,%r118,0f3a9c54a1; fma.rn.f32 %r262,%r261,%r118,0f3bf2027e; fma.rn.f32 %r263,%r262,%r118,0f3d89f001; fma.rn.f32 %r264,%r263,%r118,0f3d9e233f; .loc 1 200 0 mul.f32 %r265,%r264,%r108; fma.rn.f32 %r266,%r259,%r118,%r265; .loc 1 201 0 fma.rn.f32 %r267,%r108,0fbf000000,%r266; add.f32 %r165,%r267,%r109; bra $L31; $L28: .loc 1 203 0 mul.f32 %r112,%r107,%r107; .loc 1 204 0 mul.f32 %r113,%r112,%r107; .loc 1 207 0 fma.rn.f32 %r268,%r113,0f39afe9f7,0fba0d3085; fma.rn.f32 %r269,%r268,%r113,0f3b141699; fma.rn.f32 %r270,%r269,%r113,0fbc28fcfe; fma.rn.f32 %r271,%r270,%r113,0f3d845a15; .loc 1 206 0 fma.rn.f32 %r272,%r113,0fb9a3f927,0f3a66f867; fma.rn.f32 %r273,%r272,%r113,0fbb7177fe; fma.rn.f32 %r274,%r273,%r113,0f3c93373d; fma.rn.f32 %r275,%r274,%r113,0fbe17213c; .loc 1 208 0 fma.rn.f32 %r276,%r271,%r107,%r275; neg.f32 %r277,%r276; fma.rn.f32 %r278,%r277,%r113,0f31e61c52; neg.f32 %r279,%r278; .loc 1 205 0 fma.rn.f32 %r280,%r113,0f39a57b6b,0fbab7f476; fma.rn.f32 %r281,%r280,%r113,0f3bc7e707; fma.rn.f32 %r282,%r281,%r113,0fbd064d47; fma.rn.f32 %r283,%r282,%r113,0f3ef7b95e; .loc 1 208 0 fma.rn.f32 %r284,%r112,%r283,%r279; .loc 1 209 0 mov.f32 %r286,0f3df8cdcd; sub.f32 %r285,%r284,%r286; add.f32 %r165,%r285,%r109; bra $L31; $L27: .loc 1 211 0 fma.rn.f32 %r287,%r166,0f3c5b3c5e,0f3e6a7578; fma.rn.f32 %r288,%r287,%r166,0f3f7a4bb2; fma.rn.f32 %r289,%r288,%r166,0f3fba3ae7; fma.rn.f32 %r290,%r289,%r166,0f3f2200f4; fma.rn.f32 %r291,%r290,%r166,0fbd9e233f; mul.f32 %r292,%r291,%r166; .loc 1 212 0 fma.rn.f32 %r293,%r166,0f3b52d5db,0f3dd572af; fma.rn.f32 %r294,%r293,%r166,0f3f44efdf; fma.rn.f32 %r295,%r294,%r166,0f4008392d; fma.rn.f32 %r296,%r295,%r166,0f401d2ebe; fma.rn.f32 %r297,%r296,%r166,0f3f800000; .loc 1 213 0 div.rn.f32 %r298,%r292,%r297; fma.rn.f32 %r299,%r166,0fbf000000,%r298; add.f32 %r165,%r299,%r109; bra $L31; $L23: .loc 1 216 0 setp.gt.s32 %r300,%r95,1090519039; @ %r300 bra $L32; .loc 1 217 0 cvt.rzi.s32.f32 %r101,%r166; .loc 1 219 0 cvt.rn.f32.s32 %r301,%r101; sub.f32 %r102,%r166,%r301; .loc 1 220 0 fma.rn.f32 %r302,%r102,0f3805ff67,0f3af135b4; fma.rn.f32 %r303,%r302,%r102,0f3cda40e4; fma.rn.f32 %r304,%r303,%r102,0f3e15dce6; fma.rn.f32 %r305,%r304,%r102,0f3ea6cc7a; fma.rn.f32 %r306,%r305,%r102,0f3e5c245a; fma.rn.f32 %r307,%r306,%r102,0fbd9e233f; mul.f32 %r308,%r307,%r102; .loc 1 221 0 fma.rn.f32 %r309,%r102,0f36f5d7bd,0f3a4beed6; fma.rn.f32 %r310,%r309,%r102,0f3c98bf54; fma.rn.f32 %r311,%r310,%r102,0f3e300f6e; fma.rn.f32 %r312,%r311,%r102,0f3f38d0c5; fma.rn.f32 %r313,%r312,%r102,0f3fb22d3b; fma.rn.f32 %r314,%r313,%r102,0f3f800000; .loc 1 222 0 div.rn.f32 %r315,%r308,%r314; fma.rn.f32 %r165,%r102,0f3f000000,%r315; .loc 1 224 0 setp.eq.u32 %r316,%r101,5; @ %r316 bra $L44; setp.gt.s32 %r317,%r101,5; @ %r317 bra $L34; setp.eq.u32 %r318,%r101,3; @ %r318 bra $L42; setp.eq.u32 %r319,%r101,4; @ %r319 bra $L43; bra $L31; $L34: setp.eq.u32 %r320,%r101,6; @ %r320 bra $L45; setp.eq.u32 %r321,%r101,7; @ ! %r321 bra $L31; .loc 1 225 0 add.f32 %r76,%r102,0f40c00000; bra $L37; $L45: .loc 1 223 0 mov.f32 %r76,0f3f800000; $L37: .loc 1 226 0 add.f32 %r322,%r102,0f40a00000; mul.f32 %r90,%r322,%r76; bra $L33; $L44: .loc 1 223 0 mov.f32 %r90,0f3f800000; $L33: .loc 1 227 0 add.f32 %r323,%r102,0f40800000; mul.f32 %r91,%r323,%r90; bra $L36; $L43: .loc 1 223 0 mov.f32 %r91,0f3f800000; $L36: .loc 1 228 0 add.f32 %r324,%r102,0f40400000; mul.f32 %r92,%r324,%r91; bra $L35; $L42: .loc 1 223 0 mov.f32 %r92,0f3f800000; $L35: .loc 1 229 0 add.f32 %r326,%r102,0f40000000; mul.f32 %r327,%r326,%r92; .loc 1 230 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r327; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r328,[%value_in]; } add.f32 %r165,%r165,%r328; bra $L31; $L32: .loc 1 233 0 setp.gt.s32 %r329,%r95,1551892479; @ %r329 bra $L39; .loc 1 234 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r331,[%value_in]; } .loc 1 235 0 mov.f32 %r332,0f3f800000; div.rn.f32 %r98,%r332,%r166; .loc 1 236 0 mul.f32 %r99,%r98,%r98; .loc 1 238 0 mov.f32 %r334,0f3f000000; sub.f32 %r333,%r166,%r334; .loc 1 237 0 fma.rn.f32 %r335,%r99,0fbad5c4e8,0f3a5b3dd2; fma.rn.f32 %r336,%r335,%r99,0fba1c065c; fma.rn.f32 %r337,%r336,%r99,0f3a500cfd; fma.rn.f32 %r338,%r337,%r99,0fbb360b61; fma.rn.f32 %r339,%r338,%r99,0f3daaaaab; fma.rn.f32 %r340,%r339,%r98,0f3ed67f1d; .loc 1 238 0 sub.f32 %r341,%r331,%r332; fma.rn.f32 %r165,%r333,%r341,%r340; bra $L31; $L39: .loc 1 241 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r344,[%value_in]; } mov.f32 %r346,0f3f800000; sub.f32 %r345,%r344,%r346; mul.f32 %r165,%r345,%r166; $L31: .loc 1 242 0 @ ! %r352 bra $L22; bra $L1; $L41: .loc 1 181 0 mov.f32 %r165,0f00000000; $L22: .loc 1 242 0 sub.f32 %r165,%r149,%r165; bra $L1; $L46: .loc 1 181 0 mov.f32 %r165,0f00000000; bra $L1; $L7: add.u32 %r349,%r95,-1065353216; and.b32 %r350,%r349,-8388609; setp.eq.u32 %r351,%r350,0; @ %r351 bra $L46; .loc 1 154 0 mov.f32 %r149,0f00000000; bra $L40; $L1: .loc 1 244 0 mov.f32 %value,%r165; st.param.f32 [%value_out],%value; ret; } lib_a-erfcl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erfcl .visible .func (.param .f64 %value_out) erfcl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/erfcl.c" // BEGIN GLOBAL FUNCTION DECL: erfc .extern .func (.param .f64 %value_out) erfc (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erfcl .visible .func (.param .f64 %value_out) erfcl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),erfc,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-erfl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erfl .visible .func (.param .f64 %value_out) erfl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/erfl.c" // BEGIN GLOBAL FUNCTION DECL: erf .extern .func (.param .f64 %value_out) erf (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erfl .visible .func (.param .f64 %value_out) erfl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),erf,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-exp2l.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp2l .visible .func (.param .f64 %value_out) exp2l (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/exp2l.c" // BEGIN GLOBAL FUNCTION DECL: exp2 .extern .func (.param .f64 %value_out) exp2 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: exp2l .visible .func (.param .f64 %value_out) exp2l (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),exp2,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-expl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expl .visible .func (.param .f64 %value_out) expl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/expl.c" // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: expl .visible .func (.param .f64 %value_out) expl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),exp,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-expm1l.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expm1l .visible .func (.param .f64 %value_out) expm1l (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/expm1l.c" // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: expm1l .visible .func (.param .f64 %value_out) expm1l (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-fabsl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fabsl .visible .func (.param .f64 %value_out) fabsl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/fabsl.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fabsl .visible .func (.param .f64 %value_out) fabsl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-fdiml.o/ 0 0 0 644 999 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fdiml .visible .func (.param .f64 %value_out) fdiml (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/fdiml.c" // BEGIN GLOBAL FUNCTION DECL: fdim .extern .func (.param .f64 %value_out) fdim (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fdiml .visible .func (.param .f64 %value_out) fdiml (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fdim,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-floorl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: floorl .visible .func (.param .f64 %value_out) floorl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/floorl.c" // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: floorl .visible .func (.param .f64 %value_out) floorl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),floor,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-fmal.o/ 0 0 0 644 1198 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmal .visible .func (.param .f64 %value_out) fmal (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/common/fmal.c" // BEGIN GLOBAL FUNCTION DECL: fma .extern .func (.param .f64 %value_out) fma (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: fmal .visible .func (.param .f64 %value_out) fmal (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r29; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; mov.f64 %r25,%ar2; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r25; call (%value_in),fma,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r29,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r29; st.param.f64 [%value_out],%value; ret; } lib_a-fmaxl.o/ 0 0 0 644 999 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmaxl .visible .func (.param .f64 %value_out) fmaxl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/fmaxl.c" // BEGIN GLOBAL FUNCTION DECL: fmax .extern .func (.param .f64 %value_out) fmax (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fmaxl .visible .func (.param .f64 %value_out) fmaxl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fmax,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-fminl.o/ 0 0 0 644 999 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fminl .visible .func (.param .f64 %value_out) fminl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/fminl.c" // BEGIN GLOBAL FUNCTION DECL: fmin .extern .func (.param .f64 %value_out) fmin (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fminl .visible .func (.param .f64 %value_out) fminl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fmin,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-fmodl.o/ 0 0 0 644 999 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmodl .visible .func (.param .f64 %value_out) fmodl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/fmodl.c" // BEGIN GLOBAL FUNCTION DECL: fmod .extern .func (.param .f64 %value_out) fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fmodl .visible .func (.param .f64 %value_out) fmodl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fmod,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-frexpl.o/ 0 0 0 644 1007 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexpl .visible .func (.param .f64 %value_out) frexpl (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/frexpl.c" // BEGIN GLOBAL FUNCTION DECL: frexp .extern .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: frexpl .visible .func (.param .f64 %value_out) frexpl (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),frexp,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-hypotl.o/ 0 0 0 644 1007 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: hypotl .visible .func (.param .f64 %value_out) hypotl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/hypotl.c" // BEGIN GLOBAL FUNCTION DECL: hypot .extern .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: hypotl .visible .func (.param .f64 %value_out) hypotl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),hypot,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-ilogbl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ilogbl .visible .func (.param .u32 %value_out) ilogbl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/ilogbl.c" // BEGIN GLOBAL FUNCTION DECL: ilogb .extern .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ilogbl .visible .func (.param .u32 %value_out) ilogbl (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u32 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),ilogb,(%out_arg1); ld.param.u32 %r25,[%value_in]; } .loc 1 40 0 mov.u32 %value,%r25; st.param.u32 [%value_out],%value; ret; } lib_a-k_cos.o/ 0 0 0 644 3125 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .visible .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/k_cos.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_cos .visible .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r46; .reg .f64 %r52; .reg .f64 %r54; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .pred %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .pred %r71; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .pred %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u64 %r84; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; mov.f64 %r59,%ar0; mov.f64 %r60,%ar1; .loc 1 75 0 mov.b64 %r61,%r59; shr.u64 %r62,%r61,32; cvt.u32.u64 %r37,%r62; .loc 1 76 0 and.b32 %r38,%r37,2147483647; .loc 1 77 0 setp.gt.s32 %r63,%r38,1044381695; @ %r63 bra $L2; .loc 1 78 0 cvt.rzi.s32.f64 %r64,%r59; setp.eq.u32 %r65,%r64,0; @ ! %r65 bra $L10; bra $L8; $L2: .loc 1 80 0 mul.f64 %r46,%r59,%r59; .loc 1 81 0 fma.rn.f64 %r66,%r46,0dbda8fae9be8838d4,0d3e21ee9ebdb4b1c4; fma.rn.f64 %r67,%r66,%r46,0dbe927e4f809c52ad; fma.rn.f64 %r68,%r67,%r46,0d3efa01a019cb1590; fma.rn.f64 %r69,%r68,%r46,0dbf56c16c16c15177; fma.rn.f64 %r70,%r69,%r46,0d3fa555555555554c; mul.f64 %r52,%r70,%r46; .loc 1 82 0 setp.gt.s32 %r71,%r38,1070805810; @ %r71 bra $L5; $L7: .loc 1 83 0 mul.f64 %r72,%r59,%r60; neg.f64 %r73,%r72; fma.rn.f64 %r74,%r46,%r52,%r73; neg.f64 %r75,%r74; fma.rn.f64 %r76,%r46,0d3fe0000000000000,%r75; mov.f64 %r77,0d3ff0000000000000; sub.f64 %r58,%r77,%r76; bra $L1; $L5: .loc 1 85 0 setp.gt.s32 %r78,%r38,1072234496; @ %r78 bra $L9; .loc 1 88 0 add.u32 %r79,%r38,-2097152; cvt.u64.u32 %r80,%r79; shl.b64 %r84,%r80,32; mov.b64 %r36,%r84; mov.f64 %r85,0d3ff0000000000000; sub.f64 %r54,%r85,%r36; bra $L6; $L9: mov.f64 %r54,0d3fe7000000000000; .loc 1 86 0 mov.f64 %r36,0d3fd2000000000000; $L6: .loc 1 90 0 neg.f64 %r86,%r36; fma.rn.f64 %r87,%r46,0d3fe0000000000000,%r86; .loc 1 92 0 mul.f64 %r88,%r59,%r60; neg.f64 %r89,%r88; fma.rn.f64 %r90,%r46,%r52,%r89; sub.f64 %r91,%r87,%r90; sub.f64 %r58,%r54,%r91; bra $L1; $L8: .loc 1 78 0 mov.f64 %r58,0d3ff0000000000000; bra $L1; $L10: .loc 1 80 0 mul.f64 %r46,%r59,%r59; .loc 1 81 0 fma.rn.f64 %r93,%r46,0dbda8fae9be8838d4,0d3e21ee9ebdb4b1c4; fma.rn.f64 %r94,%r46,%r93,0dbe927e4f809c52ad; fma.rn.f64 %r95,%r46,%r94,0d3efa01a019cb1590; fma.rn.f64 %r96,%r46,%r95,0dbf56c16c16c15177; fma.rn.f64 %r97,%r46,%r96,0d3fa555555555554c; mul.f64 %r52,%r97,%r46; bra $L7; $L1: .loc 1 94 0 mov.f64 %value,%r58; st.param.f64 [%value_out],%value; ret; } /330 0 0 0 644 25157 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2 .visible .func (.param .u32 %value_out) __kernel_rem_pio2 (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); .file 1 "../../../../../newlib/libm/math/k_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN VAR DEF: init_jk .const .align 4 .u32 init_jk[4] = {2,3,4,6 }; // BEGIN VAR DEF: PIo2 .const .align 8 .u64 PIo2[8] = {4609753056584663040,4500296887714185216,4393339057296375808,4285399695318056960,4174867106174599168,4069606033725587456,3955147982449410048,3848874662444400640 }; // BEGIN GLOBAL FUNCTION DEF: __kernel_rem_pio2 .visible .func (.param .u32 %value_out) __kernel_rem_pio2 (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .local .align 8 .b8 %frame_ar[560]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r261; .reg .u32 %r262; .reg .u32 %r263; .reg .u32 %r264; .reg .u32 %r265; .reg .u32 %r267; .reg .u32 %r273; .reg .u32 %r275; .reg .u32 %r277; .reg .f64 %r295; .reg .u32 %r299; .reg .u32 %r307; .reg .f64 %r313; .reg .f64 %r316; .reg .f64 %r317; .reg .u64 %r329; .reg .u32 %r330; .reg .u64 %r337; .reg .u64 %r338; .reg .u64 %r340; .reg .u32 %r341; .reg .f64 %r342; .reg .u64 %r343; .reg .f64 %r344; .reg .u32 %r348; .reg .u32 %r350; .reg .u32 %r351; .reg .f64 %r353; .reg .f64 %r354; .reg .u32 %r355; .reg .u32 %r357; .reg .u32 %r359; .reg .u64 %r360; .reg .f64 %r362; .reg .u32 %r364; .reg .u64 %r368; .reg .u32 %r369; .reg .f64 %r370; .reg .f64 %r371; .reg .f64 %r372; .reg .f64 %r374; .reg .u32 %r375; .reg .f64 %r376; .reg .f64 %r377; .reg .f64 %r378; .reg .f64 %r379; .reg .f64 %r381; .reg .f64 %r383; .reg .u32 %r385; .reg .u64 %r386; .reg .u32 %r388; .reg .u32 %r390; .reg .u64 %r395; .reg .u64 %r397; .reg .u32 %r399; .reg .u64 %r400; .reg .u64 %r401; .reg .u64 %r408; .reg .u64 %r415; .reg .u64 %r416; .reg .f64 %r419; .reg .u64 %r420; .reg .u64 %r421; .reg .f64 %r422; .reg .f64 %r423; .reg .u64 %r424; .reg .f64 %r427; .reg .u32 %r430; .reg .u64 %r431; .reg .u64 %r432; .reg .u64 %r433; .reg .u32 %r436; .reg .u64 %r437; .reg .u64 %r439; .reg .u32 %r441; .reg .u64 %r442; .reg .u64 %r443; .reg .u64 %r444; .reg .u64 %r446; .reg .u64 %r455; .reg .u64 %r456; .reg .u64 %r462; .reg .u64 %r463; .reg .u64 %r474; .reg .u64 %r476; .reg .u64 %r477; .reg .u64 %r482; .reg .u32 %r483; .reg .u64 %r487; .reg .u32 %r490; .reg .u32 %r496; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r504; .reg .u64 %r506; .reg .u64 %r514; .reg .u64 %r515; .reg .u64 %r527; .reg .u64 %r532; .reg .u64 %r534; .reg .u64 %r536; .reg .u64 %r537; .reg .u64 %r540; .reg .u64 %r550; .reg .u64 %r551; .reg .u64 %r552; .reg .u64 %r554; .reg .u64 %r562; .reg .u64 %r563; .reg .u64 %r564; .reg .u32 %r565; .reg .u32 %r570; .reg .u64 %r571; .reg .u64 %r572; .reg .u32 %r581; .reg .u64 %r584; .reg .u64 %r585; .reg .u32 %r586; .reg .u32 %r587; .reg .u32 %r588; .reg .u64 %r589; .reg .u64 %r590; .reg .u64 %r591; .reg .u64 %r592; .reg .u64 %r593; .reg .u32 %r594; .reg .u32 %r595; .reg .u32 %r597; .reg .u32 %r598; .reg .u32 %r599; .reg .pred %r600; .reg .u64 %r601; .reg .u64 %r602; .reg .u32 %r603; .reg .pred %r604; .reg .u32 %r605; .reg .pred %r606; .reg .u64 %r609; .reg .u64 %r610; .reg .f64 %r615; .reg .f64 %r616; .reg .pred %r617; .reg .pred %r618; .reg .u32 %r621; .reg .u64 %r622; .reg .u64 %r623; .reg .u64 %r624; .reg .u64 %r625; .reg .u64 %r626; .reg .u64 %r628; .reg .u64 %r629; .reg .u32 %r631; .reg .u64 %r632; .reg .u64 %r634; .reg .u64 %r636; .reg .u64 %r637; .reg .f64 %r638; .reg .u32 %r639; .reg .f64 %r641; .reg .u32 %r642; .reg .f64 %r643; .reg .pred %r644; .reg .f64 %r647; .reg .f64 %r649; .reg .f64 %r650; .reg .f64 %r652; .reg .u64 %r654; .reg .u64 %r655; .reg .u64 %r656; .reg .u64 %r657; .reg .u32 %r658; .reg .u32 %r659; .reg .u32 %r664; .reg .u32 %r665; .reg .u32 %r667; .reg .u64 %r668; .reg .u64 %r669; .reg .u64 %r670; .reg .u32 %r672; .reg .pred %r673; .reg .pred %r674; .reg .pred %r676; .reg .pred %r677; .reg .pred %r679; .reg .pred %r680; .reg .u64 %r681; .reg .u64 %r682; .reg .u64 %r683; .reg .u32 %r685; .reg .u32 %r686; .reg .pred %r687; .reg .u64 %r688; .reg .u64 %r689; .reg .u64 %r690; .reg .u32 %r694; .reg .u32 %r695; .reg .u64 %r696; .reg .u64 %r697; .reg .u64 %r698; .reg .u64 %r701; .reg .u64 %r702; .reg .u32 %r703; .reg .u64 %r704; .reg .u32 %r705; .reg .u32 %r706; .reg .pred %r707; .reg .u64 %r708; .reg .u64 %r709; .reg .u64 %r713; .reg .u64 %r714; .reg .u64 %r715; .reg .u64 %r716; .reg .u32 %r721; .reg .u32 %r722; .reg .u64 %r723; .reg .u64 %r724; .reg .u64 %r725; .reg .u64 %r726; .reg .u32 %r731; .reg .u32 %r732; .reg .pred %r733; .reg .f64 %r734; .reg .pred %r735; .reg .f64 %r738; .reg .pred %r739; .reg .pred %r740; .reg .u64 %r745; .reg .u32 %r746; .reg .u32 %r747; .reg .u64 %r748; .reg .u64 %r749; .reg .u32 %r750; .reg .pred %r751; .reg .pred %r752; .reg .u32 %r758; .reg .pred %r759; .reg .u32 %r760; .reg .pred %r761; .reg .pred %r762; .reg .u64 %r763; .reg .u64 %r764; .reg .u64 %r765; .reg .u64 %r767; .reg .u64 %r768; .reg .u64 %r769; .reg .u32 %r770; .reg .u64 %r773; .reg .u64 %r774; .reg .f64 %r775; .reg .pred %r776; .reg .pred %r777; .reg .u64 %r779; .reg .u64 %r780; .reg .u32 %r782; .reg .pred %r783; .reg .u32 %r785; .reg .u64 %r786; .reg .u64 %r787; .reg .u32 %r788; .reg .pred %r789; .reg .u32 %r792; .reg .f64 %r793; .reg .pred %r794; .reg .f64 %r795; .reg .u64 %r797; .reg .u64 %r798; .reg .f64 %r800; .reg .f64 %r802; .reg .u32 %r803; .reg .u64 %r804; .reg .u64 %r805; .reg .u64 %r806; .reg .u64 %r809; .reg .u64 %r810; .reg .u32 %r812; .reg .f64 %r813; .reg .f64 %r815; .reg .pred %r816; .reg .f64 %r822; .reg .u32 %r823; .reg .f64 %r824; .reg .pred %r825; .reg .f64 %r826; .reg .pred %r827; .reg .pred %r828; .reg .pred %r829; .reg .pred %r831; .reg .pred %r832; .reg .pred %r833; .reg .pred %r834; .reg .pred %r835; .reg .pred %r836; .reg .f64 %r841; .reg .pred %r842; .reg .pred %r843; .reg .u64 %r844; .reg .u64 %r845; .reg .f64 %r851; .reg .pred %r852; .reg .f64 %r854; .reg .f64 %r855; .reg .pred %r856; .reg .f64 %r858; .reg .pred %r859; .reg .u64 %r862; .reg .u64 %r863; .reg .u64 %r869; .reg .u64 %r871; .reg .u64 %r872; .reg .u64 %r874; .reg .u64 %r875; .reg .u64 %r876; .reg .u64 %r877; .reg .f64 %r878; .reg .f64 %r879; .reg .pred %r880; .reg .pred %r881; .reg .u64 %r883; .reg .u64 %r884; .reg .u32 %r889; .reg .u64 %r890; .reg .u64 %r891; .reg .u64 %r893; .reg .u64 %r894; .reg .u64 %r895; .reg .u64 %r896; .reg .f64 %r897; .reg .f64 %r898; .reg .pred %r899; .reg .u64 %r901; .reg .f64 %r902; .reg .pred %r903; .reg .pred %r904; .reg .f64 %r905; .reg .f64 %r906; .reg .f64 %r907; .reg .u32 %r908; .reg .pred %r909; .reg .f64 %r910; .reg .pred %r911; .reg .pred %r912; .reg .pred %r913; .reg .pred %r914; .reg .f64 %r915; .reg .pred %r916; .reg .u64 %r917; .reg .u32 %r918; .reg .pred %r919; .reg .pred %r921; .reg .u32 %r922; .reg .pred %r923; .reg .u64 %r924; .reg .pred %r925; .reg .pred %r926; .reg .u64 %r928; .reg .u64 %r929; .reg .u64 %r930; .reg .u64 %r931; .reg .f64 %r932; .reg .u64 %r933; .reg .pred %r934; .reg .pred %r935; .reg .pred %r936; .reg .u64 %r937; .reg .u32 %r938; .reg .u64 %r939; .reg .u64 %r940; .reg .u64 %r941; .reg .u64 %r942; .reg .u64 %r943; .reg .pred %r944; .reg .u64 %r945; .reg .u64 %r946; .reg .u64 %r947; .reg .f64 %r948; mov.u64 %r584,%ar0; mov.u64 %r585,%ar1; mov.u32 %r586,%ar2; mov.u32 %r587,%ar3; mov.u32 %r588,%ar4; mov.u64 %r589,%ar5; .loc 1 176 0 cvta.const.u64 %r590,init_jk; cvt.s64.s32 %r591,%r588; shl.b64 %r592,%r591,2; add.u64 %r593,%r590,%r592; ld.u32 %r348,[%r593]; .loc 1 180 0 add.u32 %r918,%r587,-1; .loc 1 181 0 add.u32 %r594,%r586,-3; div.s32 %r350,%r594,24; max.s32 %r390,%r350,0; .loc 1 182 0 add.u32 %r595,%r390,1; shl.b32 %r597,%r595,2; sub.u32 %r598,%r595,%r597; shl.b32 %r599,%r598,3; add.u32 %r264,%r599,%r586; .loc 1 185 0 sub.u32 %r385,%r390,%r918; add.u32 %r351,%r348,%r918; .loc 1 186 0 setp.lt.s32 %r600,%r351,0; @ %r600 bra $L2; add.u64 %r571,%frame,320; cvt.s64.s32 %r601,%r385; shl.b64 %r602,%r601,2; add.u64 %r572,%r589,%r602; add.u32 %r603,%r385,%r351; add.u32 %r581,%r603,1; mov.f64 %r948,0d0000000000000000; $L4: setp.lt.s32 %r604,%r385,0; @ %r604 bra $L71; ld.u32 %r605,[%r572]; cvt.rn.f64.s32 %r344,%r605; bra $L3; $L71: mov.f64 %r344,%r948; $L3: st.f64 [%r571],%r344; add.u32 %r385,%r385,1; add.u64 %r571,%r571,8; add.u64 %r572,%r572,4; setp.ne.u32 %r606,%r385,%r581; @ %r606 bra $L4; $L2: .loc 1 189 0 setp.lt.s32 %r926,%r348,0; @ %r926 bra $L5; mov.u64 %r564,%frame; mov.u32 %r565,%r918; add.u32 %r570,%r348,%r587; cvt.u64.u32 %r609,%r918; shl.b64 %r562,%r609,3; setp.ge.s32 %r925,%r918,0; add.u64 %r945,%frame,320; add.u64 %r946,%frame,312; sub.u64 %r947,%r946,%r562; bra $L6; $L8: mov.u64 %r551,%r584; cvt.s64.s32 %r610,%r565; shl.b64 %r554,%r610,3; add.u64 %r552,%r945,%r554; add.u64 %r563,%r947,%r554; .loc 1 190 0 mov.f64 %r383,0d0000000000000000; $L7: ld.f64 %r615,[%r551]; ld.f64 %r616,[%r552]; fma.rn.f64 %r383,%r615,%r616,%r383; add.u64 %r551,%r551,8; add.u64 %r552,%r552,-8; setp.ne.u64 %r617,%r552,%r563; @ %r617 bra $L7; $L9: st.f64 [%r564],%r383; add.u64 %r564,%r564,8; add.u32 %r565,%r565,1; .loc 1 189 0 setp.eq.u32 %r618,%r565,%r570; @ %r618 bra $L5; $L6: .loc 1 190 0 @ %r925 bra $L8; mov.f64 %r383,0d0000000000000000; bra $L9; $L5: add.u64 %r917,%frame,480; add.u32 %r621,%r348,-2; cvt.s64.s32 %r622,%r621; shl.b64 %r623,%r622,2; add.u64 %r498,%r917,%r623; add.u64 %r624,%r584,8; cvt.u64.u32 %r625,%r918; shl.b64 %r626,%r625,3; add.u64 %r474,%r624,%r626; .loc 1 176 0 mov.u32 %r307,%r348; setp.le.s32 %r919,%r264,0; add.u64 %r933,%frame,-8; .loc 1 227 0 setp.eq.u32 %r934,%r264,1; setp.eq.u32 %r935,%r264,2; .loc 1 213 0 setp.ne.u32 %r936,%r264,0; add.u64 %r937,%frame,476; .loc 1 245 0 add.u32 %r938,%r348,-1; cvt.s64.s32 %r939,%r938; shl.b64 %r940,%r939,2; add.u64 %r941,%frame,%r940; add.u64 %r942,%r941,480; add.u64 %r943,%frame,320; setp.lt.s32 %r944,%r918,0; $L10: .loc 1 196 0 cvt.s64.s32 %r924,%r307; shl.b64 %r628,%r924,3; add.u64 %r629,%frame,%r628; ld.f64 %r317,[%r629]; setp.le.s32 %r921,%r307,0; @ %r921 bra $L11; mov.u64 %r536,%r917; add.u32 %r631,%r307,-1; cvt.s64.s32 %r632,%r631; shl.b64 %r540,%r632,3; add.u64 %r537,%frame,%r540; add.u64 %r634,%r933,%r540; cvt.u64.u32 %r636,%r631; shl.b64 %r637,%r636,3; sub.u64 %r550,%r634,%r637; $L12: .loc 1 197 0 mul.f64 %r638,%r317,0d3e70000000000000; cvt.rzi.s32.f64 %r639,%r638; cvt.rn.f64.s32 %r381,%r639; .loc 1 198 0 fma.rn.f64 %r641,%r381,0dc170000000000000,%r317; cvt.rzi.s32.f64 %r642,%r641; st.u32 [%r536],%r642; .loc 1 199 0 ld.f64 %r643,[%r537]; add.f64 %r317,%r381,%r643; add.u64 %r536,%r536,4; add.u64 %r537,%r537,-8; .loc 1 196 0 setp.ne.u64 %r644,%r537,%r550; @ %r644 bra $L12; $L11: .loc 1 203 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r317; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r264; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r647,[%value_in]; } .loc 1 204 0 mul.f64 %r649,%r647,0d3fc0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r649; call (%value_in),floor,(%out_arg1); ld.param.f64 %r650,[%value_in]; } fma.rn.f64 %r354,%r650,0dc020000000000000,%r647; .loc 1 205 0 cvt.rzi.s32.f64 %r330,%r354; .loc 1 206 0 cvt.rn.f64.s32 %r652,%r330; sub.f64 %r342,%r354,%r652; .loc 1 208 0 @ %r919 bra $L13; .loc 1 209 0 add.u32 %r261,%r307,-1; cvt.s64.s32 %r654,%r261; shl.b64 %r655,%r654,2; add.u64 %r656,%frame,%r655; add.u64 %r657,%r656,480; ld.u32 %r262,[%r657]; mov.u32 %r658,24; sub.u32 %r263,%r658,%r264; shr.s32 %r355,%r262,%r263; add.u32 %r330,%r330,%r355; .loc 1 210 0 shl.b32 %r659,%r355,%r263; sub.u32 %r267,%r262,%r659; st.u32 [%r657],%r267; .loc 1 211 0 mov.u32 %r665,23; sub.u32 %r664,%r665,%r264; shr.s32 %r341,%r267,%r664; bra $L14; $L13: .loc 1 213 0 @ %r936 bra $L15; add.u32 %r667,%r307,-1; cvt.s64.s32 %r668,%r667; shl.b64 %r669,%r668,2; add.u64 %r670,%frame,%r669; ld.u32 %r672,[%r670+480]; shr.s32 %r341,%r672,23; bra $L14; $L15: .loc 1 214 0 setp.ge.f64 %r673,%r342,0d3fe0000000000000; @ %r673 bra $L16; .loc 1 207 0 mov.u32 %r341,0; bra $L17; $L14: .loc 1 216 0 setp.le.s32 %r674,%r341,0; @ %r674 bra $L17; .loc 1 217 0 add.u32 %r330,%r330,1; .loc 1 218 0 @ ! %r921 bra $L68; bra $L72; $L81: .loc 1 214 0 mov.u32 %r341,2; $L68: .loc 1 219 0 ld.u32 %r357,[%frame+480]; .loc 1 221 0 setp.ne.u32 %r676,%r357,0; @ %r676 bra $L73; .loc 1 218 0 setp.eq.u32 %r677,%r307,1; @ %r677 bra $L18; add.u64 %r534,%frame,484; mov.u32 %r399,1; bra $L20; $L21: add.u64 %r534,%r534,4; mov.u32 %r399,%r430; setp.eq.u32 %r679,%r307,%r399; @ %r679 bra $L18; $L20: .loc 1 219 0 ld.u32 %r357,[%r534]; add.u32 %r430,%r399,1; .loc 1 221 0 setp.eq.u32 %r680,%r357,0; @ %r680 bra $L21; bra $L19; $L73: mov.u32 %r430,1; mov.u32 %r399,0; $L19: .loc 1 222 0 cvt.s64.s32 %r681,%r399; shl.b64 %r682,%r681,2; add.u64 %r683,%frame,%r682; mov.u32 %r686,16777216; sub.u32 %r685,%r686,%r357; st.u32 [%r683+480],%r685; .loc 1 218 0 setp.le.s32 %r687,%r307,%r430; @ %r687 bra $L74; .loc 1 219 0 cvt.s64.s32 %r688,%r430; shl.b64 %r689,%r688,2; add.u64 %r690,%frame,%r689; ld.u32 %r388,[%r690+480]; add.u64 %r515,%r917,%r689; add.u32 %r694,%r307,-1; sub.u32 %r695,%r694,%r430; cvt.u64.u32 %r696,%r695; add.u64 %r697,%r696,%r688; shl.b64 %r698,%r697,2; add.u64 %r527,%r917,%r698; neg.s64 %r701,%r688; shl.b64 %r702,%r701,2; add.u32 %r703,%r430,1; cvt.u64.u32 %r704,%r703; shl.b64 %r532,%r704,2; .loc 1 224 0 mov.u32 %r706,16777215; $L22: sub.u32 %r705,%r706,%r388; st.u32 [%r515],%r705; .loc 1 218 0 setp.eq.u64 %r707,%r515,%r527; @ %r707 bra $L75; .loc 1 219 0 add.u64 %r708,%r515,%r702; add.u64 %r709,%r708,%r532; ld.u32 %r388,[%r709]; add.u64 %r515,%r515,4; bra $L22; $L72: .loc 1 217 0 mov.u32 %r357,0; bra $L18; $L74: .loc 1 222 0 mov.u32 %r357,1; bra $L18; $L75: mov.u32 %r357,1; $L18: .loc 1 226 0 @ %r919 bra $L23; .loc 1 227 0 @ %r934 bra $L24; @ %r935 bra $L25; bra $L23; $L24: .loc 1 229 0 add.u32 %r273,%r307,-1; cvt.s64.s32 %r713,%r273; shl.b64 %r714,%r713,2; add.u64 %r715,%frame,%r714; add.u64 %r716,%r715,480; ld.u32 %r722,[%r716]; and.b32 %r721,%r722,8388607; st.u32 [%r716],%r721; bra $L23; $L25: .loc 1 231 0 add.u32 %r277,%r307,-1; cvt.s64.s32 %r723,%r277; shl.b64 %r724,%r723,2; add.u64 %r725,%frame,%r724; add.u64 %r726,%r725,480; ld.u32 %r732,[%r726]; and.b32 %r731,%r732,4194303; st.u32 [%r726],%r731; $L23: .loc 1 234 0 setp.ne.u32 %r733,%r341,2; @ %r733 bra $L17; .loc 1 235 0 mov.f64 %r734,0d3ff0000000000000; sub.f64 %r342,%r734,%r342; .loc 1 236 0 setp.eq.u32 %r735,%r357,0; @ %r735 bra $L17; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r734; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r264; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r738,[%value_in]; } sub.f64 %r342,%r342,%r738; $L17: .loc 1 241 0 setp.neu.f64 %r739,%r342,0d0000000000000000; @ %r739 bra $L26; .loc 1 243 0 add.u32 %r369,%r307,-1; setp.gt.s32 %r740,%r348,%r369; @ %r740 bra $L27; cvt.s64.s32 %r928,%r369; shl.b64 %r506,%r928,2; add.u64 %r504,%r917,%r506; add.u64 %r745,%r937,%r506; not.b32 %r746,%r348; add.u32 %r747,%r746,%r307; cvt.u64.u32 %r748,%r747; shl.b64 %r749,%r748,2; sub.u64 %r514,%r745,%r749; .loc 1 242 0 mov.u32 %r364,0; $L28: .loc 1 243 0 ld.u32 %r750,[%r504]; or.b32 %r364,%r364,%r750; add.u64 %r504,%r504,-4; setp.ne.u64 %r751,%r504,%r514; @ %r751 bra $L28; .loc 1 244 0 setp.ne.u32 %r752,%r364,0; @ %r752 bra $L29; $L27: .loc 1 245 0 ld.u32 %r758,[%r942]; setp.ne.u32 %r759,%r758,0; @ %r759 bra $L76; mov.u64 %r497,%r498; mov.u32 %r275,1; $L31: add.u32 %r275,%r275,1; add.u64 %r497,%r497,-4; ld.u32 %r760,[%r497+4]; setp.eq.u32 %r761,%r760,0; @ %r761 bra $L31; bra $L30; $L76: mov.u32 %r275,1; $L30: .loc 1 247 0 add.u32 %r359,%r307,1; add.u32 %r307,%r307,%r275; setp.gt.s32 %r762,%r359,%r307; @ %r762 bra $L10; cvt.s64.s32 %r477,%r359; cvt.s64.s32 %r763,%r390; add.u64 %r764,%r763,%r477; shl.b64 %r765,%r764,2; add.u64 %r476,%r589,%r765; add.u32 %r483,%r918,%r359; cvt.s64.s32 %r767,%r483; shl.b64 %r768,%r767,3; add.u64 %r482,%r943,%r768; shl.b64 %r769,%r477,3; add.u64 %r487,%frame,%r769; add.u32 %r490,%r483,-1; add.u32 %r496,%r307,%r918; $L35: .loc 1 248 0 ld.u32 %r770,[%r476]; cvt.rn.f64.s32 %r427,%r770; st.f64 [%r482],%r427; .loc 1 249 0 @ %r944 bra $L77; cvt.s64.s32 %r773,%r490; shl.b64 %r774,%r773,3; add.u64 %r463,%r943,%r774; mov.u64 %r462,%r584; mov.f64 %r362,0d0000000000000000; $L34: ld.f64 %r775,[%r462]; fma.rn.f64 %r362,%r775,%r427,%r362; add.u64 %r462,%r462,8; setp.eq.u64 %r776,%r462,%r474; @ %r776 bra $L33; ld.f64 %r427,[%r463]; add.u64 %r463,%r463,-8; bra $L34; $L77: mov.f64 %r362,0d0000000000000000; $L33: .loc 1 250 0 st.f64 [%r487],%r362; add.u64 %r476,%r476,4; add.u64 %r482,%r482,8; add.u64 %r487,%r487,8; add.u32 %r490,%r490,1; .loc 1 247 0 setp.ne.u32 %r777,%r490,%r496; @ %r777 bra $L35; bra $L10; $L29: .loc 1 259 0 add.u32 %r264,%r264,-24; .loc 1 260 0 shl.b64 %r779,%r928,2; add.u64 %r780,%frame,%r779; ld.u32 %r782,[%r780+480]; setp.ne.u32 %r783,%r782,0; @ %r783 bra $L36; add.u32 %r785,%r307,-2; cvt.s64.s32 %r786,%r785; shl.b64 %r787,%r786,2; add.u64 %r456,%r917,%r787; $L37: add.u32 %r369,%r369,-1; add.u32 %r264,%r264,-24; add.u64 %r456,%r456,-4; ld.u32 %r788,[%r456+4]; setp.eq.u32 %r789,%r788,0; @ %r789 bra $L37; bra $L36; $L26: .loc 1 262 0 neg.s32 %r792,%r264; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r342; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r792; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r793,[%value_in]; } .loc 1 263 0 setp.ge.f64 %r794,%r793,0d4170000000000000; @ ! %r794 bra $L115; .loc 1 264 0 mul.f64 %r795,%r793,0d3e70000000000000; cvt.rzi.s32.f64 %r299,%r795; .loc 1 265 0 shl.b64 %r797,%r924,2; add.u64 %r798,%frame,%r797; .loc 1 264 0 cvt.rn.f64.s32 %r800,%r299; .loc 1 265 0 fma.rn.f64 %r802,%r800,0dc170000000000000,%r793; cvt.rzi.s32.f64 %r803,%r802; st.u32 [%r798+480],%r803; .loc 1 266 0 add.u32 %r369,%r307,1; add.u32 %r264,%r264,24; .loc 1 267 0 cvt.s64.s32 %r804,%r369; shl.b64 %r805,%r804,2; add.u64 %r806,%frame,%r805; st.u32 [%r806+480],%r299; bra $L36; $L115: .loc 1 268 0 shl.b64 %r809,%r924,2; add.u64 %r810,%frame,%r809; cvt.rzi.s32.f64 %r812,%r793; st.u32 [%r810+480],%r812; mov.u32 %r369,%r307; $L36: .loc 1 272 0 mov.f64 %r813,0d3ff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r813; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r264; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r815,[%value_in]; } mov.f64 %r379,%r815; .loc 1 273 0 setp.lt.s32 %r816,%r369,0; @ %r816 bra $L40; cvt.s64.s32 %r443,%r369; shl.b64 %r444,%r443,2; add.u64 %r442,%r917,%r444; shl.b64 %r930,%r443,3; add.u64 %r439,%frame,%r930; add.u64 %r455,%frame,476; mov.u64 %r446,%r439; $L41: .loc 1 274 0 ld.u32 %r823,[%r442]; cvt.rn.f64.s32 %r822,%r823; mul.f64 %r824,%r822,%r379; st.f64 [%r446],%r824; mul.f64 %r379,%r379,0d3e70000000000000; add.u64 %r442,%r442,-4; add.u64 %r446,%r446,-8; .loc 1 273 0 setp.ne.u64 %r825,%r442,%r455; @ %r825 bra $L41; add.u64 %r931,%frame,160; add.u32 %r441,%r369,1; mov.u64 %r437,%r931; mov.u32 %r436,0; .loc 1 279 0 mov.f64 %r932,0d3ff921fb40000000; bra $L42; $L44: ld.f64 %r826,[%r432]; fma.rn.f64 %r378,%r826,%r419,%r378; add.u32 %r265,%r265,1; setp.lt.s32 %r827,%r348,%r265; @ %r827 bra $L43; add.u64 %r432,%r432,8; add.u64 %r433,%r433,8; setp.gt.s32 %r828,%r265,%r436; @ %r828 bra $L43; ld.f64 %r419,[%r433]; bra $L44; $L78: mov.f64 %r378,0d0000000000000000; $L43: .loc 1 280 0 st.f64 [%r437],%r378; add.u32 %r436,%r436,1; add.u64 %r437,%r437,8; add.u64 %r439,%r439,-8; .loc 1 278 0 setp.eq.u32 %r829,%r436,%r441; @ %r829 bra $L45; $L42: .loc 1 279 0 @ %r926 bra $L78; cvta.const.u64 %r433,PIo2; mov.u64 %r432,%r439; mov.f64 %r419,%r932; mov.f64 %r378,0d0000000000000000; mov.u32 %r265,0; bra $L44; $L40: .loc 1 284 0 setp.gt.s32 %r831,%r588,2; @ %r831 bra $L47; setp.gt.s32 %r832,%r588,0; @ %r832 bra $L48; setp.eq.u32 %r833,%r588,0; @ %r833 bra $L79; bra $L51; $L47: setp.eq.u32 %r834,%r588,3; @ ! %r834 bra $L51; $L50: .loc 1 300 0 setp.gt.s32 %r835,%r369,0; @ %r835 bra $L52; .loc 1 310 0 mov.f64 %r370,0d0000000000000000; bra $L53; $L48: .loc 1 293 0 setp.ge.s32 %r836,%r369,0; @ %r836 bra $L54; .loc 1 292 0 mov.f64 %r376,0d0000000000000000; bra $L55; $L56: add.u64 %r408,%r931,%r930; add.u64 %r401,%r931,-8; .loc 1 284 0 mov.f64 %r377,0d0000000000000000; $L57: .loc 1 287 0 ld.f64 %r841,[%r408]; add.f64 %r377,%r377,%r841; add.u64 %r408,%r408,-8; setp.ne.u64 %r842,%r401,%r408; @ %r842 bra $L57; bra $L49; $L79: .loc 1 286 0 mov.f64 %r377,0d0000000000000000; $L49: .loc 1 288 0 setp.eq.u32 %r843,%r341,0; @ %r843 bra $L58; neg.f64 %r377,%r377; $L58: st.f64 [%r585],%r377; .loc 1 289 0 bra $L51; $L54: cvt.s64.s32 %r844,%r369; shl.b64 %r395,%r844,3; add.u64 %r845,%frame,160; add.u64 %r397,%r845,%r395; add.u64 %r386,%frame,152; .loc 1 292 0 mov.f64 %r376,0d0000000000000000; $L59: .loc 1 293 0 ld.f64 %r851,[%r397]; add.f64 %r376,%r376,%r851; add.u64 %r397,%r397,-8; setp.ne.u64 %r852,%r386,%r397; @ %r852 bra $L59; $L55: .loc 1 294 0 setp.eq.u32 %r923,%r341,0; @ %r923 bra $L60; neg.f64 %r854,%r376; st.f64 [%r585],%r854; .loc 1 295 0 ld.f64 %r855,[%frame+160]; sub.f64 %r374,%r855,%r376; .loc 1 296 0 setp.le.s32 %r856,%r369,0; @ %r856 bra $L61; $L70: add.u64 %r400,%frame,168; .loc 1 292 0 mov.u32 %r375,1; $L62: .loc 1 296 0 ld.f64 %r858,[%r400]; add.f64 %r374,%r374,%r858; add.u32 %r375,%r375,1; add.u64 %r400,%r400,8; setp.ge.s32 %r859,%r369,%r375; @ %r859 bra $L62; .loc 1 297 0 @ %r923 bra $L63; $L61: neg.f64 %r374,%r374; $L63: st.f64 [%r585+8],%r374; .loc 1 298 0 bra $L51; $L52: cvt.s64.s32 %r928,%r369; shl.b64 %r862,%r928,3; add.u64 %r863,%frame,%r862; ld.f64 %r295,[%r863+160]; add.u32 %r922,%r369,-1; cvt.s64.s32 %r416,%r922; shl.b64 %r415,%r416,3; add.u64 %r931,%frame,160; add.u64 %r420,%r931,%r415; add.u64 %r929,%frame,152; add.u64 %r869,%r929,%r415; cvt.u64.u32 %r871,%r922; shl.b64 %r872,%r871,3; sub.u64 %r431,%r869,%r872; neg.s64 %r874,%r416; shl.b64 %r875,%r874,3; add.u64 %r368,%r415,8; $L64: .loc 1 301 0 ld.f64 %r313,[%r420]; add.f64 %r372,%r313,%r295; .loc 1 302 0 add.u64 %r876,%r875,%r420; add.u64 %r877,%r876,%r368; sub.f64 %r878,%r313,%r372; add.f64 %r879,%r878,%r295; st.f64 [%r877],%r879; .loc 1 303 0 st.f64 [%r420],%r372; add.u64 %r420,%r420,-8; mov.f64 %r295,%r372; .loc 1 300 0 setp.ne.u64 %r880,%r420,%r431; @ %r880 bra $L64; .loc 1 305 0 setp.le.s32 %r881,%r369,1; @ %r881 bra $L80; shl.b64 %r883,%r928,3; add.u64 %r884,%frame,%r883; ld.f64 %r353,[%r884+160]; cvt.s64.s32 %r338,%r922; shl.b64 %r337,%r338,3; add.u64 %r340,%r931,%r337; add.u32 %r889,%r369,-2; cvt.u64.u32 %r890,%r889; shl.b64 %r424,%r890,3; add.u64 %r891,%r929,%r337; sub.u64 %r421,%r891,%r424; neg.s64 %r893,%r338; shl.b64 %r894,%r893,3; add.u64 %r329,%r337,8; $L65: .loc 1 306 0 ld.f64 %r316,[%r340]; add.f64 %r371,%r316,%r353; .loc 1 307 0 add.u64 %r895,%r894,%r340; add.u64 %r896,%r895,%r329; sub.f64 %r897,%r316,%r371; add.f64 %r898,%r897,%r353; st.f64 [%r896],%r898; .loc 1 308 0 st.f64 [%r340],%r371; add.u64 %r340,%r340,-8; mov.f64 %r353,%r371; .loc 1 305 0 setp.ne.u64 %r899,%r340,%r421; @ %r899 bra $L65; add.u64 %r360,%r931,%r329; add.u64 %r901,%r929,%r329; sub.u64 %r343,%r901,%r424; .loc 1 310 0 mov.f64 %r370,0d0000000000000000; $L66: ld.f64 %r902,[%r360]; add.f64 %r370,%r370,%r902; add.u64 %r360,%r360,-8; setp.ne.u64 %r903,%r343,%r360; @ %r903 bra $L66; bra $L53; $L80: mov.f64 %r370,0d0000000000000000; $L53: ld.f64 %r422,[%frame+160]; ld.f64 %r423,[%frame+168]; .loc 1 311 0 setp.ne.u32 %r904,%r341,0; @ %r904 bra $L67; .loc 1 312 0 st.f64 [%r585],%r422; st.f64 [%r585+8],%r423; st.f64 [%r585+16],%r370; bra $L51; $L67: .loc 1 314 0 neg.f64 %r905,%r422; st.f64 [%r585],%r905; neg.f64 %r906,%r423; st.f64 [%r585+8],%r906; neg.f64 %r907,%r370; st.f64 [%r585+16],%r907; $L51: .loc 1 317 0 and.b32 %r908,%r330,7; bra $L116; $L16: .loc 1 217 0 add.u32 %r330,%r330,1; .loc 1 218 0 setp.gt.s32 %r909,%r307,0; @ %r909 bra $L81; .loc 1 235 0 mov.f64 %r910,0d3ff0000000000000; sub.f64 %r342,%r910,%r342; mov.u32 %r341,2; bra $L17; $L45: .loc 1 284 0 setp.gt.s32 %r911,%r588,2; @ %r911 bra $L69; setp.gt.s32 %r912,%r588,0; @ %r912 bra $L48; setp.eq.u32 %r913,%r588,0; @ %r913 bra $L56; bra $L51; $L69: setp.eq.u32 %r914,%r588,3; @ %r914 bra $L50; bra $L51; $L60: .loc 1 294 0 st.f64 [%r585],%r376; .loc 1 295 0 ld.f64 %r915,[%frame+160]; sub.f64 %r374,%r915,%r376; .loc 1 296 0 setp.gt.s32 %r916,%r369,0; @ %r916 bra $L70; bra $L63; $L116: .loc 1 318 0 mov.u32 %value,%r908; st.param.u32 [%value_out],%value; ret; } lib_a-k_sin.o/ 0 0 0 644 2103 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .visible .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libm/math/k_sin.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_sin .visible .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r31; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .u32 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; mov.f64 %r43,%ar0; mov.f64 %r44,%ar1; mov.u32 %r45,%ar2; .loc 1 68 0 mov.b64 %r46,%r43; shr.u64 %r47,%r46,32; cvt.u32.u64 %r31,%r47; .loc 1 69 0 and.b32 %r48,%r31,2147483647; .loc 1 70 0 setp.gt.s32 %r49,%r48,1044381695; @ %r49 bra $L2; .loc 1 71 0 cvt.rzi.s32.f64 %r50,%r43; setp.eq.u32 %r51,%r50,0; @ %r51 bra $L5; $L2: .loc 1 72 0 mul.f64 %r33,%r43,%r43; .loc 1 73 0 mul.f64 %r34,%r43,%r33; .loc 1 74 0 fma.rn.f64 %r52,%r33,0d3de5d93a5acfd57c,0dbe5ae5e68a2b9ceb; fma.rn.f64 %r53,%r52,%r33,0d3ec71de357b1fe7d; fma.rn.f64 %r54,%r53,%r33,0dbf2a01a019c161d5; fma.rn.f64 %r35,%r54,%r33,0d3f8111111110f8a6; .loc 1 75 0 setp.ne.u32 %r55,%r45,0; @ %r55 bra $L4; fma.rn.f64 %r56,%r33,%r35,0dbfc5555555555549; fma.rn.f64 %r42,%r56,%r34,%r43; bra $L1; $L4: .loc 1 76 0 mul.f64 %r57,%r34,%r35; neg.f64 %r58,%r57; fma.rn.f64 %r59,%r44,0d3fe0000000000000,%r58; neg.f64 %r60,%r44; fma.rn.f64 %r61,%r59,%r33,%r60; fma.rn.f64 %r62,%r34,0d3fc5555555555549,%r61; sub.f64 %r42,%r43,%r62; bra $L1; $L5: .loc 1 71 0 mov.f64 %r42,%r43; $L1: .loc 1 77 0 mov.f64 %value,%r42; st.param.f64 [%value_out],%value; ret; } /350 0 0 0 644 69738 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __kernel_standard .visible .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libm/math/k_standard.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {97,99,111,115,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {97,99,111,115,102,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[5] = {97,115,105,110,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[6] = {97,115,105,110,102,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[6] = {97,116,97,110,50,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[7] = {97,116,97,110,50,102,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[6] = {104,121,112,111,116,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[7] = {104,121,112,111,116,102,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[5] = {99,111,115,104,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[6] = {99,111,115,104,102,0 }; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[4] = {101,120,112,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[5] = {101,120,112,102,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[3] = {121,48,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[4] = {121,48,102,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[3] = {121,49,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[4] = {121,49,102,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[3] = {121,110,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[4] = {121,110,102,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[7] = {108,103,97,109,109,97,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[8] = {108,103,97,109,109,97,102,0 }; // BEGIN VAR DEF: $LC33 .const .align 1 .u8 $LC33[11] = {114,101,109,97,105,110,100,101,114,102,0 }; // BEGIN VAR DEF: $LC34 .const .align 1 .u8 $LC34[6] = {97,99,111,115,104,0 }; // BEGIN VAR DEF: $LC35 .const .align 1 .u8 $LC35[7] = {97,99,111,115,104,102,0 }; // BEGIN VAR DEF: $LC36 .const .align 1 .u8 $LC36[6] = {97,116,97,110,104,0 }; // BEGIN VAR DEF: $LC37 .const .align 1 .u8 $LC37[7] = {97,116,97,110,104,102,0 }; // BEGIN VAR DEF: $LC38 .const .align 1 .u8 $LC38[6] = {115,99,97,108,98,0 }; // BEGIN VAR DEF: $LC39 .const .align 1 .u8 $LC39[7] = {115,99,97,108,98,102,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[5] = {102,109,111,100,0 }; // BEGIN VAR DEF: $LC31 .const .align 1 .u8 $LC31[6] = {102,109,111,100,102,0 }; // BEGIN VAR DEF: $LC32 .const .align 1 .u8 $LC32[10] = {114,101,109,97,105,110,100,101,114,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[6] = {115,105,110,104,102,0 }; // BEGIN VAR DEF: $LC40 .const .align 1 .u8 $LC40[3] = {106,48,0 }; // BEGIN VAR DEF: $LC41 .const .align 1 .u8 $LC41[4] = {106,48,102,0 }; // BEGIN VAR DEF: $LC42 .const .align 1 .u8 $LC42[3] = {106,49,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[4] = {108,111,103,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[5] = {108,111,103,102,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[6] = {108,111,103,49,48,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[7] = {108,111,103,49,48,102,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[4] = {112,111,119,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[5] = {112,111,119,102,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[5] = {115,105,110,104,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[5] = {115,113,114,116,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[6] = {115,113,114,116,102,0 }; // BEGIN VAR DEF: $LC43 .const .align 1 .u8 $LC43[4] = {106,49,102,0 }; // BEGIN VAR DEF: $LC44 .const .align 1 .u8 $LC44[3] = {106,110,0 }; // BEGIN VAR DEF: $LC45 .const .align 1 .u8 $LC45[4] = {106,110,102,0 }; // BEGIN VAR DEF: $LC46 .const .align 1 .u8 $LC46[6] = {103,97,109,109,97,0 }; // BEGIN VAR DEF: $LC47 .const .align 1 .u8 $LC47[7] = {103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: __kernel_standard .visible .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u32 %r38; .reg .u32 %r42; .reg .u32 %r50; .reg .u32 %r54; .reg .u32 %r58; .reg .u32 %r62; .reg .u32 %r66; .reg .u32 %r70; .reg .u32 %r74; .reg .u32 %r78; .reg .u32 %r82; .reg .u32 %r86; .reg .u32 %r90; .reg .u32 %r94; .reg .u32 %r101; .reg .u32 %r111; .reg .u32 %r115; .reg .u32 %r120; .reg .u32 %r124; .reg .u32 %r129; .reg .u32 %r187; .reg .u32 %r191; .reg .u32 %r201; .reg .u64 %r202; .reg .u64 %r203; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u64 %r211; .reg .u64 %r212; .reg .u64 %r213; .reg .u64 %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .u64 %r217; .reg .u64 %r218; .reg .u64 %r219; .reg .u64 %r220; .reg .u64 %r221; .reg .u64 %r222; .reg .u64 %r223; .reg .u64 %r224; .reg .u64 %r225; .reg .u64 %r226; .reg .f64 %r227; .reg .f64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .f64 %r236; .reg .u64 %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u64 %r245; .reg .u64 %r246; .reg .u32 %r247; .reg .f64 %r248; .reg .u32 %r249; .reg .f64 %r250; .reg .f64 %r251; .reg .f64 %r252; .reg .u32 %r253; .reg .u32 %r254; .reg .pred %r255; .reg .pred %r256; .reg .pred %r257; .reg .pred %r258; .reg .pred %r259; .reg .pred %r260; .reg .pred %r261; .reg .pred %r262; .reg .pred %r263; .reg .pred %r264; .reg .pred %r265; .reg .pred %r266; .reg .pred %r267; .reg .pred %r268; .reg .pred %r269; .reg .pred %r270; .reg .pred %r271; .reg .pred %r272; .reg .pred %r273; .reg .pred %r274; .reg .pred %r275; .reg .pred %r276; .reg .pred %r277; .reg .pred %r278; .reg .pred %r279; .reg .pred %r280; .reg .pred %r281; .reg .pred %r282; .reg .pred %r283; .reg .pred %r284; .reg .pred %r285; .reg .pred %r286; .reg .pred %r287; .reg .pred %r288; .reg .pred %r289; .reg .pred %r290; .reg .pred %r291; .reg .pred %r292; .reg .pred %r293; .reg .pred %r294; .reg .pred %r295; .reg .pred %r296; .reg .pred %r297; .reg .pred %r298; .reg .pred %r299; .reg .pred %r300; .reg .pred %r301; .reg .pred %r302; .reg .pred %r303; .reg .pred %r304; .reg .pred %r305; .reg .pred %r306; .reg .pred %r307; .reg .pred %r308; .reg .pred %r309; .reg .pred %r310; .reg .pred %r311; .reg .pred %r312; .reg .pred %r313; .reg .pred %r314; .reg .pred %r315; .reg .pred %r316; .reg .pred %r317; .reg .pred %r318; .reg .pred %r319; .reg .pred %r320; .reg .pred %r321; .reg .pred %r322; .reg .pred %r323; .reg .pred %r324; .reg .pred %r325; .reg .pred %r326; .reg .pred %r327; .reg .pred %r328; .reg .pred %r329; .reg .pred %r330; .reg .pred %r331; .reg .pred %r332; .reg .pred %r333; .reg .pred %r334; .reg .pred %r335; .reg .pred %r336; .reg .pred %r337; .reg .pred %r338; .reg .pred %r339; .reg .pred %r340; .reg .pred %r341; .reg .pred %r342; .reg .pred %r343; .reg .pred %r344; .reg .pred %r345; .reg .pred %r346; .reg .pred %r347; .reg .pred %r348; .reg .pred %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .pred %r353; .reg .pred %r354; .reg .pred %r355; .reg .pred %r356; .reg .pred %r357; .reg .pred %r358; .reg .pred %r359; .reg .pred %r360; .reg .u32 %r361; .reg .pred %r362; .reg .f64 %r363; .reg .u32 %r364; .reg .pred %r365; .reg .u64 %r366; .reg .u32 %r367; .reg .u32 %r369; .reg .pred %r370; .reg .u64 %r371; .reg .u32 %r372; .reg .u32 %r373; .reg .pred %r374; .reg .f64 %r375; .reg .u32 %r376; .reg .pred %r377; .reg .u64 %r378; .reg .u32 %r379; .reg .u32 %r381; .reg .pred %r382; .reg .u64 %r383; .reg .u32 %r384; .reg .u32 %r385; .reg .pred %r386; .reg .f64 %r387; .reg .u32 %r388; .reg .pred %r389; .reg .u64 %r390; .reg .u32 %r391; .reg .u32 %r393; .reg .pred %r394; .reg .u64 %r395; .reg .u32 %r396; .reg .u32 %r397; .reg .pred %r398; .reg .pred %r399; .reg .f64 %r400; .reg .f64 %r401; .reg .pred %r402; .reg .u64 %r403; .reg .u32 %r404; .reg .u32 %r406; .reg .pred %r407; .reg .u64 %r408; .reg .u32 %r409; .reg .u32 %r410; .reg .pred %r411; .reg .pred %r412; .reg .f64 %r413; .reg .f64 %r414; .reg .pred %r415; .reg .u64 %r416; .reg .u32 %r417; .reg .u32 %r419; .reg .pred %r420; .reg .u64 %r421; .reg .u32 %r422; .reg .u32 %r423; .reg .pred %r424; .reg .pred %r425; .reg .f64 %r426; .reg .f64 %r427; .reg .pred %r428; .reg .u64 %r429; .reg .u32 %r430; .reg .u32 %r432; .reg .pred %r433; .reg .u64 %r434; .reg .u32 %r435; .reg .u32 %r436; .reg .pred %r437; .reg .f64 %r438; .reg .u32 %r439; .reg .pred %r440; .reg .u64 %r441; .reg .u32 %r442; .reg .u32 %r444; .reg .pred %r445; .reg .u64 %r446; .reg .u32 %r447; .reg .u32 %r448; .reg .pred %r449; .reg .pred %r450; .reg .f64 %r451; .reg .f64 %r452; .reg .pred %r453; .reg .u64 %r454; .reg .u32 %r455; .reg .u32 %r457; .reg .pred %r458; .reg .u64 %r459; .reg .u32 %r460; .reg .u32 %r461; .reg .pred %r462; .reg .pred %r463; .reg .f64 %r464; .reg .f64 %r465; .reg .pred %r466; .reg .u64 %r467; .reg .u32 %r468; .reg .u32 %r470; .reg .pred %r471; .reg .u64 %r472; .reg .u32 %r473; .reg .u32 %r474; .reg .pred %r475; .reg .pred %r476; .reg .f64 %r477; .reg .f64 %r478; .reg .pred %r479; .reg .u64 %r480; .reg .u32 %r481; .reg .u32 %r483; .reg .pred %r484; .reg .u64 %r485; .reg .u32 %r486; .reg .u32 %r487; .reg .pred %r488; .reg .pred %r489; .reg .f64 %r490; .reg .f64 %r491; .reg .pred %r492; .reg .u64 %r493; .reg .u32 %r494; .reg .u32 %r496; .reg .pred %r497; .reg .u64 %r498; .reg .u32 %r499; .reg .u32 %r500; .reg .pred %r501; .reg .pred %r502; .reg .f64 %r503; .reg .f64 %r504; .reg .pred %r505; .reg .u64 %r506; .reg .u32 %r507; .reg .u32 %r509; .reg .pred %r510; .reg .u64 %r511; .reg .u32 %r512; .reg .u32 %r513; .reg .pred %r514; .reg .pred %r515; .reg .f64 %r516; .reg .f64 %r517; .reg .pred %r518; .reg .u64 %r519; .reg .u32 %r520; .reg .u32 %r522; .reg .pred %r523; .reg .u64 %r524; .reg .u32 %r525; .reg .u32 %r526; .reg .pred %r527; .reg .pred %r528; .reg .f64 %r529; .reg .f64 %r530; .reg .pred %r531; .reg .u64 %r532; .reg .u32 %r533; .reg .u32 %r535; .reg .pred %r536; .reg .u64 %r537; .reg .u32 %r538; .reg .u32 %r539; .reg .pred %r540; .reg .pred %r541; .reg .f64 %r542; .reg .f64 %r543; .reg .pred %r544; .reg .u64 %r545; .reg .u32 %r546; .reg .u32 %r548; .reg .pred %r549; .reg .u64 %r550; .reg .u32 %r551; .reg .u32 %r552; .reg .pred %r553; .reg .pred %r554; .reg .f64 %r555; .reg .f64 %r556; .reg .pred %r557; .reg .u64 %r558; .reg .u32 %r559; .reg .u32 %r561; .reg .pred %r562; .reg .u64 %r563; .reg .u32 %r564; .reg .u32 %r565; .reg .pred %r566; .reg .pred %r567; .reg .f64 %r568; .reg .f64 %r569; .reg .pred %r570; .reg .u64 %r571; .reg .u32 %r572; .reg .u32 %r574; .reg .pred %r575; .reg .u64 %r576; .reg .u32 %r577; .reg .u32 %r578; .reg .pred %r579; .reg .pred %r580; .reg .f64 %r581; .reg .f64 %r582; .reg .pred %r583; .reg .u64 %r584; .reg .u32 %r585; .reg .u32 %r587; .reg .pred %r588; .reg .u64 %r589; .reg .u32 %r590; .reg .u32 %r591; .reg .pred %r592; .reg .pred %r593; .reg .f64 %r594; .reg .f64 %r595; .reg .pred %r596; .reg .u64 %r597; .reg .u32 %r598; .reg .u32 %r600; .reg .pred %r601; .reg .u64 %r602; .reg .u32 %r603; .reg .u32 %r604; .reg .pred %r605; .reg .f64 %r606; .reg .u32 %r607; .reg .pred %r608; .reg .u32 %r610; .reg .pred %r611; .reg .u64 %r612; .reg .u32 %r613; .reg .u32 %r614; .reg .pred %r615; .reg .pred %r616; .reg .f64 %r617; .reg .pred %r618; .reg .f64 %r620; .reg .pred %r621; .reg .f64 %r622; .reg .f64 %r623; .reg .pred %r624; .reg .f64 %r626; .reg .pred %r627; .reg .f64 %r628; .reg .pred %r629; .reg .u64 %r630; .reg .u32 %r631; .reg .u32 %r633; .reg .pred %r634; .reg .u64 %r635; .reg .u32 %r636; .reg .u32 %r637; .reg .pred %r638; .reg .f64 %r639; .reg .u32 %r640; .reg .pred %r641; .reg .u64 %r642; .reg .u32 %r643; .reg .u32 %r645; .reg .pred %r646; .reg .u64 %r647; .reg .u32 %r648; .reg .u32 %r649; .reg .pred %r650; .reg .pred %r651; .reg .f64 %r652; .reg .f64 %r653; .reg .pred %r654; .reg .u64 %r655; .reg .u32 %r656; .reg .u32 %r658; .reg .pred %r659; .reg .u64 %r660; .reg .u32 %r661; .reg .u32 %r662; .reg .pred %r663; .reg .pred %r664; .reg .f64 %r665; .reg .f64 %r666; .reg .f64 %r667; .reg .pred %r668; .reg .u64 %r669; .reg .u32 %r670; .reg .u32 %r672; .reg .pred %r673; .reg .u64 %r674; .reg .u32 %r675; .reg .u32 %r676; .reg .pred %r677; .reg .pred %r678; .reg .pred %r679; .reg .pred %r680; .reg .pred %r681; .reg .u64 %r682; .reg .u32 %r683; .reg .u32 %r685; .reg .pred %r686; .reg .u64 %r687; .reg .u32 %r688; .reg .u32 %r689; .reg .pred %r690; .reg .pred %r691; .reg .f64 %r692; .reg .f64 %r693; .reg .f64 %r694; .reg .pred %r695; .reg .u64 %r696; .reg .u32 %r697; .reg .u32 %r699; .reg .pred %r700; .reg .u64 %r701; .reg .u32 %r702; .reg .u32 %r703; .reg .pred %r704; .reg .pred %r705; .reg .f64 %r706; .reg .f64 %r707; .reg .pred %r708; .reg .u64 %r709; .reg .u32 %r710; .reg .u32 %r712; .reg .pred %r713; .reg .u64 %r714; .reg .u32 %r715; .reg .u32 %r716; .reg .pred %r717; .reg .f64 %r718; .reg .f64 %r719; .reg .u32 %r720; .reg .pred %r721; .reg .u64 %r722; .reg .u32 %r723; .reg .u32 %r725; .reg .pred %r726; .reg .u64 %r727; .reg .u32 %r728; .reg .u32 %r729; .reg .pred %r730; .reg .f64 %r731; .reg .f64 %r732; .reg .u32 %r733; .reg .pred %r734; .reg .u64 %r735; .reg .u32 %r736; .reg .u32 %r738; .reg .pred %r739; .reg .u64 %r740; .reg .u32 %r741; .reg .u32 %r742; .reg .pred %r743; .reg .f64 %r744; .reg .f64 %r745; .reg .u32 %r746; .reg .pred %r747; .reg .u64 %r748; .reg .u32 %r749; .reg .u32 %r751; .reg .pred %r752; .reg .u64 %r753; .reg .u32 %r754; .reg .u32 %r755; .reg .pred %r756; .reg .f64 %r757; .reg .u32 %r758; .reg .pred %r759; .reg .u64 %r760; .reg .u32 %r761; .reg .u32 %r763; .reg .pred %r764; .reg .u64 %r765; .reg .u32 %r766; .reg .u32 %r767; .reg .pred %r768; .reg .pred %r769; .reg .u32 %r770; .reg .pred %r771; .reg .u64 %r772; .reg .u32 %r773; .reg .u32 %r775; .reg .pred %r776; .reg .u64 %r777; .reg .u32 %r778; .reg .u32 %r779; .reg .pred %r780; .reg .f64 %r781; .reg .f64 %r783; .reg .u32 %r784; .reg .pred %r785; .reg .u64 %r786; .reg .u32 %r787; .reg .u32 %r789; .reg .pred %r790; .reg .u64 %r791; .reg .u32 %r792; .reg .u32 %r793; .reg .pred %r794; .reg .f64 %r795; .reg .u32 %r796; .reg .pred %r797; .reg .u64 %r798; .reg .u32 %r799; .reg .u32 %r801; .reg .pred %r802; .reg .u64 %r803; .reg .u32 %r804; .reg .u32 %r805; .reg .pred %r806; .reg .f64 %r807; .reg .u32 %r808; .reg .pred %r809; .reg .u64 %r810; .reg .u32 %r811; .reg .u32 %r813; .reg .pred %r814; .reg .u64 %r815; .reg .u32 %r816; .reg .u32 %r817; .reg .pred %r818; .reg .f64 %r819; .reg .u32 %r820; .reg .pred %r821; .reg .u64 %r822; .reg .u32 %r823; .reg .u32 %r825; .reg .pred %r826; .reg .u64 %r827; .reg .u32 %r828; .reg .u32 %r829; .reg .pred %r830; .reg .f64 %r831; .reg .u32 %r832; .reg .pred %r833; .reg .u64 %r834; .reg .u32 %r835; .reg .u32 %r837; .reg .pred %r838; .reg .u64 %r839; .reg .u32 %r840; .reg .u32 %r841; .reg .pred %r842; .reg .f64 %r843; .reg .u32 %r844; .reg .pred %r845; .reg .u64 %r846; .reg .u32 %r847; .reg .u32 %r849; .reg .pred %r850; .reg .u64 %r851; .reg .u32 %r852; .reg .u32 %r853; .reg .pred %r854; .reg .f64 %r855; .reg .u32 %r856; .reg .pred %r857; .reg .u64 %r858; .reg .u32 %r859; .reg .u32 %r861; .reg .pred %r862; .reg .u64 %r863; .reg .u32 %r864; .reg .u32 %r865; .reg .pred %r866; .reg .pred %r867; .reg .f64 %r868; .reg .f64 %r869; .reg .pred %r870; .reg .u64 %r871; .reg .u32 %r872; .reg .u32 %r874; .reg .pred %r875; .reg .u64 %r876; .reg .u32 %r877; .reg .u32 %r878; .reg .pred %r879; .reg .pred %r880; .reg .f64 %r881; .reg .f64 %r882; .reg .pred %r883; .reg .u64 %r884; .reg .u32 %r885; .reg .u32 %r887; .reg .pred %r888; .reg .u64 %r889; .reg .u32 %r890; .reg .u32 %r891; .reg .pred %r892; .reg .u32 %r894; .reg .u32 %r895; .reg .u32 %r897; .reg .u32 %r898; .reg .u16 %r899; .reg .u16 %r900; .reg .u16 %r901; .reg .u32 %r902; .reg .u16 %r903; .reg .pred %r904; .reg .u32 %r906; .reg .pred %r907; .reg .u64 %r908; .reg .u32 %r909; .reg .pred %r910; .reg .u64 %r911; mov.f64 %r251,%ar0; mov.f64 %r252,%ar1; mov.u32 %r253,%ar2; .loc 1 99 0 st.f64 [%frame+16],%r251; .loc 1 100 0 st.f64 [%frame+24],%r252; .loc 1 101 0 mov.u32 %r254,0; st.u32 [%frame+40],%r254; .loc 1 102 0 setp.eq.u32 %r255,%r253,42; @ %r255 bra $L3; setp.gt.s32 %r256,%r253,42; @ %r256 bra $L4; setp.eq.u32 %r257,%r253,21; @ %r257 bra $L5; setp.gt.s32 %r258,%r253,21; @ %r258 bra $L6; setp.eq.u32 %r259,%r253,10; @ %r259 bra $L7; setp.gt.s32 %r260,%r253,10; @ %r260 bra $L8; setp.eq.u32 %r261,%r253,5; @ %r261 bra $L9; setp.gt.s32 %r262,%r253,5; @ %r262 bra $L10; setp.eq.u32 %r263,%r253,2; @ %r263 bra $L11; setp.gt.s32 %r264,%r253,2; @ %r264 bra $L12; setp.eq.u32 %r265,%r253,1; @ %r265 bra $L13; bra $L505; $L12: setp.eq.u32 %r266,%r253,3; @ %r266 bra $L14; setp.eq.u32 %r267,%r253,4; @ %r267 bra $L15; bra $L505; $L10: setp.eq.u32 %r268,%r253,7; @ %r268 bra $L16; setp.lt.s32 %r269,%r253,7; @ %r269 bra $L17; setp.eq.u32 %r270,%r253,8; @ %r270 bra $L18; setp.eq.u32 %r271,%r253,9; @ %r271 bra $L19; bra $L505; $L8: setp.eq.u32 %r272,%r253,15; @ %r272 bra $L20; setp.gt.s32 %r273,%r253,15; @ %r273 bra $L21; setp.eq.u32 %r274,%r253,12; @ %r274 bra $L22; setp.lt.s32 %r275,%r253,12; @ %r275 bra $L23; setp.eq.u32 %r276,%r253,13; @ %r276 bra $L24; setp.eq.u32 %r277,%r253,14; @ %r277 bra $L25; bra $L505; $L21: setp.eq.u32 %r278,%r253,18; @ %r278 bra $L26; setp.gt.s32 %r279,%r253,18; @ %r279 bra $L27; setp.eq.u32 %r280,%r253,16; @ %r280 bra $L28; setp.eq.u32 %r281,%r253,17; @ %r281 bra $L29; bra $L505; $L27: setp.eq.u32 %r282,%r253,19; @ %r282 bra $L30; setp.eq.u32 %r283,%r253,20; @ %r283 bra $L31; bra $L505; $L6: setp.eq.u32 %r284,%r253,31; @ %r284 bra $L32; setp.gt.s32 %r285,%r253,31; @ %r285 bra $L33; setp.eq.u32 %r286,%r253,26; @ %r286 bra $L34; setp.gt.s32 %r287,%r253,26; @ %r287 bra $L35; setp.eq.u32 %r288,%r253,23; @ %r288 bra $L36; setp.lt.s32 %r289,%r253,23; @ %r289 bra $L37; setp.eq.u32 %r290,%r253,24; @ %r290 bra $L38; setp.eq.u32 %r291,%r253,25; @ %r291 bra $L39; bra $L505; $L35: setp.eq.u32 %r292,%r253,28; @ %r292 bra $L40; setp.lt.s32 %r293,%r253,28; @ %r293 bra $L41; setp.eq.u32 %r294,%r253,29; @ %r294 bra $L42; setp.eq.u32 %r295,%r253,30; @ %r295 bra $L43; bra $L505; $L33: setp.eq.u32 %r296,%r253,36; @ %r296 bra $L44; setp.gt.s32 %r297,%r253,36; @ %r297 bra $L45; setp.eq.u32 %r298,%r253,33; @ %r298 bra $L46; setp.lt.s32 %r299,%r253,33; @ %r299 bra $L47; setp.eq.u32 %r300,%r253,34; @ %r300 bra $L48; setp.eq.u32 %r301,%r253,35; @ %r301 bra $L49; bra $L505; $L45: setp.eq.u32 %r302,%r253,39; @ %r302 bra $L50; setp.gt.s32 %r303,%r253,39; @ %r303 bra $L51; setp.eq.u32 %r304,%r253,37; @ %r304 bra $L52; setp.eq.u32 %r305,%r253,38; @ %r305 bra $L53; bra $L505; $L51: setp.eq.u32 %r306,%r253,40; @ %r306 bra $L54; setp.eq.u32 %r307,%r253,41; @ %r307 bra $L55; bra $L505; $L4: setp.eq.u32 %r308,%r253,121; @ %r308 bra $L5; setp.gt.s32 %r309,%r253,121; @ %r309 bra $L56; setp.eq.u32 %r310,%r253,110; @ %r310 bra $L7; setp.gt.s32 %r311,%r253,110; @ %r311 bra $L57; setp.eq.u32 %r312,%r253,105; @ %r312 bra $L9; setp.gt.s32 %r313,%r253,105; @ %r313 bra $L58; setp.eq.u32 %r314,%r253,102; @ %r314 bra $L11; setp.gt.s32 %r315,%r253,102; @ %r315 bra $L59; setp.eq.u32 %r316,%r253,101; @ %r316 bra $L13; bra $L505; $L59: setp.eq.u32 %r317,%r253,103; @ %r317 bra $L14; setp.eq.u32 %r318,%r253,104; @ %r318 bra $L15; bra $L505; $L58: setp.eq.u32 %r319,%r253,107; @ %r319 bra $L16; setp.lt.s32 %r320,%r253,107; @ %r320 bra $L17; setp.eq.u32 %r321,%r253,108; @ %r321 bra $L18; setp.eq.u32 %r322,%r253,109; @ %r322 bra $L19; bra $L505; $L57: setp.eq.u32 %r323,%r253,115; @ %r323 bra $L20; setp.gt.s32 %r324,%r253,115; @ %r324 bra $L60; setp.eq.u32 %r325,%r253,112; @ %r325 bra $L22; setp.lt.s32 %r326,%r253,112; @ %r326 bra $L23; setp.eq.u32 %r327,%r253,113; @ %r327 bra $L24; setp.eq.u32 %r328,%r253,114; @ %r328 bra $L25; bra $L505; $L60: setp.eq.u32 %r329,%r253,118; @ %r329 bra $L26; setp.gt.s32 %r330,%r253,118; @ %r330 bra $L61; setp.eq.u32 %r331,%r253,116; @ %r331 bra $L28; setp.eq.u32 %r332,%r253,117; @ %r332 bra $L29; bra $L505; $L61: setp.eq.u32 %r333,%r253,119; @ %r333 bra $L30; setp.eq.u32 %r334,%r253,120; @ %r334 bra $L31; bra $L505; $L56: setp.eq.u32 %r335,%r253,132; @ %r335 bra $L47; setp.gt.s32 %r336,%r253,132; @ %r336 bra $L62; setp.eq.u32 %r337,%r253,126; @ %r337 bra $L34; setp.gt.s32 %r338,%r253,126; @ %r338 bra $L63; setp.eq.u32 %r339,%r253,123; @ %r339 bra $L36; setp.lt.s32 %r340,%r253,123; @ %r340 bra $L37; setp.eq.u32 %r341,%r253,124; @ %r341 bra $L38; setp.eq.u32 %r342,%r253,125; @ %r342 bra $L39; bra $L505; $L63: setp.eq.u32 %r343,%r253,129; @ %r343 bra $L42; setp.gt.s32 %r344,%r253,129; @ %r344 bra $L64; setp.eq.u32 %r345,%r253,127; @ %r345 bra $L41; setp.eq.u32 %r346,%r253,128; @ %r346 bra $L40; bra $L505; $L64: setp.eq.u32 %r347,%r253,130; @ %r347 bra $L43; setp.eq.u32 %r348,%r253,131; @ %r348 bra $L32; bra $L505; $L62: setp.eq.u32 %r349,%r253,137; @ %r349 bra $L52; setp.gt.s32 %r350,%r253,137; @ %r350 bra $L65; setp.eq.u32 %r351,%r253,134; @ %r351 bra $L48; setp.lt.s32 %r352,%r253,134; @ %r352 bra $L46; setp.eq.u32 %r353,%r253,135; @ %r353 bra $L49; setp.eq.u32 %r354,%r253,136; @ %r354 bra $L44; bra $L505; $L65: setp.eq.u32 %r355,%r253,140; @ %r355 bra $L54; setp.gt.s32 %r356,%r253,140; @ %r356 bra $L66; setp.eq.u32 %r357,%r253,138; @ %r357 bra $L53; setp.eq.u32 %r358,%r253,139; @ %r358 bra $L50; bra $L505; $L66: setp.eq.u32 %r359,%r253,141; @ %r359 bra $L55; setp.eq.u32 %r360,%r253,142; @ %r360 bra $L3; bra $L505; $L13: .loc 1 106 0 mov.u32 %r361,1; st.u32 [%frame],%r361; .loc 1 107 0 setp.gt.s32 %r362,%r253,99; @ %r362 bra $L230; cvta.const.u64 %r202,$LC0; bra $L67; $L230: cvta.const.u64 %r202,$LC1; $L67: st.u64 [%frame+8],%r202; .loc 1 108 0 mov.f64 %r363,0d0000000000000000; st.f64 [%frame+32],%r363; .loc 1 109 0 ld.global.u32 %r364,[__fdlib_version]; setp.ne.u32 %r365,%r364,2; @ %r365 bra $L68; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r366,[%value_in]; } mov.u32 %r367,33; st.u32 [%r366],%r367; ld.u32 %r249,[%frame+40]; bra $L2; $L68: .loc 1 111 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r369,[%value_in]; } setp.eq.u32 %r370,%r369,0; @ %r370 bra $L69; ld.u32 %r249,[%frame+40]; bra $L2; $L69: .loc 1 115 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r371,[%value_in]; } mov.u32 %r372,33; st.u32 [%r371],%r372; ld.u32 %r249,[%frame+40]; bra $L2; $L11: .loc 1 121 0 mov.u32 %r373,1; st.u32 [%frame],%r373; .loc 1 122 0 setp.gt.s32 %r374,%r253,99; @ %r374 bra $L231; cvta.const.u64 %r203,$LC2; bra $L70; $L231: cvta.const.u64 %r203,$LC3; $L70: st.u64 [%frame+8],%r203; .loc 1 123 0 mov.f64 %r375,0d0000000000000000; st.f64 [%frame+32],%r375; .loc 1 124 0 ld.global.u32 %r376,[__fdlib_version]; setp.ne.u32 %r377,%r376,2; @ %r377 bra $L71; .loc 1 125 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r378,[%value_in]; } mov.u32 %r379,33; st.u32 [%r378],%r379; ld.u32 %r249,[%frame+40]; bra $L2; $L71: .loc 1 126 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r381,[%value_in]; } setp.eq.u32 %r382,%r381,0; @ %r382 bra $L72; ld.u32 %r249,[%frame+40]; bra $L2; $L72: .loc 1 130 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r383,[%value_in]; } mov.u32 %r384,33; st.u32 [%r383],%r384; ld.u32 %r249,[%frame+40]; bra $L2; $L14: .loc 1 136 0 st.f64 [%frame+16],%r252; .loc 1 137 0 st.f64 [%frame+24],%r251; .loc 1 138 0 mov.u32 %r385,1; st.u32 [%frame],%r385; .loc 1 139 0 setp.gt.s32 %r386,%r253,99; @ %r386 bra $L232; cvta.const.u64 %r204,$LC4; bra $L73; $L232: cvta.const.u64 %r204,$LC5; $L73: st.u64 [%frame+8],%r204; .loc 1 140 0 mov.f64 %r387,0d0000000000000000; st.f64 [%frame+32],%r387; .loc 1 141 0 ld.global.u32 %r388,[__fdlib_version]; setp.ne.u32 %r389,%r388,2; @ %r389 bra $L74; .loc 1 142 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r390,[%value_in]; } mov.u32 %r391,33; st.u32 [%r390],%r391; ld.u32 %r249,[%frame+40]; bra $L2; $L74: .loc 1 143 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r393,[%value_in]; } setp.eq.u32 %r394,%r393,0; @ %r394 bra $L75; ld.u32 %r249,[%frame+40]; bra $L2; $L75: .loc 1 147 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r395,[%value_in]; } mov.u32 %r396,33; st.u32 [%r395],%r396; ld.u32 %r249,[%frame+40]; bra $L2; $L15: .loc 1 153 0 mov.u32 %r397,3; st.u32 [%frame],%r397; .loc 1 154 0 setp.gt.s32 %r398,%r253,99; @ %r398 bra $L233; cvta.const.u64 %r205,$LC6; bra $L76; $L233: cvta.const.u64 %r205,$LC7; $L76: st.u64 [%frame+8],%r205; .loc 1 155 0 ld.global.u32 %r34,[__fdlib_version]; setp.ne.u32 %r399,%r34,0; @ %r399 bra $L77; .loc 1 156 0 mov.f64 %r400,0d47efffffe0000000; st.f64 [%frame+32],%r400; bra $L78; $L77: .loc 1 158 0 mov.f64 %r401,0d7ff0000000000000; st.f64 [%frame+32],%r401; .loc 1 159 0 setp.ne.u32 %r402,%r34,2; @ %r402 bra $L78; .loc 1 160 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r403,[%value_in]; } mov.u32 %r404,34; st.u32 [%r403],%r404; ld.u32 %r249,[%frame+40]; bra $L2; $L78: .loc 1 161 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r406,[%value_in]; } setp.eq.u32 %r407,%r406,0; @ %r407 bra $L79; ld.u32 %r249,[%frame+40]; bra $L2; $L79: .loc 1 162 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r408,[%value_in]; } mov.u32 %r409,34; st.u32 [%r408],%r409; ld.u32 %r249,[%frame+40]; bra $L2; $L9: .loc 1 168 0 mov.u32 %r410,3; st.u32 [%frame],%r410; .loc 1 169 0 setp.gt.s32 %r411,%r253,99; @ %r411 bra $L234; cvta.const.u64 %r206,$LC8; bra $L80; $L234: cvta.const.u64 %r206,$LC9; $L80: st.u64 [%frame+8],%r206; .loc 1 170 0 ld.global.u32 %r38,[__fdlib_version]; setp.ne.u32 %r412,%r38,0; @ %r412 bra $L81; .loc 1 171 0 mov.f64 %r413,0d47efffffe0000000; st.f64 [%frame+32],%r413; bra $L82; $L81: .loc 1 173 0 mov.f64 %r414,0d7ff0000000000000; st.f64 [%frame+32],%r414; .loc 1 174 0 setp.ne.u32 %r415,%r38,2; @ %r415 bra $L82; .loc 1 175 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r416,[%value_in]; } mov.u32 %r417,34; st.u32 [%r416],%r417; ld.u32 %r249,[%frame+40]; bra $L2; $L82: .loc 1 176 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r419,[%value_in]; } setp.eq.u32 %r420,%r419,0; @ %r420 bra $L83; ld.u32 %r249,[%frame+40]; bra $L2; $L83: .loc 1 177 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r421,[%value_in]; } mov.u32 %r422,34; st.u32 [%r421],%r422; ld.u32 %r249,[%frame+40]; bra $L2; $L17: .loc 1 183 0 mov.u32 %r423,3; st.u32 [%frame],%r423; .loc 1 184 0 setp.gt.s32 %r424,%r253,99; @ %r424 bra $L235; cvta.const.u64 %r207,$LC10; bra $L84; $L235: cvta.const.u64 %r207,$LC11; $L84: st.u64 [%frame+8],%r207; .loc 1 185 0 ld.global.u32 %r42,[__fdlib_version]; setp.ne.u32 %r425,%r42,0; @ %r425 bra $L85; .loc 1 186 0 mov.f64 %r426,0d47efffffe0000000; st.f64 [%frame+32],%r426; bra $L86; $L85: .loc 1 188 0 mov.f64 %r427,0d7ff0000000000000; st.f64 [%frame+32],%r427; .loc 1 189 0 setp.ne.u32 %r428,%r42,2; @ %r428 bra $L86; .loc 1 190 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r429,[%value_in]; } mov.u32 %r430,34; st.u32 [%r429],%r430; ld.u32 %r249,[%frame+40]; bra $L2; $L86: .loc 1 191 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r432,[%value_in]; } setp.eq.u32 %r433,%r432,0; @ %r433 bra $L87; ld.u32 %r249,[%frame+40]; bra $L2; $L87: .loc 1 192 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r434,[%value_in]; } mov.u32 %r435,34; st.u32 [%r434],%r435; ld.u32 %r249,[%frame+40]; bra $L2; $L16: .loc 1 198 0 mov.u32 %r436,4; st.u32 [%frame],%r436; .loc 1 199 0 setp.gt.s32 %r437,%r253,99; @ %r437 bra $L236; cvta.const.u64 %r208,$LC10; bra $L88; $L236: cvta.const.u64 %r208,$LC11; $L88: st.u64 [%frame+8],%r208; .loc 1 200 0 mov.f64 %r438,0d0000000000000000; st.f64 [%frame+32],%r438; .loc 1 201 0 ld.global.u32 %r439,[__fdlib_version]; setp.ne.u32 %r440,%r439,2; @ %r440 bra $L89; .loc 1 202 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r441,[%value_in]; } mov.u32 %r442,34; st.u32 [%r441],%r442; ld.u32 %r249,[%frame+40]; bra $L2; $L89: .loc 1 203 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r444,[%value_in]; } setp.eq.u32 %r445,%r444,0; @ %r445 bra $L90; ld.u32 %r249,[%frame+40]; bra $L2; $L90: .loc 1 204 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r446,[%value_in]; } mov.u32 %r447,34; st.u32 [%r446],%r447; ld.u32 %r249,[%frame+40]; bra $L2; $L18: .loc 1 210 0 mov.u32 %r448,1; st.u32 [%frame],%r448; .loc 1 211 0 setp.gt.s32 %r449,%r253,99; @ %r449 bra $L237; cvta.const.u64 %r209,$LC12; bra $L91; $L237: cvta.const.u64 %r209,$LC13; $L91: st.u64 [%frame+8],%r209; .loc 1 212 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r450,%r50,0; @ %r450 bra $L92; .loc 1 213 0 mov.f64 %r451,0dc7efffffe0000000; st.f64 [%frame+32],%r451; bra $L93; $L92: .loc 1 215 0 mov.f64 %r452,0dfff0000000000000; st.f64 [%frame+32],%r452; .loc 1 216 0 setp.ne.u32 %r453,%r50,2; @ %r453 bra $L93; .loc 1 217 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r454,[%value_in]; } mov.u32 %r455,33; st.u32 [%r454],%r455; ld.u32 %r249,[%frame+40]; bra $L2; $L93: .loc 1 218 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r457,[%value_in]; } setp.eq.u32 %r458,%r457,0; @ %r458 bra $L94; ld.u32 %r249,[%frame+40]; bra $L2; $L94: .loc 1 222 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r459,[%value_in]; } mov.u32 %r460,33; st.u32 [%r459],%r460; ld.u32 %r249,[%frame+40]; bra $L2; $L19: .loc 1 228 0 mov.u32 %r461,1; st.u32 [%frame],%r461; .loc 1 229 0 setp.gt.s32 %r462,%r253,99; @ %r462 bra $L238; cvta.const.u64 %r210,$LC12; bra $L95; $L238: cvta.const.u64 %r210,$LC13; $L95: st.u64 [%frame+8],%r210; .loc 1 230 0 ld.global.u32 %r54,[__fdlib_version]; setp.ne.u32 %r463,%r54,0; @ %r463 bra $L96; .loc 1 231 0 mov.f64 %r464,0dc7efffffe0000000; st.f64 [%frame+32],%r464; bra $L97; $L96: .loc 1 233 0 mov.f64 %r465,0dfff0000000000000; st.f64 [%frame+32],%r465; .loc 1 234 0 setp.ne.u32 %r466,%r54,2; @ %r466 bra $L97; .loc 1 235 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r467,[%value_in]; } mov.u32 %r468,33; st.u32 [%r467],%r468; ld.u32 %r249,[%frame+40]; bra $L2; $L97: .loc 1 236 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r470,[%value_in]; } setp.eq.u32 %r471,%r470,0; @ %r471 bra $L98; ld.u32 %r249,[%frame+40]; bra $L2; $L98: .loc 1 240 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r472,[%value_in]; } mov.u32 %r473,33; st.u32 [%r472],%r473; ld.u32 %r249,[%frame+40]; bra $L2; $L7: .loc 1 246 0 mov.u32 %r474,1; st.u32 [%frame],%r474; .loc 1 247 0 setp.gt.s32 %r475,%r253,99; @ %r475 bra $L239; cvta.const.u64 %r211,$LC14; bra $L99; $L239: cvta.const.u64 %r211,$LC15; $L99: st.u64 [%frame+8],%r211; .loc 1 248 0 ld.global.u32 %r58,[__fdlib_version]; setp.ne.u32 %r476,%r58,0; @ %r476 bra $L100; .loc 1 249 0 mov.f64 %r477,0dc7efffffe0000000; st.f64 [%frame+32],%r477; bra $L101; $L100: .loc 1 251 0 mov.f64 %r478,0dfff0000000000000; st.f64 [%frame+32],%r478; .loc 1 252 0 setp.ne.u32 %r479,%r58,2; @ %r479 bra $L101; .loc 1 253 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r480,[%value_in]; } mov.u32 %r481,33; st.u32 [%r480],%r481; ld.u32 %r249,[%frame+40]; bra $L2; $L101: .loc 1 254 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r483,[%value_in]; } setp.eq.u32 %r484,%r483,0; @ %r484 bra $L102; ld.u32 %r249,[%frame+40]; bra $L2; $L102: .loc 1 258 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r485,[%value_in]; } mov.u32 %r486,33; st.u32 [%r485],%r486; ld.u32 %r249,[%frame+40]; bra $L2; $L23: .loc 1 264 0 mov.u32 %r487,1; st.u32 [%frame],%r487; .loc 1 265 0 setp.gt.s32 %r488,%r253,99; @ %r488 bra $L240; cvta.const.u64 %r212,$LC14; bra $L103; $L240: cvta.const.u64 %r212,$LC15; $L103: st.u64 [%frame+8],%r212; .loc 1 266 0 ld.global.u32 %r62,[__fdlib_version]; setp.ne.u32 %r489,%r62,0; @ %r489 bra $L104; .loc 1 267 0 mov.f64 %r490,0dc7efffffe0000000; st.f64 [%frame+32],%r490; bra $L105; $L104: .loc 1 269 0 mov.f64 %r491,0dfff0000000000000; st.f64 [%frame+32],%r491; .loc 1 270 0 setp.ne.u32 %r492,%r62,2; @ %r492 bra $L105; .loc 1 271 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r493,[%value_in]; } mov.u32 %r494,33; st.u32 [%r493],%r494; ld.u32 %r249,[%frame+40]; bra $L2; $L105: .loc 1 272 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r496,[%value_in]; } setp.eq.u32 %r497,%r496,0; @ %r497 bra $L106; ld.u32 %r249,[%frame+40]; bra $L2; $L106: .loc 1 276 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r498,[%value_in]; } mov.u32 %r499,33; st.u32 [%r498],%r499; ld.u32 %r249,[%frame+40]; bra $L2; $L22: .loc 1 282 0 mov.u32 %r500,1; st.u32 [%frame],%r500; .loc 1 283 0 setp.gt.s32 %r501,%r253,99; @ %r501 bra $L241; cvta.const.u64 %r213,$LC16; bra $L107; $L241: cvta.const.u64 %r213,$LC17; $L107: st.u64 [%frame+8],%r213; .loc 1 284 0 ld.global.u32 %r66,[__fdlib_version]; setp.ne.u32 %r502,%r66,0; @ %r502 bra $L108; .loc 1 285 0 mov.f64 %r503,0dc7efffffe0000000; st.f64 [%frame+32],%r503; bra $L109; $L108: .loc 1 287 0 mov.f64 %r504,0dfff0000000000000; st.f64 [%frame+32],%r504; .loc 1 288 0 setp.ne.u32 %r505,%r66,2; @ %r505 bra $L109; .loc 1 289 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r506,[%value_in]; } mov.u32 %r507,33; st.u32 [%r506],%r507; ld.u32 %r249,[%frame+40]; bra $L2; $L109: .loc 1 290 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r509,[%value_in]; } setp.eq.u32 %r510,%r509,0; @ %r510 bra $L110; ld.u32 %r249,[%frame+40]; bra $L2; $L110: .loc 1 294 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r511,[%value_in]; } mov.u32 %r512,33; st.u32 [%r511],%r512; ld.u32 %r249,[%frame+40]; bra $L2; $L24: .loc 1 300 0 mov.u32 %r513,1; st.u32 [%frame],%r513; .loc 1 301 0 setp.gt.s32 %r514,%r253,99; @ %r514 bra $L242; cvta.const.u64 %r214,$LC16; bra $L111; $L242: cvta.const.u64 %r214,$LC17; $L111: st.u64 [%frame+8],%r214; .loc 1 302 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r515,%r70,0; @ %r515 bra $L112; .loc 1 303 0 mov.f64 %r516,0dc7efffffe0000000; st.f64 [%frame+32],%r516; bra $L113; $L112: .loc 1 305 0 mov.f64 %r517,0dfff0000000000000; st.f64 [%frame+32],%r517; .loc 1 306 0 setp.ne.u32 %r518,%r70,2; @ %r518 bra $L113; .loc 1 307 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r519,[%value_in]; } mov.u32 %r520,33; st.u32 [%r519],%r520; ld.u32 %r249,[%frame+40]; bra $L2; $L113: .loc 1 308 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r522,[%value_in]; } setp.eq.u32 %r523,%r522,0; @ %r523 bra $L114; ld.u32 %r249,[%frame+40]; bra $L2; $L114: .loc 1 312 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r524,[%value_in]; } mov.u32 %r525,33; st.u32 [%r524],%r525; ld.u32 %r249,[%frame+40]; bra $L2; $L25: .loc 1 318 0 mov.u32 %r526,3; st.u32 [%frame],%r526; .loc 1 319 0 setp.gt.s32 %r527,%r253,99; @ %r527 bra $L243; cvta.const.u64 %r215,$LC18; bra $L115; $L243: cvta.const.u64 %r215,$LC19; $L115: st.u64 [%frame+8],%r215; .loc 1 320 0 ld.global.u32 %r74,[__fdlib_version]; setp.ne.u32 %r528,%r74,0; @ %r528 bra $L116; .loc 1 321 0 mov.f64 %r529,0d47efffffe0000000; st.f64 [%frame+32],%r529; bra $L117; $L116: .loc 1 323 0 mov.f64 %r530,0d7ff0000000000000; st.f64 [%frame+32],%r530; .loc 1 324 0 setp.ne.u32 %r531,%r74,2; @ %r531 bra $L117; .loc 1 325 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r532,[%value_in]; } mov.u32 %r533,34; st.u32 [%r532],%r533; ld.u32 %r249,[%frame+40]; bra $L2; $L117: .loc 1 326 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r535,[%value_in]; } setp.eq.u32 %r536,%r535,0; @ %r536 bra $L118; ld.u32 %r249,[%frame+40]; bra $L2; $L118: .loc 1 327 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r537,[%value_in]; } mov.u32 %r538,34; st.u32 [%r537],%r538; ld.u32 %r249,[%frame+40]; bra $L2; $L20: .loc 1 333 0 mov.u32 %r539,2; st.u32 [%frame],%r539; .loc 1 334 0 setp.gt.s32 %r540,%r253,99; @ %r540 bra $L244; cvta.const.u64 %r216,$LC18; bra $L119; $L244: cvta.const.u64 %r216,$LC19; $L119: st.u64 [%frame+8],%r216; .loc 1 335 0 ld.global.u32 %r78,[__fdlib_version]; setp.ne.u32 %r541,%r78,0; @ %r541 bra $L120; .loc 1 336 0 mov.f64 %r542,0d47efffffe0000000; st.f64 [%frame+32],%r542; bra $L121; $L120: .loc 1 338 0 mov.f64 %r543,0d7ff0000000000000; st.f64 [%frame+32],%r543; .loc 1 339 0 setp.ne.u32 %r544,%r78,2; @ %r544 bra $L121; .loc 1 340 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r545,[%value_in]; } mov.u32 %r546,33; st.u32 [%r545],%r546; ld.u32 %r249,[%frame+40]; bra $L2; $L121: .loc 1 341 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r548,[%value_in]; } setp.eq.u32 %r549,%r548,0; @ %r549 bra $L122; ld.u32 %r249,[%frame+40]; bra $L2; $L122: .loc 1 345 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r550,[%value_in]; } mov.u32 %r551,33; st.u32 [%r550],%r551; ld.u32 %r249,[%frame+40]; bra $L2; $L28: .loc 1 351 0 mov.u32 %r552,2; st.u32 [%frame],%r552; .loc 1 352 0 setp.gt.s32 %r553,%r253,99; @ %r553 bra $L245; cvta.const.u64 %r217,$LC20; bra $L123; $L245: cvta.const.u64 %r217,$LC21; $L123: st.u64 [%frame+8],%r217; .loc 1 353 0 ld.global.u32 %r82,[__fdlib_version]; setp.ne.u32 %r554,%r82,0; @ %r554 bra $L124; .loc 1 354 0 mov.f64 %r555,0dc7efffffe0000000; st.f64 [%frame+32],%r555; bra $L125; $L124: .loc 1 356 0 mov.f64 %r556,0dfff0000000000000; st.f64 [%frame+32],%r556; .loc 1 357 0 setp.ne.u32 %r557,%r82,2; @ %r557 bra $L125; .loc 1 358 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r558,[%value_in]; } mov.u32 %r559,34; st.u32 [%r558],%r559; ld.u32 %r249,[%frame+40]; bra $L2; $L125: .loc 1 359 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r561,[%value_in]; } setp.eq.u32 %r562,%r561,0; @ %r562 bra $L126; ld.u32 %r249,[%frame+40]; bra $L2; $L126: .loc 1 363 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r563,[%value_in]; } mov.u32 %r564,33; st.u32 [%r563],%r564; ld.u32 %r249,[%frame+40]; bra $L2; $L29: .loc 1 369 0 mov.u32 %r565,1; st.u32 [%frame],%r565; .loc 1 370 0 setp.gt.s32 %r566,%r253,99; @ %r566 bra $L246; cvta.const.u64 %r218,$LC20; bra $L127; $L246: cvta.const.u64 %r218,$LC21; $L127: st.u64 [%frame+8],%r218; .loc 1 371 0 ld.global.u32 %r86,[__fdlib_version]; setp.ne.u32 %r567,%r86,0; @ %r567 bra $L128; .loc 1 372 0 mov.f64 %r568,0dc7efffffe0000000; st.f64 [%frame+32],%r568; bra $L129; $L128: .loc 1 374 0 mov.f64 %r569,0dfff0000000000000; st.f64 [%frame+32],%r569; .loc 1 375 0 setp.ne.u32 %r570,%r86,2; @ %r570 bra $L129; .loc 1 376 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r571,[%value_in]; } mov.u32 %r572,33; st.u32 [%r571],%r572; ld.u32 %r249,[%frame+40]; bra $L2; $L129: .loc 1 377 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r574,[%value_in]; } setp.eq.u32 %r575,%r574,0; @ %r575 bra $L130; ld.u32 %r249,[%frame+40]; bra $L2; $L130: .loc 1 381 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r576,[%value_in]; } mov.u32 %r577,33; st.u32 [%r576],%r577; ld.u32 %r249,[%frame+40]; bra $L2; $L26: .loc 1 387 0 mov.u32 %r578,2; st.u32 [%frame],%r578; .loc 1 388 0 setp.gt.s32 %r579,%r253,99; @ %r579 bra $L247; cvta.const.u64 %r219,$LC22; bra $L131; $L247: cvta.const.u64 %r219,$LC23; $L131: st.u64 [%frame+8],%r219; .loc 1 389 0 ld.global.u32 %r90,[__fdlib_version]; setp.ne.u32 %r580,%r90,0; @ %r580 bra $L132; .loc 1 390 0 mov.f64 %r581,0dc7efffffe0000000; st.f64 [%frame+32],%r581; bra $L133; $L132: .loc 1 392 0 mov.f64 %r582,0dfff0000000000000; st.f64 [%frame+32],%r582; .loc 1 393 0 setp.ne.u32 %r583,%r90,2; @ %r583 bra $L133; .loc 1 394 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r584,[%value_in]; } mov.u32 %r585,34; st.u32 [%r584],%r585; ld.u32 %r249,[%frame+40]; bra $L2; $L133: .loc 1 395 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r587,[%value_in]; } setp.eq.u32 %r588,%r587,0; @ %r588 bra $L134; ld.u32 %r249,[%frame+40]; bra $L2; $L134: .loc 1 399 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r589,[%value_in]; } mov.u32 %r590,33; st.u32 [%r589],%r590; ld.u32 %r249,[%frame+40]; bra $L2; $L30: .loc 1 405 0 mov.u32 %r591,1; st.u32 [%frame],%r591; .loc 1 406 0 setp.gt.s32 %r592,%r253,99; @ %r592 bra $L248; cvta.const.u64 %r220,$LC22; bra $L135; $L248: cvta.const.u64 %r220,$LC23; $L135: st.u64 [%frame+8],%r220; .loc 1 407 0 ld.global.u32 %r94,[__fdlib_version]; setp.ne.u32 %r593,%r94,0; @ %r593 bra $L136; .loc 1 408 0 mov.f64 %r594,0dc7efffffe0000000; st.f64 [%frame+32],%r594; bra $L137; $L136: .loc 1 410 0 mov.f64 %r595,0dfff0000000000000; st.f64 [%frame+32],%r595; .loc 1 411 0 setp.ne.u32 %r596,%r94,2; @ %r596 bra $L137; .loc 1 412 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r597,[%value_in]; } mov.u32 %r598,33; st.u32 [%r597],%r598; ld.u32 %r249,[%frame+40]; bra $L2; $L137: .loc 1 413 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r600,[%value_in]; } setp.eq.u32 %r601,%r600,0; @ %r601 bra $L138; ld.u32 %r249,[%frame+40]; bra $L2; $L138: .loc 1 417 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r602,[%value_in]; } mov.u32 %r603,33; st.u32 [%r602],%r603; ld.u32 %r249,[%frame+40]; bra $L2; $L31: .loc 1 424 0 mov.u32 %r604,1; st.u32 [%frame],%r604; .loc 1 425 0 setp.gt.s32 %r605,%r253,99; @ %r605 bra $L249; cvta.const.u64 %r221,$LC24; bra $L139; $L249: cvta.const.u64 %r221,$LC25; $L139: st.u64 [%frame+8],%r221; .loc 1 426 0 mov.f64 %r606,0d0000000000000000; st.f64 [%frame+32],%r606; .loc 1 427 0 ld.global.u32 %r607,[__fdlib_version]; setp.eq.u32 %r608,%r607,0; @ %r608 bra $L140; $L226: .loc 1 102 0 mov.f64 %r250,0d3ff0000000000000; bra $L1; $L140: .loc 1 428 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r610,[%value_in]; } setp.eq.u32 %r611,%r610,0; @ %r611 bra $L142; ld.u32 %r249,[%frame+40]; bra $L2; $L142: .loc 1 430 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r612,[%value_in]; } mov.u32 %r613,33; st.u32 [%r612],%r613; ld.u32 %r249,[%frame+40]; bra $L2; $L5: .loc 1 436 0 mov.u32 %r614,3; st.u32 [%frame],%r614; .loc 1 437 0 setp.gt.s32 %r615,%r253,99; @ %r615 bra $L250; cvta.const.u64 %r222,$LC24; bra $L143; $L250: cvta.const.u64 %r222,$LC25; $L143: st.u64 [%frame+8],%r222; .loc 1 438 0 ld.global.u32 %r101,[__fdlib_version]; mul.f64 %r248,%r252,0d3fe0000000000000; setp.ne.u32 %r616,%r101,0; @ %r616 bra $L144; .loc 1 439 0 mov.f64 %r617,0d47efffffe0000000; st.f64 [%frame+32],%r617; .loc 1 441 0 setp.lt.f64 %r618,%r251,0d0000000000000000; @ ! %r618 bra $L145; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r248; call (%value_in),rint,(%out_arg1); ld.param.f64 %r620,[%value_in]; } setp.neu.f64 %r621,%r620,%r248; @ %r621 bra $L147; ld.global.u32 %r101,[__fdlib_version]; bra $L148; $L147: mov.f64 %r622,0dc7efffffe0000000; st.f64 [%frame+32],%r622; ld.global.u32 %r101,[__fdlib_version]; bra $L148; $L144: .loc 1 443 0 mov.f64 %r623,0d7ff0000000000000; st.f64 [%frame+32],%r623; .loc 1 445 0 setp.lt.f64 %r624,%r251,0d0000000000000000; @ ! %r624 bra $L148; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r248; call (%value_in),rint,(%out_arg1); ld.param.f64 %r626,[%value_in]; } setp.neu.f64 %r627,%r626,%r248; @ %r627 bra $L150; ld.global.u32 %r101,[__fdlib_version]; bra $L148; $L150: mov.f64 %r628,0dfff0000000000000; st.f64 [%frame+32],%r628; ld.global.u32 %r101,[__fdlib_version]; $L148: .loc 1 447 0 setp.ne.u32 %r629,%r101,2; @ %r629 bra $L145; .loc 1 448 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r630,[%value_in]; } mov.u32 %r631,34; st.u32 [%r630],%r631; ld.u32 %r249,[%frame+40]; bra $L2; $L145: .loc 1 449 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r633,[%value_in]; } setp.eq.u32 %r634,%r633,0; @ %r634 bra $L151; ld.u32 %r249,[%frame+40]; bra $L2; $L151: .loc 1 450 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r635,[%value_in]; } mov.u32 %r636,34; st.u32 [%r635],%r636; ld.u32 %r249,[%frame+40]; bra $L2; $L37: .loc 1 456 0 mov.u32 %r637,4; st.u32 [%frame],%r637; .loc 1 457 0 setp.gt.s32 %r638,%r253,99; @ %r638 bra $L251; cvta.const.u64 %r223,$LC24; bra $L152; $L251: cvta.const.u64 %r223,$LC25; $L152: st.u64 [%frame+8],%r223; .loc 1 458 0 mov.f64 %r639,0d0000000000000000; st.f64 [%frame+32],%r639; .loc 1 459 0 ld.global.u32 %r640,[__fdlib_version]; setp.ne.u32 %r641,%r640,2; @ %r641 bra $L153; .loc 1 460 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r642,[%value_in]; } mov.u32 %r643,34; st.u32 [%r642],%r643; ld.u32 %r249,[%frame+40]; bra $L2; $L153: .loc 1 461 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r645,[%value_in]; } setp.eq.u32 %r646,%r645,0; @ %r646 bra $L154; ld.u32 %r249,[%frame+40]; bra $L2; $L154: .loc 1 462 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r647,[%value_in]; } mov.u32 %r648,34; st.u32 [%r647],%r648; ld.u32 %r249,[%frame+40]; bra $L2; $L36: .loc 1 468 0 mov.u32 %r649,1; st.u32 [%frame],%r649; .loc 1 469 0 setp.gt.s32 %r650,%r253,99; @ %r650 bra $L252; cvta.const.u64 %r224,$LC24; bra $L155; $L252: cvta.const.u64 %r224,$LC25; $L155: st.u64 [%frame+8],%r224; .loc 1 470 0 ld.global.u32 %r111,[__fdlib_version]; setp.ne.u32 %r651,%r111,0; @ %r651 bra $L156; .loc 1 471 0 mov.f64 %r652,0d0000000000000000; st.f64 [%frame+32],%r652; bra $L157; $L156: .loc 1 473 0 mov.f64 %r653,0dfff0000000000000; st.f64 [%frame+32],%r653; .loc 1 474 0 setp.ne.u32 %r654,%r111,2; @ %r654 bra $L157; .loc 1 475 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r655,[%value_in]; } mov.u32 %r656,33; st.u32 [%r655],%r656; ld.u32 %r249,[%frame+40]; bra $L2; $L157: .loc 1 476 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r658,[%value_in]; } setp.eq.u32 %r659,%r658,0; @ %r659 bra $L158; ld.u32 %r249,[%frame+40]; bra $L2; $L158: .loc 1 480 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r660,[%value_in]; } mov.u32 %r661,33; st.u32 [%r660],%r661; ld.u32 %r249,[%frame+40]; bra $L2; $L38: .loc 1 486 0 mov.u32 %r662,1; st.u32 [%frame],%r662; .loc 1 487 0 setp.gt.s32 %r663,%r253,99; @ %r663 bra $L253; cvta.const.u64 %r225,$LC24; bra $L159; $L253: cvta.const.u64 %r225,$LC25; $L159: st.u64 [%frame+8],%r225; .loc 1 488 0 ld.global.u32 %r115,[__fdlib_version]; setp.ne.u32 %r664,%r115,0; @ %r664 bra $L160; .loc 1 489 0 mov.f64 %r665,0d0000000000000000; st.f64 [%frame+32],%r665; bra $L161; $L160: .loc 1 491 0 mov.f64 %r667,0d0000000000000000; div.rn.f64 %r666,%r667,0d0000000000000000; st.f64 [%frame+32],%r666; .loc 1 492 0 setp.ne.u32 %r668,%r115,2; @ %r668 bra $L161; .loc 1 493 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r669,[%value_in]; } mov.u32 %r670,33; st.u32 [%r669],%r670; ld.u32 %r249,[%frame+40]; bra $L2; $L161: .loc 1 494 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r672,[%value_in]; } setp.eq.u32 %r673,%r672,0; @ %r673 bra $L162; ld.u32 %r249,[%frame+40]; bra $L2; $L162: .loc 1 498 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r674,[%value_in]; } mov.u32 %r675,33; st.u32 [%r674],%r675; ld.u32 %r249,[%frame+40]; bra $L2; $L39: .loc 1 504 0 mov.u32 %r676,3; st.u32 [%frame],%r676; .loc 1 505 0 setp.gt.s32 %r677,%r253,99; @ %r677 bra $L254; cvta.const.u64 %r226,$LC26; bra $L163; $L254: cvta.const.u64 %r226,$LC27; $L163: st.u64 [%frame+8],%r226; .loc 1 506 0 ld.global.u32 %r120,[__fdlib_version]; setp.ne.u32 %r678,%r120,0; @ %r678 bra $L164; .loc 1 507 0 setp.gt.f64 %r679,%r251,0d0000000000000000; selp.f64 %r227,0d47efffffe0000000,0dc7efffffe0000000,%r679; st.f64 [%frame+32],%r227; bra $L167; $L164: .loc 1 509 0 setp.gt.f64 %r680,%r251,0d0000000000000000; selp.f64 %r228,0d7ff0000000000000,0dfff0000000000000,%r680; st.f64 [%frame+32],%r228; .loc 1 510 0 setp.ne.u32 %r681,%r120,2; @ %r681 bra $L167; .loc 1 511 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r682,[%value_in]; } mov.u32 %r683,34; st.u32 [%r682],%r683; ld.u32 %r249,[%frame+40]; bra $L2; $L167: .loc 1 512 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r685,[%value_in]; } setp.eq.u32 %r686,%r685,0; @ %r686 bra $L170; ld.u32 %r249,[%frame+40]; bra $L2; $L170: .loc 1 513 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r687,[%value_in]; } mov.u32 %r688,34; st.u32 [%r687],%r688; ld.u32 %r249,[%frame+40]; bra $L2; $L34: .loc 1 519 0 mov.u32 %r689,1; st.u32 [%frame],%r689; .loc 1 520 0 setp.gt.s32 %r690,%r253,99; @ %r690 bra $L257; cvta.const.u64 %r229,$LC28; bra $L171; $L257: cvta.const.u64 %r229,$LC29; $L171: st.u64 [%frame+8],%r229; .loc 1 521 0 ld.global.u32 %r124,[__fdlib_version]; setp.ne.u32 %r691,%r124,0; @ %r691 bra $L172; .loc 1 522 0 mov.f64 %r692,0d0000000000000000; st.f64 [%frame+32],%r692; bra $L173; $L172: .loc 1 524 0 mov.f64 %r694,0d0000000000000000; div.rn.f64 %r693,%r694,0d0000000000000000; st.f64 [%frame+32],%r693; .loc 1 525 0 setp.ne.u32 %r695,%r124,2; @ %r695 bra $L173; .loc 1 526 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r696,[%value_in]; } mov.u32 %r697,33; st.u32 [%r696],%r697; ld.u32 %r249,[%frame+40]; bra $L2; $L173: .loc 1 527 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r699,[%value_in]; } setp.eq.u32 %r700,%r699,0; @ %r700 bra $L174; ld.u32 %r249,[%frame+40]; bra $L2; $L174: .loc 1 531 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r701,[%value_in]; } mov.u32 %r702,33; st.u32 [%r701],%r702; ld.u32 %r249,[%frame+40]; bra $L2; $L41: .loc 1 537 0 mov.u32 %r703,1; st.u32 [%frame],%r703; .loc 1 538 0 setp.gt.s32 %r704,%r253,99; @ %r704 bra $L258; cvta.const.u64 %r230,$LC30; bra $L175; $L258: cvta.const.u64 %r230,$LC31; $L175: st.u64 [%frame+8],%r230; .loc 1 539 0 ld.global.u32 %r129,[__fdlib_version]; setp.ne.u32 %r705,%r129,0; @ %r705 bra $L176; .loc 1 540 0 st.f64 [%frame+32],%r251; bra $L177; $L176: .loc 1 542 0 mov.f64 %r707,0d0000000000000000; div.rn.f64 %r706,%r707,0d0000000000000000; st.f64 [%frame+32],%r706; .loc 1 543 0 setp.ne.u32 %r708,%r129,2; @ %r708 bra $L177; .loc 1 544 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r709,[%value_in]; } mov.u32 %r710,33; st.u32 [%r709],%r710; ld.u32 %r249,[%frame+40]; bra $L2; $L177: .loc 1 545 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r712,[%value_in]; } setp.eq.u32 %r713,%r712,0; @ %r713 bra $L178; ld.u32 %r249,[%frame+40]; bra $L2; $L178: .loc 1 549 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r714,[%value_in]; } mov.u32 %r715,33; st.u32 [%r714],%r715; ld.u32 %r249,[%frame+40]; bra $L2; $L40: .loc 1 555 0 mov.u32 %r716,1; st.u32 [%frame],%r716; .loc 1 556 0 setp.gt.s32 %r717,%r253,99; @ %r717 bra $L259; cvta.const.u64 %r231,$LC32; bra $L179; $L259: cvta.const.u64 %r231,$LC33; $L179: st.u64 [%frame+8],%r231; .loc 1 557 0 mov.f64 %r719,0d0000000000000000; div.rn.f64 %r718,%r719,0d0000000000000000; st.f64 [%frame+32],%r718; .loc 1 558 0 ld.global.u32 %r720,[__fdlib_version]; setp.ne.u32 %r721,%r720,2; @ %r721 bra $L180; .loc 1 559 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r722,[%value_in]; } mov.u32 %r723,33; st.u32 [%r722],%r723; ld.u32 %r249,[%frame+40]; bra $L2; $L180: .loc 1 560 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r725,[%value_in]; } setp.eq.u32 %r726,%r725,0; @ %r726 bra $L181; ld.u32 %r249,[%frame+40]; bra $L2; $L181: .loc 1 564 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r727,[%value_in]; } mov.u32 %r728,33; st.u32 [%r727],%r728; ld.u32 %r249,[%frame+40]; bra $L2; $L42: .loc 1 570 0 mov.u32 %r729,1; st.u32 [%frame],%r729; .loc 1 571 0 setp.gt.s32 %r730,%r253,99; @ %r730 bra $L260; cvta.const.u64 %r232,$LC34; bra $L182; $L260: cvta.const.u64 %r232,$LC35; $L182: st.u64 [%frame+8],%r232; .loc 1 572 0 mov.f64 %r732,0d0000000000000000; div.rn.f64 %r731,%r732,0d0000000000000000; st.f64 [%frame+32],%r731; .loc 1 573 0 ld.global.u32 %r733,[__fdlib_version]; setp.ne.u32 %r734,%r733,2; @ %r734 bra $L183; .loc 1 574 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r735,[%value_in]; } mov.u32 %r736,33; st.u32 [%r735],%r736; ld.u32 %r249,[%frame+40]; bra $L2; $L183: .loc 1 575 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r738,[%value_in]; } setp.eq.u32 %r739,%r738,0; @ %r739 bra $L184; ld.u32 %r249,[%frame+40]; bra $L2; $L184: .loc 1 579 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r740,[%value_in]; } mov.u32 %r741,33; st.u32 [%r740],%r741; ld.u32 %r249,[%frame+40]; bra $L2; $L43: .loc 1 585 0 mov.u32 %r742,1; st.u32 [%frame],%r742; .loc 1 586 0 setp.gt.s32 %r743,%r253,99; @ %r743 bra $L261; cvta.const.u64 %r233,$LC36; bra $L185; $L261: cvta.const.u64 %r233,$LC37; $L185: st.u64 [%frame+8],%r233; .loc 1 587 0 mov.f64 %r745,0d0000000000000000; div.rn.f64 %r744,%r745,0d0000000000000000; st.f64 [%frame+32],%r744; .loc 1 588 0 ld.global.u32 %r746,[__fdlib_version]; setp.ne.u32 %r747,%r746,2; @ %r747 bra $L186; .loc 1 589 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r748,[%value_in]; } mov.u32 %r749,33; st.u32 [%r748],%r749; ld.u32 %r249,[%frame+40]; bra $L2; $L186: .loc 1 590 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r751,[%value_in]; } setp.eq.u32 %r752,%r751,0; @ %r752 bra $L187; ld.u32 %r249,[%frame+40]; bra $L2; $L187: .loc 1 594 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r753,[%value_in]; } mov.u32 %r754,33; st.u32 [%r753],%r754; ld.u32 %r249,[%frame+40]; bra $L2; $L32: .loc 1 600 0 mov.u32 %r755,2; st.u32 [%frame],%r755; .loc 1 601 0 setp.gt.s32 %r756,%r253,99; @ %r756 bra $L262; cvta.const.u64 %r234,$LC36; bra $L188; $L262: cvta.const.u64 %r234,$LC37; $L188: st.u64 [%frame+8],%r234; .loc 1 602 0 div.rn.f64 %r757,%r251,0d0000000000000000; st.f64 [%frame+32],%r757; .loc 1 603 0 ld.global.u32 %r758,[__fdlib_version]; setp.ne.u32 %r759,%r758,2; @ %r759 bra $L189; .loc 1 604 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r760,[%value_in]; } mov.u32 %r761,33; st.u32 [%r760],%r761; ld.u32 %r249,[%frame+40]; bra $L2; $L189: .loc 1 605 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r763,[%value_in]; } setp.eq.u32 %r764,%r763,0; @ %r764 bra $L190; ld.u32 %r249,[%frame+40]; bra $L2; $L190: .loc 1 609 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r765,[%value_in]; } mov.u32 %r766,33; st.u32 [%r765],%r766; ld.u32 %r249,[%frame+40]; bra $L2; $L47: .loc 1 615 0 mov.u32 %r767,3; st.u32 [%frame],%r767; .loc 1 616 0 setp.gt.s32 %r768,%r253,99; @ %r768 bra $L263; cvta.const.u64 %r235,$LC38; bra $L191; $L263: cvta.const.u64 %r235,$LC39; $L191: st.u64 [%frame+8],%r235; .loc 1 617 0 setp.gt.f64 %r769,%r251,0d0000000000000000; selp.f64 %r236,0d7ff0000000000000,0dfff0000000000000,%r769; st.f64 [%frame+32],%r236; .loc 1 618 0 ld.global.u32 %r770,[__fdlib_version]; setp.ne.u32 %r771,%r770,2; @ %r771 bra $L194; .loc 1 619 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r772,[%value_in]; } mov.u32 %r773,34; st.u32 [%r772],%r773; ld.u32 %r249,[%frame+40]; bra $L2; $L194: .loc 1 620 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r775,[%value_in]; } setp.eq.u32 %r776,%r775,0; @ %r776 bra $L195; ld.u32 %r249,[%frame+40]; bra $L2; $L195: .loc 1 621 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r777,[%value_in]; } mov.u32 %r778,34; st.u32 [%r777],%r778; ld.u32 %r249,[%frame+40]; bra $L2; $L46: .loc 1 627 0 mov.u32 %r779,4; st.u32 [%frame],%r779; .loc 1 628 0 setp.gt.s32 %r780,%r253,99; @ %r780 bra $L265; cvta.const.u64 %r237,$LC38; bra $L196; $L265: cvta.const.u64 %r237,$LC39; $L196: st.u64 [%frame+8],%r237; .loc 1 629 0 mov.f64 %r781,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r781; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r251; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r783,[%value_in]; } st.f64 [%frame+32],%r783; .loc 1 630 0 ld.global.u32 %r784,[__fdlib_version]; setp.ne.u32 %r785,%r784,2; @ %r785 bra $L197; .loc 1 631 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r786,[%value_in]; } mov.u32 %r787,34; st.u32 [%r786],%r787; ld.u32 %r249,[%frame+40]; bra $L2; $L197: .loc 1 632 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r789,[%value_in]; } setp.eq.u32 %r790,%r789,0; @ %r790 bra $L198; ld.u32 %r249,[%frame+40]; bra $L2; $L198: .loc 1 633 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r791,[%value_in]; } mov.u32 %r792,34; st.u32 [%r791],%r792; ld.u32 %r249,[%frame+40]; bra $L2; $L48: .loc 1 639 0 mov.u32 %r793,5; st.u32 [%frame],%r793; .loc 1 640 0 setp.gt.s32 %r794,%r253,99; @ %r794 bra $L266; cvta.const.u64 %r238,$LC40; bra $L199; $L266: cvta.const.u64 %r238,$LC41; $L199: st.u64 [%frame+8],%r238; .loc 1 641 0 mov.f64 %r795,0d0000000000000000; st.f64 [%frame+32],%r795; .loc 1 642 0 ld.global.u32 %r796,[__fdlib_version]; setp.ne.u32 %r797,%r796,2; @ %r797 bra $L200; .loc 1 643 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r798,[%value_in]; } mov.u32 %r799,34; st.u32 [%r798],%r799; ld.u32 %r249,[%frame+40]; bra $L2; $L200: .loc 1 644 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r801,[%value_in]; } setp.eq.u32 %r802,%r801,0; @ %r802 bra $L201; ld.u32 %r249,[%frame+40]; bra $L2; $L201: .loc 1 649 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r803,[%value_in]; } mov.u32 %r804,34; st.u32 [%r803],%r804; ld.u32 %r249,[%frame+40]; bra $L2; $L49: .loc 1 655 0 mov.u32 %r805,5; st.u32 [%frame],%r805; .loc 1 656 0 setp.gt.s32 %r806,%r253,99; @ %r806 bra $L267; cvta.const.u64 %r239,$LC12; bra $L202; $L267: cvta.const.u64 %r239,$LC13; $L202: st.u64 [%frame+8],%r239; .loc 1 657 0 mov.f64 %r807,0d0000000000000000; st.f64 [%frame+32],%r807; .loc 1 658 0 ld.global.u32 %r808,[__fdlib_version]; setp.ne.u32 %r809,%r808,2; @ %r809 bra $L203; .loc 1 659 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r810,[%value_in]; } mov.u32 %r811,34; st.u32 [%r810],%r811; ld.u32 %r249,[%frame+40]; bra $L2; $L203: .loc 1 660 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r813,[%value_in]; } setp.eq.u32 %r814,%r813,0; @ %r814 bra $L204; ld.u32 %r249,[%frame+40]; bra $L2; $L204: .loc 1 665 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r815,[%value_in]; } mov.u32 %r816,34; st.u32 [%r815],%r816; ld.u32 %r249,[%frame+40]; bra $L2; $L44: .loc 1 671 0 mov.u32 %r817,5; st.u32 [%frame],%r817; .loc 1 672 0 setp.gt.s32 %r818,%r253,99; @ %r818 bra $L268; cvta.const.u64 %r240,$LC42; bra $L205; $L268: cvta.const.u64 %r240,$LC43; $L205: st.u64 [%frame+8],%r240; .loc 1 673 0 mov.f64 %r819,0d0000000000000000; st.f64 [%frame+32],%r819; .loc 1 674 0 ld.global.u32 %r820,[__fdlib_version]; setp.ne.u32 %r821,%r820,2; @ %r821 bra $L206; .loc 1 675 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r822,[%value_in]; } mov.u32 %r823,34; st.u32 [%r822],%r823; ld.u32 %r249,[%frame+40]; bra $L2; $L206: .loc 1 676 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r825,[%value_in]; } setp.eq.u32 %r826,%r825,0; @ %r826 bra $L207; ld.u32 %r249,[%frame+40]; bra $L2; $L207: .loc 1 681 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r827,[%value_in]; } mov.u32 %r828,34; st.u32 [%r827],%r828; ld.u32 %r249,[%frame+40]; bra $L2; $L52: .loc 1 687 0 mov.u32 %r829,5; st.u32 [%frame],%r829; .loc 1 688 0 setp.gt.s32 %r830,%r253,99; @ %r830 bra $L269; cvta.const.u64 %r241,$LC14; bra $L208; $L269: cvta.const.u64 %r241,$LC15; $L208: st.u64 [%frame+8],%r241; .loc 1 689 0 mov.f64 %r831,0d0000000000000000; st.f64 [%frame+32],%r831; .loc 1 690 0 ld.global.u32 %r832,[__fdlib_version]; setp.ne.u32 %r833,%r832,2; @ %r833 bra $L209; .loc 1 691 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r834,[%value_in]; } mov.u32 %r835,34; st.u32 [%r834],%r835; ld.u32 %r249,[%frame+40]; bra $L2; $L209: .loc 1 692 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r837,[%value_in]; } setp.eq.u32 %r838,%r837,0; @ %r838 bra $L210; ld.u32 %r249,[%frame+40]; bra $L2; $L210: .loc 1 697 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r839,[%value_in]; } mov.u32 %r840,34; st.u32 [%r839],%r840; ld.u32 %r249,[%frame+40]; bra $L2; $L53: .loc 1 703 0 mov.u32 %r841,5; st.u32 [%frame],%r841; .loc 1 704 0 setp.gt.s32 %r842,%r253,99; @ %r842 bra $L270; cvta.const.u64 %r242,$LC44; bra $L211; $L270: cvta.const.u64 %r242,$LC45; $L211: st.u64 [%frame+8],%r242; .loc 1 705 0 mov.f64 %r843,0d0000000000000000; st.f64 [%frame+32],%r843; .loc 1 706 0 ld.global.u32 %r844,[__fdlib_version]; setp.ne.u32 %r845,%r844,2; @ %r845 bra $L212; .loc 1 707 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r846,[%value_in]; } mov.u32 %r847,34; st.u32 [%r846],%r847; ld.u32 %r249,[%frame+40]; bra $L2; $L212: .loc 1 708 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r849,[%value_in]; } setp.eq.u32 %r850,%r849,0; @ %r850 bra $L213; ld.u32 %r249,[%frame+40]; bra $L2; $L213: .loc 1 713 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r851,[%value_in]; } mov.u32 %r852,34; st.u32 [%r851],%r852; ld.u32 %r249,[%frame+40]; bra $L2; $L50: .loc 1 719 0 mov.u32 %r853,5; st.u32 [%frame],%r853; .loc 1 720 0 setp.gt.s32 %r854,%r253,99; @ %r854 bra $L271; cvta.const.u64 %r243,$LC16; bra $L214; $L271: cvta.const.u64 %r243,$LC17; $L214: st.u64 [%frame+8],%r243; .loc 1 721 0 mov.f64 %r855,0d0000000000000000; st.f64 [%frame+32],%r855; .loc 1 722 0 ld.global.u32 %r856,[__fdlib_version]; setp.ne.u32 %r857,%r856,2; @ %r857 bra $L215; .loc 1 723 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r858,[%value_in]; } mov.u32 %r859,34; st.u32 [%r858],%r859; ld.u32 %r249,[%frame+40]; bra $L2; $L215: .loc 1 724 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r861,[%value_in]; } setp.eq.u32 %r862,%r861,0; @ %r862 bra $L216; ld.u32 %r249,[%frame+40]; bra $L2; $L216: .loc 1 729 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r863,[%value_in]; } mov.u32 %r864,34; st.u32 [%r863],%r864; ld.u32 %r249,[%frame+40]; bra $L2; $L54: .loc 1 735 0 mov.u32 %r865,3; st.u32 [%frame],%r865; .loc 1 736 0 setp.gt.s32 %r866,%r253,99; @ %r866 bra $L272; cvta.const.u64 %r244,$LC46; bra $L217; $L272: cvta.const.u64 %r244,$LC47; $L217: st.u64 [%frame+8],%r244; .loc 1 737 0 ld.global.u32 %r187,[__fdlib_version]; setp.ne.u32 %r867,%r187,0; @ %r867 bra $L218; .loc 1 738 0 mov.f64 %r868,0d47efffffe0000000; st.f64 [%frame+32],%r868; bra $L219; $L218: .loc 1 740 0 mov.f64 %r869,0d7ff0000000000000; st.f64 [%frame+32],%r869; .loc 1 741 0 setp.ne.u32 %r870,%r187,2; @ %r870 bra $L219; .loc 1 742 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r871,[%value_in]; } mov.u32 %r872,34; st.u32 [%r871],%r872; ld.u32 %r249,[%frame+40]; bra $L2; $L219: .loc 1 743 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r874,[%value_in]; } setp.eq.u32 %r875,%r874,0; @ %r875 bra $L220; ld.u32 %r249,[%frame+40]; bra $L2; $L220: .loc 1 744 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r876,[%value_in]; } mov.u32 %r877,34; st.u32 [%r876],%r877; ld.u32 %r249,[%frame+40]; bra $L2; $L55: .loc 1 750 0 mov.u32 %r878,2; st.u32 [%frame],%r878; .loc 1 751 0 setp.gt.s32 %r879,%r253,99; @ %r879 bra $L273; cvta.const.u64 %r245,$LC46; bra $L221; $L273: cvta.const.u64 %r245,$LC47; $L221: st.u64 [%frame+8],%r245; .loc 1 752 0 ld.global.u32 %r191,[__fdlib_version]; setp.ne.u32 %r880,%r191,0; @ %r880 bra $L222; .loc 1 753 0 mov.f64 %r881,0d47efffffe0000000; st.f64 [%frame+32],%r881; bra $L223; $L222: .loc 1 755 0 mov.f64 %r882,0d7ff0000000000000; st.f64 [%frame+32],%r882; .loc 1 756 0 setp.ne.u32 %r883,%r191,2; @ %r883 bra $L223; .loc 1 757 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r884,[%value_in]; } mov.u32 %r885,33; st.u32 [%r884],%r885; ld.u32 %r249,[%frame+40]; bra $L2; $L223: .loc 1 758 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r887,[%value_in]; } setp.eq.u32 %r888,%r887,0; @ %r888 bra $L224; ld.u32 %r249,[%frame+40]; bra $L2; $L224: .loc 1 762 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r889,[%value_in]; } mov.u32 %r890,33; st.u32 [%r889],%r890; ld.u32 %r249,[%frame+40]; bra $L2; $L3: .loc 1 769 0 mov.u32 %r891,1; st.u32 [%frame],%r891; .loc 1 770 0 setp.gt.s32 %r892,%r253,99; @ %r892 bra $L274; cvta.const.u64 %r246,$LC24; bra $L225; $L274: cvta.const.u64 %r246,$LC25; $L225: st.u64 [%frame+8],%r246; .loc 1 771 0 st.f64 [%frame+32],%r251; .loc 1 772 0 ld.global.u32 %r247,[__fdlib_version]; set.u32.eq.u32 %r894,%r247,-1; neg.s32 %r895,%r894; set.u32.eq.u32 %r897,%r247,2; neg.s32 %r898,%r897; cvt.u16.u32 %r900,%r895; cvt.u16.u32 %r901,%r898; or.b16 %r899,%r900,%r901; cvt.u32.u16 %r902,%r899; cvt.u16.u8 %r903,%r902; setp.ne.u16 %r904,%r903,0; @ %r904 bra $L226; .loc 1 774 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r906,[%value_in]; } setp.eq.u32 %r907,%r906,0; @ %r907 bra $L227; ld.u32 %r249,[%frame+40]; bra $L2; $L227: .loc 1 775 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r908,[%value_in]; } mov.u32 %r909,33; st.u32 [%r908],%r909; ld.u32 %r249,[%frame+40]; $L2: .loc 1 779 0 setp.ne.u32 %r910,%r249,0; @ %r910 bra $L228; $L505: ld.f64 %r250,[%frame+32]; bra $L1; $L228: .loc 1 780 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r911,[%value_in]; } ld.u32 %r201,[%frame+40]; st.u32 [%r911],%r201; ld.f64 %r250,[%frame+32]; $L1: .loc 1 782 0 mov.f64 %value,%r250; st.param.f64 [%value_out],%value; ret; } lib_a-k_tan.o/ 0 0 0 644 4962 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_tan .visible .func (.param .f64 %value_out) __kernel_tan (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libm/math/k_tan.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __kernel_tan .visible .func (.param .f64 %value_out) __kernel_tan (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .f64 %r39; .reg .u32 %r52; .reg .u32 %r53; .reg .f64 %r54; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r68; .reg .u64 %r71; .reg .u64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .pred %r79; .reg .u32 %r80; .reg .pred %r81; .reg .u32 %r82; .reg .u32 %r84; .reg .u32 %r85; .reg .u32 %r86; .reg .pred %r87; .reg .f64 %r89; .reg .f64 %r90; .reg .pred %r91; .reg .f64 %r92; .reg .pred %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .f64 %r121; .reg .pred %r122; .reg .u64 %r123; .reg .f64 %r124; .reg .u64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .pred %r131; mov.f64 %r74,%ar0; mov.f64 %r75,%ar1; mov.u32 %r76,%ar2; .loc 1 85 0 mov.b64 %r77,%r74; shr.u64 %r78,%r77,32; cvt.u32.u64 %r52,%r78; .loc 1 86 0 and.b32 %r53,%r52,2147483647; .loc 1 87 0 setp.gt.s32 %r79,%r53,1043333119; @ %r79 bra $L2; .loc 1 88 0 cvt.rzi.s32.f64 %r80,%r74; setp.ne.u32 %r81,%r80,0; @ ! %r81 bra $L13; setp.le.s32 %r131,%r53,1072010279; bra $L3; $L13: .loc 1 91 0 add.u32 %r82,%r76,1; cvt.u32.u64 %r85,%r77; or.b32 %r84,%r82,%r85; or.b32 %r86,%r84,%r53; setp.ne.u32 %r87,%r86,0; @ %r87 bra $L4; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r89,[%value_in]; } mov.f64 %r90,0d3ff0000000000000; div.rn.f64 %r73,%r90,%r89; bra $L1; $L4: .loc 1 92 0 setp.eq.u32 %r91,%r76,1; @ %r91 bra $L8; mov.f64 %r92,0dbff0000000000000; div.rn.f64 %r73,%r92,%r74; bra $L1; $L2: .loc 1 95 0 setp.le.s32 %r131,%r53,1072010279; @ %r131 bra $L3; .loc 1 96 0 setp.ge.s32 %r94,%r52,0; @ %r94 bra $L6; neg.f64 %r74,%r74; neg.f64 %r75,%r75; $L6: .loc 1 97 0 mov.f64 %r95,0d3fe921fb54442d18; sub.f64 %r54,%r95,%r74; .loc 1 98 0 mov.f64 %r97,0d3c81a62633145c07; sub.f64 %r96,%r97,%r75; .loc 1 99 0 add.f64 %r74,%r96,%r54; mov.f64 %r75,0d0000000000000000; $L3: .loc 1 101 0 mul.f64 %r57,%r74,%r74; .loc 1 102 0 mul.f64 %r58,%r57,%r57; .loc 1 109 0 mul.f64 %r60,%r74,%r57; .loc 1 108 0 fma.rn.f64 %r98,%r58,0d3efb2a7074bf7ad4,0d3f12b80f32f0a7e9; fma.rn.f64 %r99,%r98,%r58,0d3f3026f71a8d1068; fma.rn.f64 %r100,%r99,%r58,0d3f57dbc8fee08315; fma.rn.f64 %r101,%r100,%r58,0d3f8226e3e96e8493; fma.rn.f64 %r102,%r101,%r58,0d3faba1ba1bb341fe; .loc 1 107 0 fma.rn.f64 %r103,%r58,0dbef375cbdb605373,0d3f147e88a03792a6; fma.rn.f64 %r104,%r103,%r58,0d3f4344d8f2f26501; fma.rn.f64 %r105,%r104,%r58,0d3f6d6d22c9560328; fma.rn.f64 %r106,%r105,%r58,0d3f9664f48406d637; fma.rn.f64 %r107,%r106,%r58,0d3fc111111110fe7a; .loc 1 110 0 fma.rn.f64 %r108,%r102,%r57,%r107; fma.rn.f64 %r39,%r108,%r60,%r75; fma.rn.f64 %r61,%r39,%r57,%r75; .loc 1 111 0 fma.rn.f64 %r62,%r60,0d3fd5555555555563,%r61; .loc 1 112 0 add.f64 %r73,%r74,%r62; .loc 1 113 0 @ %r131 bra $L7; .loc 1 114 0 cvt.rn.f64.s32 %r68,%r76; .loc 1 115 0 mul.f64 %r110,%r73,%r73; add.f64 %r111,%r73,%r68; div.rn.f64 %r112,%r110,%r111; sub.f64 %r113,%r112,%r62; sub.f64 %r114,%r74,%r113; fma.rn.f64 %r116,%r114,0dc000000000000000,%r68; shr.s32 %r117,%r52,30; and.b32 %r118,%r117,2; mov.u32 %r120,1; sub.u32 %r119,%r120,%r118; cvt.rn.f64.s32 %r121,%r119; mul.f64 %r73,%r116,%r121; bra $L1; $L7: .loc 1 117 0 setp.eq.u32 %r122,%r76,1; @ %r122 bra $L1; .loc 1 123 0 mov.b64 %r71,%r73; and.b64 %r123,%r71,-4294967296; mov.b64 %r63,%r123; .loc 1 125 0 mov.f64 %r124,0dbff0000000000000; div.rn.f64 %r65,%r124,%r73; .loc 1 126 0 mov.b64 %r72,%r65; and.b64 %r125,%r72,-4294967296; mov.b64 %r66,%r125; .loc 1 124 0 sub.f64 %r126,%r63,%r74; sub.f64 %r127,%r62,%r126; .loc 1 127 0 fma.rn.f64 %r128,%r63,%r66,0d3ff0000000000000; .loc 1 128 0 fma.rn.f64 %r129,%r127,%r66,%r128; fma.rn.f64 %r73,%r129,%r65,%r66; bra $L1; $L8: .loc 1 92 0 mov.f64 %r73,%r74; $L1: .loc 1 130 0 mov.f64 %value,%r73; st.param.f64 [%value_out],%value; ret; } lib_a-kf_cos.o/ 0 0 0 644 2824 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .visible .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/kf_cos.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_cosf .visible .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .f32 %r45; .reg .f32 %r51; .reg .f32 %r53; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .pred %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .pred %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .pred %r74; .reg .u32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; mov.f32 %r57,%ar0; mov.f32 %r58,%ar1; .loc 1 40 0 mov.b32 %r36,%r57; .loc 1 41 0 and.b32 %r37,%r36,2147483647; .loc 1 42 0 setp.gt.s32 %r59,%r37,838860799; @ %r59 bra $L2; .loc 1 43 0 cvt.rzi.s32.f32 %r60,%r57; setp.eq.u32 %r61,%r60,0; @ ! %r61 bra $L10; bra $L8; $L2: .loc 1 45 0 mul.f32 %r45,%r57,%r57; .loc 1 46 0 fma.rn.f32 %r62,%r45,0fad47d74e,0f310f74f6; fma.rn.f32 %r63,%r62,%r45,0fb493f27c; fma.rn.f32 %r64,%r63,%r45,0f37d00d01; fma.rn.f32 %r65,%r64,%r45,0fbab60b61; fma.rn.f32 %r66,%r65,%r45,0f3d2aaaab; mul.f32 %r51,%r66,%r45; .loc 1 47 0 setp.gt.s32 %r67,%r37,1050253721; @ %r67 bra $L5; $L7: .loc 1 48 0 mul.f32 %r68,%r57,%r58; neg.f32 %r69,%r68; fma.rn.f32 %r70,%r45,%r51,%r69; neg.f32 %r71,%r70; fma.rn.f32 %r72,%r45,0f3f000000,%r71; mov.f32 %r73,0f3f800000; sub.f32 %r56,%r73,%r72; bra $L1; $L5: .loc 1 50 0 setp.gt.s32 %r74,%r37,1061683200; @ %r74 bra $L9; .loc 1 53 0 add.u32 %r75,%r37,-16777216; mov.b32 %r35,%r75; mov.f32 %r76,0f3f800000; sub.f32 %r53,%r76,%r35; bra $L6; $L9: mov.f32 %r53,0f3f380000; .loc 1 51 0 mov.f32 %r35,0f3e900000; $L6: .loc 1 55 0 neg.f32 %r77,%r35; fma.rn.f32 %r78,%r45,0f3f000000,%r77; .loc 1 57 0 mul.f32 %r79,%r57,%r58; neg.f32 %r80,%r79; fma.rn.f32 %r81,%r45,%r51,%r80; sub.f32 %r82,%r78,%r81; sub.f32 %r56,%r53,%r82; bra $L1; $L8: .loc 1 43 0 mov.f32 %r56,0f3f800000; bra $L1; $L10: .loc 1 45 0 mul.f32 %r45,%r57,%r57; .loc 1 46 0 fma.rn.f32 %r84,%r45,0fad47d74e,0f310f74f6; fma.rn.f32 %r85,%r45,%r84,0fb493f27c; fma.rn.f32 %r86,%r45,%r85,0f37d00d01; fma.rn.f32 %r87,%r45,%r86,0fbab60b61; fma.rn.f32 %r88,%r45,%r87,0f3d2aaaab; mul.f32 %r51,%r88,%r45; bra $L7; $L1: .loc 1 59 0 mov.f32 %value,%r56; st.param.f32 [%value_out],%value; ret; } /370 0 0 0 644 24857 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2f .visible .func (.param .u32 %value_out) __kernel_rem_pio2f (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); .file 1 "../../../../../newlib/libm/math/kf_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN VAR DEF: init_jk .const .align 4 .u32 init_jk[3] = {4,7,9 }; // BEGIN VAR DEF: PIo2 .const .align 4 .u32 PIo2[11] = {1070137344,972029952,937033728,866254848,780402688,726663168,667025408,584056832,532938752,465960960,390332416 }; // BEGIN GLOBAL FUNCTION DEF: __kernel_rem_pio2f .visible .func (.param .u32 %value_out) __kernel_rem_pio2f (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .local .align 8 .b8 %frame_ar[320]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r249; .reg .u32 %r250; .reg .u32 %r251; .reg .u32 %r252; .reg .u32 %r253; .reg .u32 %r255; .reg .u32 %r261; .reg .u32 %r263; .reg .u32 %r265; .reg .f32 %r283; .reg .u32 %r296; .reg .f32 %r302; .reg .f32 %r305; .reg .f32 %r306; .reg .u64 %r318; .reg .u32 %r319; .reg .u64 %r326; .reg .u64 %r327; .reg .u64 %r329; .reg .u32 %r330; .reg .f32 %r331; .reg .u64 %r332; .reg .f32 %r333; .reg .u32 %r337; .reg .u32 %r340; .reg .f32 %r342; .reg .f32 %r343; .reg .u32 %r344; .reg .u32 %r346; .reg .u32 %r348; .reg .u64 %r349; .reg .f32 %r351; .reg .u32 %r353; .reg .f32 %r356; .reg .u64 %r357; .reg .u32 %r358; .reg .f32 %r359; .reg .f32 %r360; .reg .f32 %r361; .reg .f32 %r363; .reg .u32 %r364; .reg .f32 %r365; .reg .f32 %r366; .reg .f32 %r367; .reg .f32 %r368; .reg .f32 %r370; .reg .f32 %r372; .reg .u32 %r374; .reg .u64 %r375; .reg .u32 %r377; .reg .u32 %r379; .reg .u64 %r384; .reg .u64 %r386; .reg .u32 %r388; .reg .u64 %r389; .reg .u64 %r390; .reg .u64 %r396; .reg .u64 %r403; .reg .u64 %r404; .reg .f32 %r407; .reg .u64 %r408; .reg .u64 %r409; .reg .f32 %r410; .reg .f32 %r411; .reg .u64 %r412; .reg .f32 %r415; .reg .u32 %r418; .reg .u64 %r419; .reg .u64 %r420; .reg .u64 %r421; .reg .u32 %r424; .reg .u64 %r425; .reg .u64 %r427; .reg .u32 %r429; .reg .u64 %r430; .reg .u64 %r432; .reg .u64 %r434; .reg .u64 %r442; .reg .u64 %r443; .reg .u64 %r449; .reg .u64 %r450; .reg .u64 %r461; .reg .u64 %r463; .reg .u64 %r464; .reg .u64 %r469; .reg .u32 %r470; .reg .u64 %r474; .reg .u32 %r477; .reg .u32 %r483; .reg .u64 %r484; .reg .u64 %r485; .reg .u64 %r491; .reg .u64 %r493; .reg .u64 %r501; .reg .u64 %r502; .reg .u64 %r514; .reg .u64 %r519; .reg .u64 %r521; .reg .u64 %r523; .reg .u64 %r524; .reg .u64 %r527; .reg .u64 %r537; .reg .u64 %r538; .reg .u64 %r539; .reg .u64 %r541; .reg .u64 %r549; .reg .u64 %r550; .reg .u64 %r551; .reg .u32 %r552; .reg .u32 %r557; .reg .u64 %r558; .reg .u64 %r559; .reg .u32 %r568; .reg .u64 %r571; .reg .u64 %r572; .reg .u32 %r573; .reg .u32 %r574; .reg .u32 %r575; .reg .u64 %r576; .reg .u64 %r577; .reg .u64 %r578; .reg .u64 %r579; .reg .u64 %r580; .reg .u32 %r581; .reg .u32 %r584; .reg .u32 %r585; .reg .u32 %r586; .reg .u32 %r587; .reg .u32 %r588; .reg .u32 %r589; .reg .pred %r590; .reg .u64 %r591; .reg .u64 %r592; .reg .u32 %r593; .reg .pred %r594; .reg .u32 %r595; .reg .pred %r596; .reg .u64 %r599; .reg .u64 %r600; .reg .f32 %r605; .reg .f32 %r606; .reg .pred %r607; .reg .pred %r608; .reg .u32 %r611; .reg .u64 %r612; .reg .u64 %r613; .reg .u64 %r614; .reg .u64 %r615; .reg .u64 %r616; .reg .u64 %r618; .reg .u64 %r619; .reg .u32 %r621; .reg .u64 %r622; .reg .u64 %r624; .reg .u64 %r626; .reg .u64 %r627; .reg .f32 %r628; .reg .u32 %r629; .reg .f32 %r631; .reg .u32 %r632; .reg .f32 %r633; .reg .pred %r634; .reg .f32 %r637; .reg .f32 %r639; .reg .f32 %r640; .reg .f32 %r642; .reg .u64 %r644; .reg .u64 %r645; .reg .u64 %r646; .reg .u64 %r647; .reg .u32 %r648; .reg .u32 %r649; .reg .u32 %r654; .reg .u32 %r655; .reg .u32 %r657; .reg .u64 %r658; .reg .u64 %r659; .reg .u64 %r660; .reg .u32 %r662; .reg .pred %r663; .reg .pred %r664; .reg .pred %r666; .reg .pred %r667; .reg .pred %r669; .reg .pred %r670; .reg .u64 %r671; .reg .u64 %r672; .reg .u64 %r673; .reg .u32 %r675; .reg .u32 %r676; .reg .pred %r677; .reg .u64 %r678; .reg .u64 %r679; .reg .u64 %r680; .reg .u32 %r684; .reg .u32 %r685; .reg .u64 %r686; .reg .u64 %r687; .reg .u64 %r688; .reg .u64 %r691; .reg .u64 %r692; .reg .u32 %r693; .reg .u64 %r694; .reg .u32 %r695; .reg .u32 %r696; .reg .pred %r697; .reg .u64 %r698; .reg .u64 %r699; .reg .u64 %r703; .reg .u64 %r704; .reg .u64 %r705; .reg .u64 %r706; .reg .u32 %r711; .reg .u32 %r712; .reg .u64 %r713; .reg .u64 %r714; .reg .u64 %r715; .reg .u64 %r716; .reg .u32 %r721; .reg .u32 %r722; .reg .pred %r723; .reg .f32 %r724; .reg .pred %r725; .reg .f32 %r728; .reg .pred %r729; .reg .pred %r730; .reg .u64 %r735; .reg .u32 %r736; .reg .u32 %r737; .reg .u64 %r738; .reg .u64 %r739; .reg .u32 %r740; .reg .pred %r741; .reg .pred %r742; .reg .u32 %r748; .reg .pred %r749; .reg .u32 %r750; .reg .pred %r751; .reg .pred %r752; .reg .u64 %r753; .reg .u64 %r754; .reg .u64 %r755; .reg .u64 %r757; .reg .u64 %r758; .reg .u64 %r759; .reg .u32 %r760; .reg .u64 %r763; .reg .u64 %r764; .reg .f32 %r765; .reg .pred %r766; .reg .pred %r767; .reg .u64 %r769; .reg .u64 %r770; .reg .u32 %r772; .reg .pred %r773; .reg .u32 %r775; .reg .u64 %r776; .reg .u64 %r777; .reg .u32 %r778; .reg .pred %r779; .reg .u32 %r782; .reg .f32 %r783; .reg .pred %r784; .reg .f32 %r785; .reg .u32 %r786; .reg .u64 %r788; .reg .u64 %r789; .reg .f32 %r792; .reg .u32 %r793; .reg .u64 %r794; .reg .u64 %r795; .reg .u64 %r796; .reg .u32 %r798; .reg .u64 %r800; .reg .u64 %r801; .reg .u32 %r803; .reg .f32 %r804; .reg .f32 %r806; .reg .pred %r807; .reg .u64 %r808; .reg .f32 %r814; .reg .u32 %r815; .reg .f32 %r816; .reg .pred %r817; .reg .f32 %r818; .reg .pred %r819; .reg .pred %r820; .reg .pred %r821; .reg .pred %r823; .reg .pred %r824; .reg .pred %r825; .reg .pred %r826; .reg .pred %r827; .reg .pred %r828; .reg .f32 %r832; .reg .pred %r833; .reg .pred %r834; .reg .u64 %r835; .reg .u64 %r836; .reg .f32 %r842; .reg .pred %r843; .reg .f32 %r845; .reg .f32 %r846; .reg .pred %r847; .reg .f32 %r849; .reg .pred %r850; .reg .u64 %r853; .reg .u64 %r854; .reg .u64 %r860; .reg .u64 %r862; .reg .u64 %r863; .reg .u64 %r865; .reg .u64 %r866; .reg .u64 %r867; .reg .u64 %r868; .reg .f32 %r869; .reg .f32 %r870; .reg .pred %r871; .reg .pred %r872; .reg .u64 %r874; .reg .u64 %r875; .reg .u32 %r880; .reg .u64 %r881; .reg .u64 %r882; .reg .u64 %r884; .reg .u64 %r885; .reg .u64 %r886; .reg .u64 %r887; .reg .f32 %r888; .reg .f32 %r889; .reg .pred %r890; .reg .u64 %r892; .reg .f32 %r893; .reg .pred %r894; .reg .pred %r895; .reg .f32 %r896; .reg .f32 %r897; .reg .f32 %r898; .reg .u32 %r899; .reg .pred %r900; .reg .f32 %r901; .reg .pred %r902; .reg .pred %r903; .reg .pred %r904; .reg .pred %r905; .reg .f32 %r906; .reg .pred %r907; .reg .u32 %r908; .reg .u64 %r909; .reg .pred %r910; .reg .pred %r911; .reg .u64 %r912; .reg .u32 %r913; .reg .pred %r914; .reg .pred %r915; .reg .pred %r916; .reg .u64 %r918; .reg .u64 %r919; .reg .u64 %r921; .reg .f32 %r922; .reg .u64 %r923; .reg .pred %r924; .reg .pred %r925; .reg .pred %r926; .reg .u64 %r927; .reg .u32 %r928; .reg .u64 %r929; .reg .u64 %r930; .reg .u64 %r931; .reg .u64 %r932; .reg .u64 %r933; .reg .pred %r934; .reg .u64 %r935; .reg .u64 %r936; .reg .u64 %r937; .reg .f32 %r938; mov.u64 %r571,%ar0; mov.u64 %r572,%ar1; mov.u32 %r573,%ar2; mov.u32 %r574,%ar3; mov.u32 %r575,%ar4; mov.u64 %r576,%ar5; .loc 1 66 0 cvta.const.u64 %r577,init_jk; cvt.s64.s32 %r578,%r575; shl.b64 %r579,%r578,2; add.u64 %r580,%r577,%r579; ld.u32 %r337,[%r580]; .loc 1 70 0 add.u32 %r908,%r574,-1; .loc 1 71 0 add.u32 %r581,%r573,-3; shr.s32 %r584,%r581,31; and.b32 %r585,%r584,7; add.u32 %r586,%r585,%r581; shr.s32 %r587,%r586,3; max.s32 %r379,%r587,0; .loc 1 72 0 add.u32 %r588,%r379,1; shl.b32 %r589,%r588,3; sub.u32 %r252,%r573,%r589; .loc 1 75 0 sub.u32 %r374,%r379,%r908; add.u32 %r340,%r337,%r908; .loc 1 76 0 setp.lt.s32 %r590,%r340,0; @ %r590 bra $L2; add.u64 %r558,%frame,160; cvt.s64.s32 %r591,%r374; shl.b64 %r592,%r591,2; add.u64 %r559,%r576,%r592; add.u32 %r593,%r374,%r340; add.u32 %r568,%r593,1; mov.f32 %r938,0f00000000; $L4: setp.lt.s32 %r594,%r374,0; @ %r594 bra $L71; ld.u32 %r595,[%r559]; cvt.rn.f32.s32 %r333,%r595; bra $L3; $L71: mov.f32 %r333,%r938; $L3: st.f32 [%r558],%r333; add.u32 %r374,%r374,1; add.u64 %r558,%r558,4; add.u64 %r559,%r559,4; setp.ne.u32 %r596,%r374,%r568; @ %r596 bra $L4; $L2: .loc 1 79 0 setp.lt.s32 %r916,%r337,0; @ %r916 bra $L5; mov.u64 %r551,%frame; mov.u32 %r552,%r908; add.u32 %r557,%r337,%r574; cvt.u64.u32 %r599,%r908; shl.b64 %r549,%r599,2; setp.ge.s32 %r915,%r908,0; add.u64 %r935,%frame,160; add.u64 %r936,%frame,156; sub.u64 %r937,%r936,%r549; bra $L6; $L8: mov.u64 %r538,%r571; cvt.s64.s32 %r600,%r552; shl.b64 %r541,%r600,2; add.u64 %r539,%r935,%r541; add.u64 %r550,%r937,%r541; .loc 1 80 0 mov.f32 %r372,0f00000000; $L7: ld.f32 %r605,[%r538]; ld.f32 %r606,[%r539]; fma.rn.f32 %r372,%r605,%r606,%r372; add.u64 %r538,%r538,4; add.u64 %r539,%r539,-4; setp.ne.u64 %r607,%r539,%r550; @ %r607 bra $L7; $L9: st.f32 [%r551],%r372; add.u64 %r551,%r551,4; add.u32 %r552,%r552,1; .loc 1 79 0 setp.eq.u32 %r608,%r552,%r557; @ %r608 bra $L5; $L6: .loc 1 80 0 @ %r915 bra $L8; mov.f32 %r372,0f00000000; bra $L9; $L5: add.u64 %r921,%frame,240; add.u32 %r611,%r337,-2; cvt.s64.s32 %r612,%r611; shl.b64 %r613,%r612,2; add.u64 %r485,%r921,%r613; add.u64 %r614,%r571,4; cvt.u64.u32 %r615,%r908; shl.b64 %r616,%r615,2; add.u64 %r461,%r614,%r616; .loc 1 66 0 mov.u32 %r296,%r337; setp.le.s32 %r910,%r252,0; add.u64 %r923,%frame,-4; .loc 1 117 0 setp.eq.u32 %r924,%r252,1; setp.eq.u32 %r925,%r252,2; .loc 1 103 0 setp.ne.u32 %r926,%r252,0; add.u64 %r927,%frame,236; .loc 1 135 0 add.u32 %r928,%r337,-1; cvt.s64.s32 %r929,%r928; shl.b64 %r930,%r929,2; add.u64 %r931,%frame,%r930; add.u64 %r932,%r931,240; add.u64 %r933,%frame,160; setp.lt.s32 %r934,%r908,0; $L10: .loc 1 86 0 cvt.s64.s32 %r909,%r296; shl.b64 %r618,%r909,2; add.u64 %r619,%frame,%r618; ld.f32 %r306,[%r619]; setp.le.s32 %r911,%r296,0; @ %r911 bra $L11; mov.u64 %r523,%r921; add.u32 %r621,%r296,-1; cvt.s64.s32 %r622,%r621; shl.b64 %r527,%r622,2; add.u64 %r524,%frame,%r527; add.u64 %r624,%r923,%r527; cvt.u64.u32 %r626,%r621; shl.b64 %r627,%r626,2; sub.u64 %r537,%r624,%r627; $L12: .loc 1 87 0 mul.f32 %r628,%r306,0f3b800000; cvt.rzi.s32.f32 %r629,%r628; cvt.rn.f32.s32 %r370,%r629; .loc 1 88 0 fma.rn.f32 %r631,%r370,0fc3800000,%r306; cvt.rzi.s32.f32 %r632,%r631; st.u32 [%r523],%r632; .loc 1 89 0 ld.f32 %r633,[%r524]; add.f32 %r306,%r370,%r633; add.u64 %r523,%r523,4; add.u64 %r524,%r524,-4; .loc 1 86 0 setp.ne.u64 %r634,%r524,%r537; @ %r634 bra $L12; $L11: .loc 1 93 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r306; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r252; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r637,[%value_in]; } .loc 1 94 0 mul.f32 %r639,%r637,0f3e000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r639; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r640,[%value_in]; } fma.rn.f32 %r343,%r640,0fc1000000,%r637; .loc 1 95 0 cvt.rzi.s32.f32 %r319,%r343; .loc 1 96 0 cvt.rn.f32.s32 %r642,%r319; sub.f32 %r331,%r343,%r642; .loc 1 98 0 @ %r910 bra $L13; .loc 1 99 0 add.u32 %r249,%r296,-1; cvt.s64.s32 %r644,%r249; shl.b64 %r645,%r644,2; add.u64 %r646,%frame,%r645; add.u64 %r647,%r646,240; ld.u32 %r250,[%r647]; mov.u32 %r648,8; sub.u32 %r251,%r648,%r252; shr.s32 %r344,%r250,%r251; add.u32 %r319,%r319,%r344; .loc 1 100 0 shl.b32 %r649,%r344,%r251; sub.u32 %r255,%r250,%r649; st.u32 [%r647],%r255; .loc 1 101 0 mov.u32 %r655,7; sub.u32 %r654,%r655,%r252; shr.s32 %r330,%r255,%r654; bra $L14; $L13: .loc 1 103 0 @ %r926 bra $L15; add.u32 %r657,%r296,-1; cvt.s64.s32 %r658,%r657; shl.b64 %r659,%r658,2; add.u64 %r660,%frame,%r659; ld.u32 %r662,[%r660+240]; shr.s32 %r330,%r662,8; bra $L14; $L15: .loc 1 104 0 setp.ge.f32 %r663,%r331,0f3f000000; @ %r663 bra $L16; .loc 1 97 0 mov.u32 %r330,0; bra $L17; $L14: .loc 1 106 0 setp.le.s32 %r664,%r330,0; @ %r664 bra $L17; .loc 1 107 0 add.u32 %r319,%r319,1; .loc 1 108 0 @ ! %r911 bra $L68; bra $L72; $L81: .loc 1 104 0 mov.u32 %r330,2; $L68: .loc 1 109 0 ld.u32 %r346,[%frame+240]; .loc 1 111 0 setp.ne.u32 %r666,%r346,0; @ %r666 bra $L73; .loc 1 108 0 setp.eq.u32 %r667,%r296,1; @ %r667 bra $L18; add.u64 %r521,%frame,244; mov.u32 %r388,1; bra $L20; $L21: add.u64 %r521,%r521,4; mov.u32 %r388,%r418; setp.eq.u32 %r669,%r296,%r388; @ %r669 bra $L18; $L20: .loc 1 109 0 ld.u32 %r346,[%r521]; add.u32 %r418,%r388,1; .loc 1 111 0 setp.eq.u32 %r670,%r346,0; @ %r670 bra $L21; bra $L19; $L73: mov.u32 %r418,1; mov.u32 %r388,0; $L19: .loc 1 112 0 cvt.s64.s32 %r671,%r388; shl.b64 %r672,%r671,2; add.u64 %r673,%frame,%r672; mov.u32 %r676,256; sub.u32 %r675,%r676,%r346; st.u32 [%r673+240],%r675; .loc 1 108 0 setp.le.s32 %r677,%r296,%r418; @ %r677 bra $L74; .loc 1 109 0 cvt.s64.s32 %r678,%r418; shl.b64 %r679,%r678,2; add.u64 %r680,%frame,%r679; ld.u32 %r377,[%r680+240]; add.u64 %r502,%r921,%r679; add.u32 %r684,%r296,-1; sub.u32 %r685,%r684,%r418; cvt.u64.u32 %r686,%r685; add.u64 %r687,%r686,%r678; shl.b64 %r688,%r687,2; add.u64 %r514,%r921,%r688; neg.s64 %r691,%r678; shl.b64 %r692,%r691,2; add.u32 %r693,%r418,1; cvt.u64.u32 %r694,%r693; shl.b64 %r519,%r694,2; .loc 1 114 0 mov.u32 %r696,255; $L22: sub.u32 %r695,%r696,%r377; st.u32 [%r502],%r695; .loc 1 108 0 setp.eq.u64 %r697,%r502,%r514; @ %r697 bra $L75; .loc 1 109 0 add.u64 %r698,%r502,%r692; add.u64 %r699,%r698,%r519; ld.u32 %r377,[%r699]; add.u64 %r502,%r502,4; bra $L22; $L72: .loc 1 107 0 mov.u32 %r346,0; bra $L18; $L74: .loc 1 112 0 mov.u32 %r346,1; bra $L18; $L75: mov.u32 %r346,1; $L18: .loc 1 116 0 @ %r910 bra $L23; .loc 1 117 0 @ %r924 bra $L24; @ %r925 bra $L25; bra $L23; $L24: .loc 1 119 0 add.u32 %r261,%r296,-1; cvt.s64.s32 %r703,%r261; shl.b64 %r704,%r703,2; add.u64 %r705,%frame,%r704; add.u64 %r706,%r705,240; ld.u32 %r712,[%r706]; and.b32 %r711,%r712,127; st.u32 [%r706],%r711; bra $L23; $L25: .loc 1 121 0 add.u32 %r265,%r296,-1; cvt.s64.s32 %r713,%r265; shl.b64 %r714,%r713,2; add.u64 %r715,%frame,%r714; add.u64 %r716,%r715,240; ld.u32 %r722,[%r716]; and.b32 %r721,%r722,63; st.u32 [%r716],%r721; $L23: .loc 1 124 0 setp.ne.u32 %r723,%r330,2; @ %r723 bra $L17; .loc 1 125 0 mov.f32 %r724,0f3f800000; sub.f32 %r331,%r724,%r331; .loc 1 126 0 setp.eq.u32 %r725,%r346,0; @ %r725 bra $L17; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r724; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r252; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r728,[%value_in]; } sub.f32 %r331,%r331,%r728; $L17: .loc 1 131 0 setp.neu.f32 %r729,%r331,0f00000000; @ %r729 bra $L26; .loc 1 133 0 add.u32 %r358,%r296,-1; setp.gt.s32 %r730,%r337,%r358; @ %r730 bra $L27; cvt.s64.s32 %r912,%r358; shl.b64 %r493,%r912,2; add.u64 %r491,%r921,%r493; add.u64 %r735,%r927,%r493; not.b32 %r736,%r337; add.u32 %r737,%r736,%r296; cvt.u64.u32 %r738,%r737; shl.b64 %r739,%r738,2; sub.u64 %r501,%r735,%r739; .loc 1 132 0 mov.u32 %r353,0; $L28: .loc 1 133 0 ld.u32 %r740,[%r491]; or.b32 %r353,%r353,%r740; add.u64 %r491,%r491,-4; setp.ne.u64 %r741,%r491,%r501; @ %r741 bra $L28; .loc 1 134 0 setp.ne.u32 %r742,%r353,0; @ %r742 bra $L29; $L27: .loc 1 135 0 ld.u32 %r748,[%r932]; setp.ne.u32 %r749,%r748,0; @ %r749 bra $L76; mov.u64 %r484,%r485; mov.u32 %r263,1; $L31: add.u32 %r263,%r263,1; add.u64 %r484,%r484,-4; ld.u32 %r750,[%r484+4]; setp.eq.u32 %r751,%r750,0; @ %r751 bra $L31; bra $L30; $L76: mov.u32 %r263,1; $L30: .loc 1 137 0 add.u32 %r348,%r296,1; add.u32 %r296,%r296,%r263; setp.gt.s32 %r752,%r348,%r296; @ %r752 bra $L10; cvt.s64.s32 %r464,%r348; cvt.s64.s32 %r753,%r379; add.u64 %r754,%r753,%r464; shl.b64 %r755,%r754,2; add.u64 %r463,%r576,%r755; add.u32 %r470,%r908,%r348; cvt.s64.s32 %r757,%r470; shl.b64 %r758,%r757,2; add.u64 %r469,%r933,%r758; shl.b64 %r759,%r464,2; add.u64 %r474,%frame,%r759; add.u32 %r477,%r470,-1; add.u32 %r483,%r296,%r908; $L35: .loc 1 138 0 ld.u32 %r760,[%r463]; cvt.rn.f32.s32 %r415,%r760; st.f32 [%r469],%r415; .loc 1 139 0 @ %r934 bra $L77; cvt.s64.s32 %r763,%r477; shl.b64 %r764,%r763,2; add.u64 %r450,%r933,%r764; mov.u64 %r449,%r571; mov.f32 %r351,0f00000000; $L34: ld.f32 %r765,[%r449]; fma.rn.f32 %r351,%r765,%r415,%r351; add.u64 %r449,%r449,4; setp.eq.u64 %r766,%r449,%r461; @ %r766 bra $L33; ld.f32 %r415,[%r450]; add.u64 %r450,%r450,-4; bra $L34; $L77: mov.f32 %r351,0f00000000; $L33: .loc 1 140 0 st.f32 [%r474],%r351; add.u64 %r463,%r463,4; add.u64 %r469,%r469,4; add.u64 %r474,%r474,4; add.u32 %r477,%r477,1; .loc 1 137 0 setp.ne.u32 %r767,%r477,%r483; @ %r767 bra $L35; bra $L10; $L29: .loc 1 149 0 add.u32 %r252,%r252,-8; .loc 1 150 0 shl.b64 %r769,%r912,2; add.u64 %r770,%frame,%r769; ld.u32 %r772,[%r770+240]; setp.ne.u32 %r773,%r772,0; @ %r773 bra $L36; add.u32 %r775,%r296,-2; cvt.s64.s32 %r776,%r775; shl.b64 %r777,%r776,2; add.u64 %r443,%r921,%r777; $L37: add.u32 %r358,%r358,-1; add.u32 %r252,%r252,-8; add.u64 %r443,%r443,-4; ld.u32 %r778,[%r443+4]; setp.eq.u32 %r779,%r778,0; @ %r779 bra $L37; bra $L36; $L26: .loc 1 152 0 neg.s32 %r782,%r252; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r331; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r782; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r783,[%value_in]; } .loc 1 153 0 setp.ge.f32 %r784,%r783,0f43800000; @ ! %r784 bra $L115; .loc 1 154 0 mul.f32 %r785,%r783,0f3b800000; cvt.rzi.s32.f32 %r786,%r785; cvt.rn.f32.s32 %r356,%r786; .loc 1 155 0 shl.b64 %r788,%r909,2; add.u64 %r789,%frame,%r788; fma.rn.f32 %r792,%r356,0fc3800000,%r783; cvt.rzi.s32.f32 %r793,%r792; st.u32 [%r789+240],%r793; .loc 1 156 0 add.u32 %r358,%r296,1; add.u32 %r252,%r252,8; .loc 1 157 0 cvt.s64.s32 %r794,%r358; shl.b64 %r795,%r794,2; add.u64 %r796,%frame,%r795; cvt.rzi.s32.f32 %r798,%r356; st.u32 [%r796+240],%r798; bra $L36; $L115: .loc 1 158 0 shl.b64 %r800,%r909,2; add.u64 %r801,%frame,%r800; cvt.rzi.s32.f32 %r803,%r783; st.u32 [%r801+240],%r803; mov.u32 %r358,%r296; $L36: .loc 1 162 0 mov.f32 %r804,0f3f800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r804; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r252; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r806,[%value_in]; } mov.f32 %r368,%r806; .loc 1 163 0 setp.lt.s32 %r807,%r358,0; @ %r807 bra $L40; cvt.s64.s32 %r808,%r358; shl.b64 %r432,%r808,2; add.u64 %r430,%r921,%r432; add.u64 %r427,%frame,%r432; add.u64 %r442,%frame,236; mov.u64 %r434,%r427; $L41: .loc 1 164 0 ld.u32 %r815,[%r430]; cvt.rn.f32.s32 %r814,%r815; mul.f32 %r816,%r814,%r368; st.f32 [%r434],%r816; mul.f32 %r368,%r368,0f3b800000; add.u64 %r430,%r430,-4; add.u64 %r434,%r434,-4; .loc 1 163 0 setp.ne.u64 %r817,%r430,%r442; @ %r817 bra $L41; add.u64 %r919,%frame,80; add.u32 %r429,%r358,1; mov.u64 %r425,%r919; mov.u32 %r424,0; .loc 1 169 0 mov.f32 %r922,0f3fc90000; bra $L42; $L44: ld.f32 %r818,[%r420]; fma.rn.f32 %r367,%r818,%r407,%r367; add.u32 %r253,%r253,1; setp.lt.s32 %r819,%r337,%r253; @ %r819 bra $L43; add.u64 %r420,%r420,4; setp.gt.s32 %r820,%r253,%r424; @ %r820 bra $L43; ld.f32 %r407,[%r421]; add.u64 %r421,%r421,4; bra $L44; $L78: mov.f32 %r367,0f00000000; $L43: .loc 1 170 0 st.f32 [%r425],%r367; add.u32 %r424,%r424,1; add.u64 %r425,%r425,4; add.u64 %r427,%r427,-4; .loc 1 168 0 setp.eq.u32 %r821,%r424,%r429; @ %r821 bra $L45; $L42: .loc 1 169 0 @ %r916 bra $L78; cvta.const.u64 %r421,PIo2+4; mov.u64 %r420,%r427; mov.f32 %r407,%r922; mov.f32 %r367,0f00000000; mov.u32 %r253,0; bra $L44; $L40: .loc 1 174 0 setp.gt.s32 %r823,%r575,2; @ %r823 bra $L47; setp.gt.s32 %r824,%r575,0; @ %r824 bra $L48; setp.eq.u32 %r825,%r575,0; @ %r825 bra $L79; bra $L51; $L47: setp.eq.u32 %r826,%r575,3; @ ! %r826 bra $L51; $L50: .loc 1 190 0 setp.gt.s32 %r827,%r358,0; @ %r827 bra $L52; .loc 1 200 0 mov.f32 %r359,0f00000000; bra $L53; $L48: .loc 1 183 0 setp.ge.s32 %r828,%r358,0; @ %r828 bra $L54; .loc 1 182 0 mov.f32 %r365,0f00000000; bra $L55; $L56: add.u64 %r396,%r919,%r432; add.u64 %r390,%r919,-4; .loc 1 174 0 mov.f32 %r366,0f00000000; $L57: .loc 1 177 0 ld.f32 %r832,[%r396]; add.f32 %r366,%r366,%r832; add.u64 %r396,%r396,-4; setp.ne.u64 %r833,%r390,%r396; @ %r833 bra $L57; bra $L49; $L79: .loc 1 176 0 mov.f32 %r366,0f00000000; $L49: .loc 1 178 0 setp.eq.u32 %r834,%r330,0; @ %r834 bra $L58; neg.f32 %r366,%r366; $L58: st.f32 [%r572],%r366; .loc 1 179 0 bra $L51; $L54: cvt.s64.s32 %r835,%r358; shl.b64 %r384,%r835,2; add.u64 %r836,%frame,80; add.u64 %r386,%r836,%r384; add.u64 %r375,%frame,76; .loc 1 182 0 mov.f32 %r365,0f00000000; $L59: .loc 1 183 0 ld.f32 %r842,[%r386]; add.f32 %r365,%r365,%r842; add.u64 %r386,%r386,-4; setp.ne.u64 %r843,%r375,%r386; @ %r843 bra $L59; $L55: .loc 1 184 0 setp.eq.u32 %r914,%r330,0; @ %r914 bra $L60; neg.f32 %r845,%r365; st.f32 [%r572],%r845; .loc 1 185 0 ld.f32 %r846,[%frame+80]; sub.f32 %r363,%r846,%r365; .loc 1 186 0 setp.le.s32 %r847,%r358,0; @ %r847 bra $L61; $L70: add.u64 %r389,%frame,84; .loc 1 182 0 mov.u32 %r364,1; $L62: .loc 1 186 0 ld.f32 %r849,[%r389]; add.f32 %r363,%r363,%r849; add.u32 %r364,%r364,1; add.u64 %r389,%r389,4; setp.ge.s32 %r850,%r358,%r364; @ %r850 bra $L62; .loc 1 187 0 @ %r914 bra $L63; $L61: neg.f32 %r363,%r363; $L63: st.f32 [%r572+4],%r363; .loc 1 188 0 bra $L51; $L52: cvt.s64.s32 %r912,%r358; shl.b64 %r853,%r912,2; add.u64 %r854,%frame,%r853; ld.f32 %r283,[%r854+80]; add.u32 %r913,%r358,-1; cvt.s64.s32 %r404,%r913; shl.b64 %r403,%r404,2; add.u64 %r919,%frame,80; add.u64 %r408,%r919,%r403; add.u64 %r918,%frame,76; add.u64 %r860,%r918,%r403; cvt.u64.u32 %r862,%r913; shl.b64 %r863,%r862,2; sub.u64 %r419,%r860,%r863; neg.s64 %r865,%r404; shl.b64 %r866,%r865,2; add.u64 %r357,%r403,4; $L64: .loc 1 191 0 ld.f32 %r302,[%r408]; add.f32 %r361,%r302,%r283; .loc 1 192 0 add.u64 %r867,%r866,%r408; add.u64 %r868,%r867,%r357; sub.f32 %r869,%r302,%r361; add.f32 %r870,%r869,%r283; st.f32 [%r868],%r870; .loc 1 193 0 st.f32 [%r408],%r361; add.u64 %r408,%r408,-4; mov.f32 %r283,%r361; .loc 1 190 0 setp.ne.u64 %r871,%r408,%r419; @ %r871 bra $L64; .loc 1 195 0 setp.le.s32 %r872,%r358,1; @ %r872 bra $L80; shl.b64 %r874,%r912,2; add.u64 %r875,%frame,%r874; ld.f32 %r342,[%r875+80]; cvt.s64.s32 %r327,%r913; shl.b64 %r326,%r327,2; add.u64 %r329,%r919,%r326; add.u32 %r880,%r358,-2; cvt.u64.u32 %r881,%r880; shl.b64 %r412,%r881,2; add.u64 %r882,%r918,%r326; sub.u64 %r409,%r882,%r412; neg.s64 %r884,%r327; shl.b64 %r885,%r884,2; add.u64 %r318,%r326,4; $L65: .loc 1 196 0 ld.f32 %r305,[%r329]; add.f32 %r360,%r305,%r342; .loc 1 197 0 add.u64 %r886,%r885,%r329; add.u64 %r887,%r886,%r318; sub.f32 %r888,%r305,%r360; add.f32 %r889,%r888,%r342; st.f32 [%r887],%r889; .loc 1 198 0 st.f32 [%r329],%r360; add.u64 %r329,%r329,-4; mov.f32 %r342,%r360; .loc 1 195 0 setp.ne.u64 %r890,%r329,%r409; @ %r890 bra $L65; add.u64 %r349,%r919,%r318; add.u64 %r892,%r918,%r318; sub.u64 %r332,%r892,%r412; .loc 1 200 0 mov.f32 %r359,0f00000000; $L66: ld.f32 %r893,[%r349]; add.f32 %r359,%r359,%r893; add.u64 %r349,%r349,-4; setp.ne.u64 %r894,%r332,%r349; @ %r894 bra $L66; bra $L53; $L80: mov.f32 %r359,0f00000000; $L53: ld.f32 %r410,[%frame+80]; ld.f32 %r411,[%frame+84]; .loc 1 201 0 setp.ne.u32 %r895,%r330,0; @ %r895 bra $L67; .loc 1 202 0 st.f32 [%r572],%r410; st.f32 [%r572+4],%r411; st.f32 [%r572+8],%r359; bra $L51; $L67: .loc 1 204 0 neg.f32 %r896,%r410; st.f32 [%r572],%r896; neg.f32 %r897,%r411; st.f32 [%r572+4],%r897; neg.f32 %r898,%r359; st.f32 [%r572+8],%r898; $L51: .loc 1 207 0 and.b32 %r899,%r319,7; bra $L116; $L16: .loc 1 107 0 add.u32 %r319,%r319,1; .loc 1 108 0 setp.gt.s32 %r900,%r296,0; @ %r900 bra $L81; .loc 1 125 0 mov.f32 %r901,0f3f800000; sub.f32 %r331,%r901,%r331; mov.u32 %r330,2; bra $L17; $L45: .loc 1 174 0 setp.gt.s32 %r902,%r575,2; @ %r902 bra $L69; setp.gt.s32 %r903,%r575,0; @ %r903 bra $L48; setp.eq.u32 %r904,%r575,0; @ %r904 bra $L56; bra $L51; $L69: setp.eq.u32 %r905,%r575,3; @ %r905 bra $L50; bra $L51; $L60: .loc 1 184 0 st.f32 [%r572],%r365; .loc 1 185 0 ld.f32 %r906,[%frame+80]; sub.f32 %r363,%r906,%r365; .loc 1 186 0 setp.gt.s32 %r907,%r358,0; @ %r907 bra $L70; bra $L63; $L116: .loc 1 208 0 mov.u32 %value,%r899; st.param.u32 [%value_out],%value; ret; } lib_a-kf_sin.o/ 0 0 0 644 1966 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .visible .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libm/math/kf_sin.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_sinf .visible .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r31; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .pred %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; mov.f32 %r43,%ar0; mov.f32 %r44,%ar1; mov.u32 %r45,%ar2; .loc 1 40 0 mov.b32 %r31,%r43; .loc 1 41 0 and.b32 %r46,%r31,2147483647; .loc 1 42 0 setp.gt.s32 %r47,%r46,838860799; @ %r47 bra $L2; .loc 1 43 0 cvt.rzi.s32.f32 %r48,%r43; setp.eq.u32 %r49,%r48,0; @ %r49 bra $L5; $L2: .loc 1 44 0 mul.f32 %r34,%r43,%r43; .loc 1 45 0 mul.f32 %r35,%r43,%r34; .loc 1 46 0 fma.rn.f32 %r50,%r34,0f2f2ec9d3,0fb2d72f34; fma.rn.f32 %r51,%r50,%r34,0f3638ef1b; fma.rn.f32 %r52,%r51,%r34,0fb9500d01; fma.rn.f32 %r36,%r52,%r34,0f3c088889; .loc 1 47 0 setp.ne.u32 %r53,%r45,0; @ %r53 bra $L4; fma.rn.f32 %r54,%r34,%r36,0fbe2aaaab; fma.rn.f32 %r42,%r54,%r35,%r43; bra $L1; $L4: .loc 1 48 0 mul.f32 %r55,%r35,%r36; neg.f32 %r56,%r55; fma.rn.f32 %r57,%r44,0f3f000000,%r56; neg.f32 %r58,%r44; fma.rn.f32 %r59,%r57,%r34,%r58; fma.rn.f32 %r60,%r35,0f3e2aaaab,%r59; sub.f32 %r42,%r43,%r60; bra $L1; $L5: .loc 1 43 0 mov.f32 %r42,%r43; $L1: .loc 1 49 0 mov.f32 %value,%r42; st.param.f32 [%value_out],%value; ret; } lib_a-kf_tan.o/ 0 0 0 644 4600 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_tanf .visible .func (.param .f32 %value_out) __kernel_tanf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libm/math/kf_tan.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __kernel_tanf .visible .func (.param .f32 %value_out) __kernel_tanf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .f32 %r36; .reg .u32 %r51; .reg .u32 %r52; .reg .f32 %r55; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r69; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .f32 %r82; .reg .f32 %r83; .reg .pred %r84; .reg .f32 %r85; .reg .pred %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r109; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .f32 %r114; .reg .pred %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .f32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .pred %r126; mov.f32 %r72,%ar0; mov.f32 %r73,%ar1; mov.u32 %r74,%ar2; .loc 1 50 0 mov.b32 %r51,%r72; .loc 1 51 0 and.b32 %r52,%r51,2147483647; .loc 1 52 0 setp.gt.s32 %r75,%r52,830472191; @ %r75 bra $L2; .loc 1 53 0 cvt.rzi.s32.f32 %r76,%r72; setp.ne.u32 %r77,%r76,0; @ ! %r77 bra $L13; setp.le.s32 %r126,%r52,1059889471; bra $L3; $L13: .loc 1 54 0 add.u32 %r78,%r74,1; or.b32 %r79,%r78,%r52; setp.ne.u32 %r80,%r79,0; @ %r80 bra $L4; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r72; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r82,[%value_in]; } mov.f32 %r83,0f3f800000; div.rn.f32 %r71,%r83,%r82; bra $L1; $L4: .loc 1 55 0 setp.eq.u32 %r84,%r74,1; @ %r84 bra $L8; mov.f32 %r85,0fbf800000; div.rn.f32 %r71,%r85,%r72; bra $L1; $L2: .loc 1 58 0 setp.le.s32 %r126,%r52,1059889471; @ %r126 bra $L3; .loc 1 59 0 setp.ge.s32 %r87,%r51,0; @ %r87 bra $L6; neg.f32 %r72,%r72; neg.f32 %r73,%r73; $L6: .loc 1 60 0 mov.f32 %r88,0f3f490fda; sub.f32 %r55,%r88,%r72; .loc 1 61 0 mov.f32 %r90,0f33222168; sub.f32 %r89,%r90,%r73; .loc 1 62 0 add.f32 %r72,%r89,%r55; mov.f32 %r73,0f00000000; $L3: .loc 1 64 0 mul.f32 %r58,%r72,%r72; .loc 1 65 0 mul.f32 %r59,%r58,%r58; .loc 1 72 0 mul.f32 %r61,%r72,%r58; .loc 1 71 0 fma.rn.f32 %r91,%r59,0f37d95384,0f3895c07a; fma.rn.f32 %r92,%r91,%r59,0f398137b9; fma.rn.f32 %r93,%r92,%r59,0f3abede48; fma.rn.f32 %r94,%r93,%r59,0f3c11371f; fma.rn.f32 %r95,%r94,%r59,0f3d5d0dd1; .loc 1 70 0 fma.rn.f32 %r96,%r59,0fb79bae5f,0f38a3f445; fma.rn.f32 %r97,%r96,%r59,0f3a1a26c8; fma.rn.f32 %r98,%r97,%r59,0f3b6b6916; fma.rn.f32 %r99,%r98,%r59,0f3cb327a4; fma.rn.f32 %r100,%r99,%r59,0f3e088889; .loc 1 73 0 fma.rn.f32 %r101,%r95,%r58,%r100; fma.rn.f32 %r36,%r101,%r61,%r73; fma.rn.f32 %r62,%r36,%r58,%r73; .loc 1 74 0 fma.rn.f32 %r63,%r61,0f3eaaaaab,%r62; .loc 1 75 0 add.f32 %r71,%r72,%r63; .loc 1 76 0 @ %r126 bra $L7; .loc 1 77 0 cvt.rn.f32.s32 %r69,%r74; .loc 1 78 0 mul.f32 %r103,%r71,%r71; add.f32 %r104,%r71,%r69; div.rn.f32 %r105,%r103,%r104; sub.f32 %r106,%r105,%r63; sub.f32 %r107,%r72,%r106; fma.rn.f32 %r109,%r107,0fc0000000,%r69; shr.s32 %r110,%r51,30; and.b32 %r111,%r110,2; mov.u32 %r113,1; sub.u32 %r112,%r113,%r111; cvt.rn.f32.s32 %r114,%r112; mul.f32 %r71,%r109,%r114; bra $L1; $L7: .loc 1 80 0 setp.eq.u32 %r115,%r74,1; @ %r115 bra $L1; .loc 1 88 0 mov.b32 %r117,%r71; and.b32 %r116,%r117,-4096; mov.b32 %r64,%r116; .loc 1 90 0 mov.f32 %r118,0fbf800000; div.rn.f32 %r66,%r118,%r71; .loc 1 92 0 mov.b32 %r120,%r66; and.b32 %r119,%r120,-4096; mov.b32 %r67,%r119; .loc 1 89 0 sub.f32 %r121,%r64,%r72; sub.f32 %r122,%r63,%r121; .loc 1 93 0 fma.rn.f32 %r123,%r64,%r67,0f3f800000; .loc 1 94 0 fma.rn.f32 %r124,%r122,%r67,%r123; fma.rn.f32 %r71,%r124,%r66,%r67; bra $L1; $L8: .loc 1 55 0 mov.f32 %r71,%r72; $L1: .loc 1 96 0 mov.f32 %value,%r71; st.param.f32 [%value_out],%value; ret; } lib_a-ldexpl.o/ 0 0 0 644 1007 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexpl .visible .func (.param .f64 %value_out) ldexpl (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/common/ldexpl.c" // BEGIN GLOBAL FUNCTION DECL: ldexp .extern .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: ldexpl .visible .func (.param .f64 %value_out) ldexpl (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u32 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-lgammal.o/0 0 0 644 808 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lgammal .visible .func (.param .f64 %value_out) lgammal (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/lgammal.c" // BEGIN GLOBAL FUNCTION DECL: lgamma .extern .func (.param .f64 %value_out) lgamma (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: lgammal .visible .func (.param .f64 %value_out) lgammal (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),lgamma,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-llrintl.o/0 0 0 644 808 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llrintl .visible .func (.param .u64 %value_out) llrintl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/llrintl.c" // BEGIN GLOBAL FUNCTION DECL: llrint .extern .func (.param .u64 %value_out) llrint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: llrintl .visible .func (.param .u64 %value_out) llrintl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),llrint,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } /391 0 0 0 644 816 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llroundl .visible .func (.param .u64 %value_out) llroundl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/llroundl.c" // BEGIN GLOBAL FUNCTION DECL: llround .extern .func (.param .u64 %value_out) llround (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: llroundl .visible .func (.param .u64 %value_out) llroundl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),llround,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-log10l.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log10l .visible .func (.param .f64 %value_out) log10l (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/log10l.c" // BEGIN GLOBAL FUNCTION DECL: log10 .extern .func (.param .f64 %value_out) log10 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log10l .visible .func (.param .f64 %value_out) log10l (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),log10,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-log1pl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log1pl .visible .func (.param .f64 %value_out) log1pl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/log1pl.c" // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log1pl .visible .func (.param .f64 %value_out) log1pl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-logl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: logl .visible .func (.param .f64 %value_out) logl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/logl.c" // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: logl .visible .func (.param .f64 %value_out) logl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),log,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-lrintl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lrintl .visible .func (.param .u64 %value_out) lrintl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/lrintl.c" // BEGIN GLOBAL FUNCTION DECL: lrint .extern .func (.param .u64 %value_out) lrint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: lrintl .visible .func (.param .u64 %value_out) lrintl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),lrint,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-lroundl.o/0 0 0 644 808 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lroundl .visible .func (.param .u64 %value_out) lroundl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/lroundl.c" // BEGIN GLOBAL FUNCTION DECL: lround .extern .func (.param .u64 %value_out) lround (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: lroundl .visible .func (.param .u64 %value_out) lroundl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),lround,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-modfl.o/ 0 0 0 644 999 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modfl .visible .func (.param .f64 %value_out) modfl (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/modfl.c" // BEGIN GLOBAL FUNCTION DECL: modf .extern .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: modfl .visible .func (.param .f64 %value_out) modfl (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),modf,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-nanl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nanl .visible .func (.param .f64 %value_out) nanl (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libm/common/nanl.c" // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nanl .visible .func (.param .f64 %value_out) nanl (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .f64 %r25; mov.u64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; call (%value_in),nan,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /409 0 0 0 644 832 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nearbyintl .visible .func (.param .f64 %value_out) nearbyintl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/nearbyintl.c" // BEGIN GLOBAL FUNCTION DECL: nearbyint .extern .func (.param .f64 %value_out) nearbyint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nearbyintl .visible .func (.param .f64 %value_out) nearbyintl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),nearbyint,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /429 0 0 0 644 1039 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nextafterl .visible .func (.param .f64 %value_out) nextafterl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/nextafterl.c" // BEGIN GLOBAL FUNCTION DECL: nextafter .extern .func (.param .f64 %value_out) nextafter (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: nextafterl .visible .func (.param .f64 %value_out) nextafterl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),nextafter,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-powl.o/ 0 0 0 644 991 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: powl .visible .func (.param .f64 %value_out) powl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/powl.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: powl .visible .func (.param .f64 %value_out) powl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } /449 0 0 0 644 1039 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remainderl .visible .func (.param .f64 %value_out) remainderl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/remainderl.c" // BEGIN GLOBAL FUNCTION DECL: remainder .extern .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: remainderl .visible .func (.param .f64 %value_out) remainderl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),remainder,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-remquol.o/0 0 0 644 1222 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remquol .visible .func (.param .f64 %value_out) remquol (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/common/remquol.c" // BEGIN GLOBAL FUNCTION DECL: remquo .extern .func (.param .f64 %value_out) remquo (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: remquol .visible .func (.param .f64 %value_out) remquol (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f64 %r23; .reg .f64 %r24; .reg .u64 %r25; .reg .f64 %r29; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),remquo,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r29,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r29; st.param.f64 [%value_out],%value; ret; } lib_a-rintl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rintl .visible .func (.param .f64 %value_out) rintl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/rintl.c" // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: rintl .visible .func (.param .f64 %value_out) rintl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),rint,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-roundl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: roundl .visible .func (.param .f64 %value_out) roundl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/roundl.c" // BEGIN GLOBAL FUNCTION DECL: round .extern .func (.param .f64 %value_out) round (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: roundl .visible .func (.param .f64 %value_out) roundl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),round,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-s_asinh.o/0 0 0 644 3815 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinh .visible .func (.param .f64 %value_out) asinh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_asinh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinh .visible .func (.param .f64 %value_out) asinh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r36; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r41; .reg .f64 %r42; .reg .u64 %r43; .reg .u64 %r44; .reg .pred %r45; .reg .pred %r46; .reg .f64 %r47; .reg .pred %r48; .reg .pred %r49; .reg .f64 %r51; .reg .f64 %r53; .reg .pred %r54; .reg .f64 %r56; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r67; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .pred %r76; mov.f64 %r42,%ar0; .loc 1 89 0 mov.b64 %r43,%r42; shr.u64 %r44,%r43,32; cvt.u32.u64 %r36,%r44; .loc 1 90 0 and.b32 %r37,%r36,2147483647; .loc 1 91 0 setp.le.s32 %r45,%r37,2146435071; @ %r45 bra $L2; add.f64 %r41,%r42,%r42; bra $L1; $L2: .loc 1 92 0 setp.gt.s32 %r46,%r37,1043333119; @ %r46 bra $L4; .loc 1 93 0 add.f64 %r47,%r42,0d7e37e43c8800759c; setp.gt.f64 %r48,%r47,0d3ff0000000000000; @ %r48 bra $L8; bra $L5; $L4: .loc 1 95 0 setp.le.s32 %r49,%r37,1102053376; @ %r49 bra $L6; .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r51,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r51; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r53,[%value_in]; } add.f64 %r41,%r53,0d3fe62e42fefa39ef; bra $L7; $L6: .loc 1 97 0 setp.le.s32 %r54,%r37,1073741824; @ %r54 bra $L5; .loc 1 98 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r56,[%value_in]; } .loc 1 99 0 fma.rn.f64 %r58,%r42,%r42,0d3ff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r58; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r59,[%value_in]; } add.f64 %r61,%r59,%r56; mov.f64 %r63,0d3ff0000000000000; div.rn.f64 %r62,%r63,%r61; fma.rn.f64 %r64,%r56,0d4000000000000000,%r62; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r64; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r65,[%value_in]; } mov.f64 %r41,%r65; bra $L7; $L5: .loc 1 101 0 mul.f64 %r38,%r42,%r42; .loc 1 102 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r67,[%value_in]; } add.f64 %r69,%r38,0d3ff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r69; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r70,[%value_in]; } add.f64 %r72,%r70,0d3ff0000000000000; div.rn.f64 %r73,%r38,%r72; add.f64 %r74,%r73,%r67; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r75,[%value_in]; } mov.f64 %r41,%r75; $L7: .loc 1 104 0 setp.gt.s32 %r76,%r36,0; @ %r76 bra $L1; neg.f64 %r41,%r41; bra $L1; $L8: .loc 1 93 0 mov.f64 %r41,%r42; $L1: .loc 1 105 0 mov.f64 %value,%r41; st.param.f64 [%value_out],%value; ret; } lib_a-s_atan.o/ 0 0 0 644 5095 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan .visible .func (.param .f64 %value_out) atan (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_atan.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN VAR DEF: atanhi .const .align 8 .u64 atanhi[4] = {4602023952714414927,4605249457297304856,4607027438436873883,4609753056924675352 }; // BEGIN VAR DEF: atanlo .const .align 8 .u64 atanlo[4] = {4357843414468748770,4359948597267291143,4354989122426817469,4364452196894661639 }; // BEGIN GLOBAL FUNCTION DEF: atan .visible .func (.param .f64 %value_out) atan (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r26; .reg .f64 %r27; .reg .f64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r31; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .f64 %r51; .reg .f64 %r52; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .pred %r65; .reg .pred %r66; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u16 %r75; .reg .u16 %r76; .reg .u16 %r77; .reg .u32 %r78; .reg .u16 %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .f64 %r84; .reg .pred %r85; .reg .f64 %r87; .reg .pred %r88; .reg .pred %r89; .reg .f64 %r90; .reg .pred %r91; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .pred %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .pred %r118; mov.f64 %r62,%ar0; .loc 1 138 0 mov.b64 %r63,%r62; shr.u64 %r64,%r63,32; cvt.u32.u64 %r46,%r64; .loc 1 139 0 and.b32 %r47,%r46,2147483647; .loc 1 140 0 setp.le.s32 %r65,%r47,1141899263; @ %r65 bra $L2; .loc 1 143 0 setp.gt.s32 %r66,%r47,2146435072; @ %r66 bra $L3; .loc 1 144 0 set.u32.eq.u32 %r68,%r47,2146435072; neg.s32 %r69,%r68; cvt.u32.u64 %r72,%r63; set.u32.ne.u32 %r73,%r72,0; neg.s32 %r74,%r73; cvt.u16.u32 %r76,%r69; cvt.u16.u32 %r77,%r74; and.b16 %r75,%r76,%r77; .loc 1 143 0 cvt.u32.u16 %r78,%r75; cvt.u16.u8 %r79,%r78; setp.eq.u16 %r80,%r79,0; @ %r80 bra $L4; $L3: .loc 1 145 0 add.f64 %r61,%r62,%r62; bra $L1; $L4: .loc 1 146 0 setp.le.s32 %r81,%r46,0; selp.f64 %r61,0dbff921fb54442d18,0d3ff921fb54442d18,%r81; bra $L1; $L2: .loc 1 148 0 setp.gt.s32 %r82,%r47,1071382527; @ %r82 bra $L6; .loc 1 149 0 setp.gt.s32 %r83,%r47,1042284543; @ %r83 bra $L13; .loc 1 150 0 add.f64 %r84,%r62,0d7e37e43c8800759c; setp.gt.f64 %r85,%r84,0d3ff0000000000000; @ %r85 bra $L14; .loc 1 152 0 mov.u32 %r45,-1; bra $L7; $L6: .loc 1 154 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r87,[%value_in]; } .loc 1 155 0 setp.gt.s32 %r88,%r47,1072889855; @ %r88 bra $L8; .loc 1 156 0 setp.gt.s32 %r89,%r47,1072037887; @ %r89 bra $L9; .loc 1 157 0 fma.rn.f64 %r26,%r87,0d4000000000000000,0dbff0000000000000; add.f64 %r27,%r87,0d4000000000000000; div.rn.f64 %r62,%r26,%r27; mov.u32 %r45,0; bra $L7; $L9: .loc 1 159 0 mov.f64 %r90,0d3ff0000000000000; sub.f64 %r28,%r87,%r90; add.f64 %r29,%r87,0d3ff0000000000000; div.rn.f64 %r62,%r28,%r29; mov.u32 %r45,1; bra $L7; $L8: .loc 1 162 0 setp.gt.s32 %r91,%r47,1073971199; @ %r91 bra $L10; .loc 1 163 0 mov.f64 %r92,0d3ff8000000000000; sub.f64 %r30,%r87,%r92; fma.rn.f64 %r31,%r87,0d3ff8000000000000,0d3ff0000000000000; div.rn.f64 %r62,%r30,%r31; mov.u32 %r45,2; bra $L7; $L10: .loc 1 165 0 mov.f64 %r93,0dbff0000000000000; div.rn.f64 %r62,%r93,%r87; mov.u32 %r45,3; bra $L7; $L13: .loc 1 152 0 mov.u32 %r45,-1; $L7: .loc 1 169 0 mul.f64 %r51,%r62,%r62; .loc 1 170 0 mul.f64 %r52,%r51,%r51; .loc 1 172 0 fma.rn.f64 %r94,%r52,0d3f90ad3ae322da11,0d3fa97b4b24760deb; fma.rn.f64 %r95,%r94,%r52,0d3fb10d66a0d03d51; fma.rn.f64 %r96,%r95,%r52,0d3fb745cdc54c206e; fma.rn.f64 %r97,%r96,%r52,0d3fc24924920083ff; fma.rn.f64 %r98,%r97,%r52,0d3fd555555555550d; .loc 1 173 0 fma.rn.f64 %r99,%r52,0dbfa2b4442c6a6c2f,0dbfadde2d52defd9a; fma.rn.f64 %r100,%r99,%r52,0dbfb3b0f2af749a6d; fma.rn.f64 %r101,%r100,%r52,0dbfbc71c6fe231671; fma.rn.f64 %r102,%r101,%r52,0dbfc999999998ebc4; mul.f64 %r103,%r102,%r52; fma.rn.f64 %r104,%r98,%r51,%r103; mul.f64 %r60,%r104,%r62; .loc 1 174 0 setp.ne.u32 %r105,%r45,-1; @ %r105 bra $L11; sub.f64 %r61,%r62,%r60; bra $L1; $L11: .loc 1 176 0 cvta.const.u64 %r106,atanhi; cvt.s64.s32 %r107,%r45; shl.b64 %r108,%r107,3; add.u64 %r109,%r106,%r108; cvta.const.u64 %r110,atanlo; add.u64 %r113,%r110,%r108; ld.f64 %r115,[%r113]; sub.f64 %r114,%r60,%r115; sub.f64 %r116,%r114,%r62; ld.f64 %r117,[%r109]; sub.f64 %r61,%r117,%r116; .loc 1 177 0 setp.ge.s32 %r118,%r46,0; @ %r118 bra $L1; neg.f64 %r61,%r61; bra $L1; $L14: .loc 1 150 0 mov.f64 %r61,%r62; $L1: .loc 1 179 0 mov.f64 %value,%r61; st.param.f64 [%value_out],%value; ret; } lib_a-s_cbrt.o/ 0 0 0 644 3621 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cbrt .visible .func (.param .f64 %value_out) cbrt (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_cbrt.c" // BEGIN GLOBAL FUNCTION DEF: cbrt .visible .func (.param .f64 %value_out) cbrt (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r48; .reg .f64 %r50; .reg .f64 %r52; .reg .u32 %r53; .reg .u64 %r60; .reg .u64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .pred %r77; .reg .u64 %r79; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u32 %r109; .reg .u32 %r110; .reg .u64 %r111; .reg .u64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .u32 %r118; .reg .u64 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; mov.f64 %r65,%ar0; mov.b64 %r66,%r65; shr.u64 %r67,%r66,32; cvt.u32.u64 %r53,%r67; .loc 1 84 0 and.b32 %r22,%r53,2147483647; .loc 1 85 0 setp.le.u32 %r68,%r22,2146435071; @ %r68 bra $L2; add.f64 %r64,%r65,%r65; bra $L1; $L2: .loc 1 87 0 cvt.u32.u64 %r71,%r66; or.b32 %r70,%r22,%r71; setp.eq.u32 %r72,%r70,0; @ %r72 bra $L6; .loc 1 90 0 cvt.u64.u32 %r73,%r22; shl.b64 %r74,%r73,32; and.b64 %r75,%r66,4294967295; or.b64 %r76,%r75,%r74; mov.b64 %r42,%r76; .loc 1 92 0 setp.gt.u32 %r77,%r22,1048575; @ %r77 bra $L4; .loc 1 94 0 mul.f64 %r44,%r42,0d4350000000000000; mov.b64 %r60,%r44; shr.u64 %r79,%r60,32; cvt.u32.u64 %r81,%r79; div.u32 %r82,%r81,3; add.u32 %r83,%r82,696219795; cvt.u64.u32 %r84,%r83; shl.b64 %r85,%r84,32; and.b64 %r86,%r60,4294967295; or.b64 %r87,%r86,%r85; mov.b64 %r39,%r87; bra $L5; $L4: .loc 1 97 0 div.s32 %r91,%r22,3; add.u32 %r92,%r91,715094163; cvt.u64.u32 %r93,%r92; shl.b64 %r94,%r93,32; mov.b64 %r39,%r94; $L5: .loc 1 101 0 mul.f64 %r97,%r39,%r39; div.rn.f64 %r98,%r97,%r42; .loc 1 102 0 fma.rn.f64 %r46,%r39,%r98,0d3fe15f15f15f15f1; .loc 1 103 0 add.f64 %r99,%r46,0d3ff6a0ea0ea0ea0f; mov.f64 %r101,0dbfe691de2532c834; div.rn.f64 %r100,%r101,%r46; add.f64 %r102,%r99,%r100; mov.f64 %r104,0d3ff9b6db6db6db6e; div.rn.f64 %r103,%r104,%r102; add.f64 %r105,%r103,0d3fd6db6db6db6db7; mul.f64 %r106,%r105,%r39; .loc 1 107 0 mov.b64 %r107,%r106; shr.u64 %r108,%r107,32; cvt.u32.u64 %r110,%r108; add.u32 %r109,%r110,1; cvt.u64.u32 %r111,%r109; shl.b64 %r115,%r111,32; mov.b64 %r48,%r115; .loc 1 111 0 mul.f64 %r116,%r48,%r48; .loc 1 112 0 div.rn.f64 %r50,%r42,%r116; .loc 1 114 0 sub.f64 %r36,%r50,%r48; fma.rn.f64 %r37,%r48,0d4000000000000000,%r50; div.rn.f64 %r117,%r36,%r37; .loc 1 115 0 fma.rn.f64 %r52,%r48,%r117,%r48; .loc 1 119 0 mov.b64 %r63,%r52; .loc 1 83 0 and.b32 %r118,%r53,-2147483648; .loc 1 119 0 shr.u64 %r120,%r63,32; cvt.u32.u64 %r122,%r120; or.b32 %r121,%r118,%r122; cvt.u64.u32 %r123,%r121; shl.b64 %r124,%r123,32; and.b64 %r125,%r63,4294967295; or.b64 %r126,%r125,%r124; mov.b64 %r64,%r126; .loc 1 120 0 bra $L1; $L6: .loc 1 88 0 mov.f64 %r64,%r65; $L1: .loc 1 121 0 mov.f64 %value,%r64; st.param.f64 [%value_out],%value; ret; } lib_a-s_ceil.o/ 0 0 0 644 3656 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ceil .visible .func (.param .f64 %value_out) ceil (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_ceil.c" // BEGIN GLOBAL FUNCTION DEF: ceil .visible .func (.param .f64 %value_out) ceil (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .f64 %r49; .reg .f64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .u32 %r54; .reg .pred %r55; .reg .pred %r56; .reg .f64 %r57; .reg .pred %r58; .reg .pred %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .f64 %r66; .reg .pred %r67; .reg .pred %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .f64 %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .u32 %r87; .reg .u64 %r88; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; mov.f64 %r50,%ar0; mov.b64 %r51,%r50; shr.u64 %r52,%r51,32; cvt.u32.u64 %r45,%r52; .loc 1 42 0 cvt.u32.u64 %r40,%r52; cvt.u32.u64 %r46,%r51; .loc 1 43 0 shr.s32 %r54,%r45,20; and.b32 %r23,%r54,2047; add.u32 %r42,%r23,-1023; .loc 1 44 0 setp.gt.s32 %r55,%r42,19; @ %r55 bra $L2; .loc 1 45 0 setp.ge.s32 %r56,%r42,0; @ %r56 bra $L3; .loc 1 46 0 add.f64 %r57,%r50,0d7e37e43c8800759c; setp.gt.f64 %r58,%r57,0d0000000000000000; @ ! %r58 bra $L4; .loc 1 47 0 setp.lt.s32 %r59,%r45,0; @ %r59 bra $L13; .loc 1 48 0 or.b32 %r60,%r45,%r46; setp.eq.u32 %r61,%r60,0; @ %r61 bra $L14; mov.u32 %r46,0; mov.u32 %r45,1072693248; bra $L4; $L3: .loc 1 51 0 mov.u32 %r62,1048575; shr.s32 %r47,%r62,%r42; .loc 1 52 0 and.b32 %r63,%r40,%r47; or.b32 %r64,%r63,%r46; setp.eq.u32 %r65,%r64,0; @ %r65 bra $L15; .loc 1 53 0 add.f64 %r66,%r50,0d7e37e43c8800759c; setp.gt.f64 %r67,%r66,0d0000000000000000; @ ! %r67 bra $L4; .loc 1 54 0 setp.le.s32 %r68,%r40,0; @ %r68 bra $L8; mov.u32 %r70,1048576; shr.s32 %r69,%r70,%r42; add.u32 %r40,%r40,%r69; $L8: .loc 1 55 0 not.b32 %r71,%r47; and.b32 %r45,%r71,%r40; mov.u32 %r46,0; bra $L4; $L2: .loc 1 58 0 setp.le.s32 %r72,%r42,51; @ %r72 bra $L9; .loc 1 59 0 setp.ne.u32 %r73,%r42,1024; @ %r73 bra $L16; add.f64 %r49,%r50,%r50; bra $L1; $L9: .loc 1 62 0 add.u32 %r74,%r23,-1043; mov.u32 %r75,-1; shr.u32 %r43,%r75,%r74; .loc 1 63 0 and.b32 %r76,%r43,%r46; setp.eq.u32 %r77,%r76,0; @ %r77 bra $L17; .loc 1 64 0 add.f64 %r78,%r50,0d7e37e43c8800759c; setp.gt.f64 %r79,%r78,0d0000000000000000; @ ! %r79 bra $L4; .loc 1 65 0 setp.le.s32 %r80,%r40,0; @ %r80 bra $L11; .loc 1 66 0 setp.ne.u32 %r81,%r42,20; @ %r81 bra $L12; add.u32 %r40,%r40,1; bra $L11; $L12: .loc 1 68 0 mov.u32 %r83,52; sub.u32 %r82,%r83,%r42; mov.u32 %r85,1; shl.b32 %r84,%r85,%r82; add.u32 %r44,%r84,%r46; .loc 1 69 0 setp.ge.u32 %r86,%r44,%r46; @ %r86 bra $L18; add.u32 %r40,%r40,1; mov.u32 %r46,%r44; bra $L11; $L18: mov.u32 %r46,%r44; $L11: .loc 1 73 0 not.b32 %r87,%r43; and.b32 %r46,%r46,%r87; mov.u32 %r45,%r40; bra $L4; $L13: mov.u32 %r46,0; mov.u32 %r45,-2147483648; bra $L4; $L14: mov.u32 %r46,%r60; mov.u32 %r45,%r46; $L4: .loc 1 76 0 cvt.u64.u32 %r88,%r45; cvt.u64.u32 %r92,%r46; shl.b64 %r93,%r88,32; or.b64 %r94,%r93,%r92; mov.b64 %r49,%r94; .loc 1 77 0 bra $L1; $L15: .loc 1 52 0 mov.f64 %r49,%r50; bra $L1; $L16: mov.f64 %r49,%r50; bra $L1; $L17: mov.f64 %r49,%r50; $L1: .loc 1 78 0 mov.f64 %value,%r49; st.param.f64 [%value_out],%value; ret; } /469 0 0 0 644 1183 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %r27; .reg .f64 %r29; .reg .f64 %r30; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .u64 %r43; mov.f64 %r29,%ar0; mov.f64 %r30,%ar1; .loc 1 78 0 mov.b64 %r27,%r29; shr.u64 %r32,%r27,32; cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; mov.b64 %r35,%r30; shr.u64 %r36,%r35,32; cvt.u32.u64 %r38,%r36; and.b32 %r37,%r38,-2147483648; or.b32 %r39,%r33,%r37; cvt.u64.u32 %r40,%r39; shl.b64 %r41,%r40,32; and.b64 %r42,%r27,4294967295; or.b64 %r43,%r42,%r41; mov.b64 %value,%r43; .loc 1 80 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_cos.o/ 0 0 0 644 3817 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cos .visible .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_cos.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .extern .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .extern .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .extern .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: cos .visible .func (.param .f64 %value_out) cos (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r33; .reg .u32 %r34; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .f64 %r44; .reg .pred %r45; .reg .u32 %r48; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .f64 %r53; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .u32 %r68; .reg .f64 %r69; .reg .f64 %r70; mov.f64 %r38,%ar0; .loc 1 60 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r33,%r40; .loc 1 63 0 and.b32 %r34,%r33,2147483647; .loc 1 64 0 setp.gt.s32 %r41,%r34,1072243195; @ %r41 bra $L2; mov.f64 %r43,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } mov.f64 %r37,%r44; bra $L1; $L2: .loc 1 67 0 setp.le.s32 %r45,%r34,2146435071; @ %r45 bra $L4; sub.f64 %r37,%r38,%r38; bra $L1; $L4: .loc 1 71 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2,(%out_arg1,%out_arg2); ld.param.u32 %r48,[%value_in]; } .loc 1 72 0 and.b32 %r49,%r48,3; setp.eq.u32 %r50,%r49,1; @ %r50 bra $L6; setp.eq.u32 %r51,%r49,2; @ %r51 bra $L7; setp.eq.u32 %r52,%r49,0; @ ! %r52 bra $L9; .loc 1 73 0 ld.f64 %r55,[%frame+8]; ld.f64 %r53,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r53; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r55; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r56,[%value_in]; } mov.f64 %r37,%r56; bra $L1; $L6: .loc 1 74 0 ld.f64 %r60,[%frame+8]; ld.f64 %r57,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r57; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r60; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r49; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r61,[%value_in]; } neg.f64 %r37,%r61; bra $L1; $L7: .loc 1 75 0 ld.f64 %r64,[%frame+8]; ld.f64 %r62,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r64; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r65,[%value_in]; } neg.f64 %r37,%r65; bra $L1; $L9: .loc 1 77 0 ld.f64 %r69,[%frame+8]; mov.u32 %r68,1; ld.f64 %r66,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r69; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r68; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r70,[%value_in]; } mov.f64 %r37,%r70; $L1: .loc 1 80 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } lib_a-s_erf.o/ 0 0 0 644 16272 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erf .visible .func (.param .f64 %value_out) erf (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_erf.c" // BEGIN GLOBAL FUNCTION DECL: erfc .visible .func (.param .f64 %value_out) erfc (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erf .visible .func (.param .f64 %value_out) erf (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r84; .reg .f64 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .u32 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .u64 %r121; .reg .f64 %r122; .reg .f64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .pred %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .pred %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .pred %r149; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .f64 %r158; .reg .f64 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .pred %r163; .reg .f64 %r164; .reg .f64 %r165; .reg .f64 %r166; .reg .pred %r167; .reg .pred %r168; .reg .f64 %r170; .reg .f64 %r171; .reg .f64 %r172; .reg .pred %r173; .reg .f64 %r174; .reg .f64 %r175; .reg .f64 %r176; .reg .f64 %r177; .reg .f64 %r178; .reg .f64 %r179; .reg .f64 %r180; .reg .f64 %r181; .reg .f64 %r182; .reg .f64 %r183; .reg .f64 %r184; .reg .f64 %r185; .reg .f64 %r186; .reg .f64 %r187; .reg .f64 %r188; .reg .f64 %r189; .reg .f64 %r190; .reg .f64 %r191; .reg .f64 %r192; .reg .f64 %r193; .reg .f64 %r194; .reg .f64 %r195; .reg .f64 %r196; .reg .f64 %r197; .reg .u64 %r198; .reg .f64 %r200; .reg .f64 %r201; .reg .f64 %r202; .reg .f64 %r204; .reg .f64 %r205; .reg .f64 %r206; .reg .f64 %r207; .reg .f64 %r208; .reg .pred %r209; .reg .f64 %r210; .reg .f64 %r211; .reg .f64 %r212; .reg .f64 %r213; mov.f64 %r123,%ar0; mov.b64 %r124,%r123; shr.u64 %r125,%r124,32; cvt.u32.u64 %r92,%r125; .loc 1 260 0 cvt.u32.u64 %r86,%r125; .loc 1 261 0 and.b32 %r87,%r92,2147483647; .loc 1 262 0 setp.le.s32 %r126,%r87,2146435071; @ %r126 bra $L2; .loc 1 263 0 shr.u32 %r127,%r92,31; add.u32 %r128,%r127,%r127; .loc 1 264 0 mov.u32 %r130,1; sub.u32 %r129,%r130,%r128; cvt.rn.f64.s32 %r131,%r129; mov.f64 %r133,0d3ff0000000000000; div.rn.f64 %r132,%r133,%r123; add.f64 %r122,%r131,%r132; bra $L1; $L2: .loc 1 267 0 setp.gt.s32 %r134,%r87,1072365567; @ %r134 bra $L4; .loc 1 268 0 setp.gt.s32 %r135,%r87,1043333119; @ %r135 bra $L5; .loc 1 269 0 setp.gt.s32 %r136,%r87,8388607; @ %r136 bra $L6; .loc 1 270 0 mul.f64 %r137,%r123,0d3ff06eba8214db69; fma.rn.f64 %r138,%r123,0d4020000000000000,%r137; mul.f64 %r122,%r138,0d3fc0000000000000; bra $L1; $L6: .loc 1 271 0 fma.rn.f64 %r122,%r123,0d3fc06eba8214db69,%r123; bra $L1; $L5: .loc 1 273 0 mul.f64 %r96,%r123,%r123; .loc 1 274 0 fma.rn.f64 %r139,%r96,0dbef8ead6120016ac,0dbf77a291236668e4; fma.rn.f64 %r140,%r139,%r96,0dbf9d2a51dbd7194f; fma.rn.f64 %r141,%r140,%r96,0dbfd4cd7d691cb913; fma.rn.f64 %r142,%r141,%r96,0d3fc06eba8214db68; .loc 1 275 0 fma.rn.f64 %r143,%r96,0dbed09c4342a26120,0d3f215dc9221c1a10; fma.rn.f64 %r144,%r143,%r96,0d3f74d022c4d36b0f; fma.rn.f64 %r145,%r144,%r96,0d3fb0a54c5536ceba; fma.rn.f64 %r146,%r145,%r96,0d3fd97779cddadc09; fma.rn.f64 %r147,%r146,%r96,0d3ff0000000000000; .loc 1 276 0 div.rn.f64 %r148,%r142,%r147; .loc 1 277 0 fma.rn.f64 %r122,%r123,%r148,%r123; bra $L1; $L4: .loc 1 279 0 setp.gt.s32 %r149,%r87,1072955391; @ %r149 bra $L7; .loc 1 280 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r123; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r151,[%value_in]; } mov.f64 %r152,0d3ff0000000000000; sub.f64 %r93,%r151,%r152; .loc 1 281 0 fma.rn.f64 %r153,%r93,0dbf61bf380a96073f,0d3fa22a36599795eb; fma.rn.f64 %r154,%r153,%r93,0dbfbc63983d3e28ec; fma.rn.f64 %r155,%r154,%r93,0d3fd45fca805120e4; fma.rn.f64 %r156,%r155,%r93,0dbfd7d240fbb8c3f1; fma.rn.f64 %r157,%r156,%r93,0d3fda8d00ad92b34d; fma.rn.f64 %r94,%r157,%r93,0dbf6359b8bef77538; .loc 1 282 0 fma.rn.f64 %r158,%r93,0d3f888b545735151d,0d3f8bedc26b51dd1c; fma.rn.f64 %r159,%r158,%r93,0d3fc02660e763351f; fma.rn.f64 %r160,%r159,%r93,0d3fb2635cd99fe9a7; fma.rn.f64 %r161,%r160,%r93,0d3fe14af092eb6f33; fma.rn.f64 %r162,%r161,%r93,0d3fbb3e6618eee323; fma.rn.f64 %r95,%r162,%r93,0d3ff0000000000000; .loc 1 283 0 setp.lt.s32 %r163,%r92,0; @ %r163 bra $L8; div.rn.f64 %r164,%r94,%r95; add.f64 %r122,%r164,0d3feb0ac160000000; bra $L1; $L8: div.rn.f64 %r165,%r94,%r95; mov.f64 %r166,0dbfeb0ac160000000; sub.f64 %r122,%r166,%r165; bra $L1; $L7: .loc 1 285 0 setp.le.s32 %r167,%r87,1075314687; @ %r167 bra $L9; .loc 1 286 0 setp.ge.s32 %r168,%r92,0; selp.f64 %r122,0d3ff0000000000000,0dbff0000000000000,%r168; bra $L1; $L9: .loc 1 288 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r123; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r170,[%value_in]; } .loc 1 289 0 mul.f64 %r171,%r170,%r170; mov.f64 %r172,0d3ff0000000000000; div.rn.f64 %r89,%r172,%r171; .loc 1 290 0 setp.gt.s32 %r173,%r87,1074191213; @ %r173 bra $L10; .loc 1 292 0 fma.rn.f64 %r174,%r89,0dc023a0efc69ac25c,0dc054526557e4d2f2; fma.rn.f64 %r175,%r174,%r89,0dc067135cebccabb2; .loc 1 291 0 fma.rn.f64 %r176,%r175,%r89,0dc0644cb184282266; fma.rn.f64 %r177,%r176,%r89,0dc04f300ae4cba38d; fma.rn.f64 %r178,%r177,%r89,0dc0251e0441b0e726; fma.rn.f64 %r179,%r178,%r89,0dbfe63416e4ba7360; fma.rn.f64 %r84,%r179,%r89,0dbf843412600d6435; .loc 1 294 0 fma.rn.f64 %r180,%r89,0dbfaeeff2ee749a62,0d401a47ef8e484a93; fma.rn.f64 %r181,%r180,%r89,0d405b28a3ee48ae2c; fma.rn.f64 %r182,%r181,%r89,0d407ad02157700314; .loc 1 293 0 fma.rn.f64 %r183,%r182,%r89,0d40842b1921ec2868; fma.rn.f64 %r184,%r183,%r89,0d407b290dd58a1a71; fma.rn.f64 %r185,%r184,%r89,0d4061350c526ae721; fma.rn.f64 %r186,%r185,%r89,0d4033a6b9bd707687; fma.rn.f64 %r85,%r186,%r89,0d3ff0000000000000; bra $L11; $L10: .loc 1 297 0 fma.rn.f64 %r187,%r89,0dc07e384e9bdc383f,0dc09004616a2e5992; .loc 1 296 0 fma.rn.f64 %r188,%r187,%r89,0dc083ec881375f228; fma.rn.f64 %r189,%r188,%r89,0dc064145d43c5ed98; fma.rn.f64 %r190,%r189,%r89,0dc031c209555f995a; fma.rn.f64 %r191,%r190,%r89,0dbfe993ba70c285de; fma.rn.f64 %r84,%r191,%r89,0dbf84341239e86f4a; .loc 1 299 0 fma.rn.f64 %r192,%r89,0dc03670e242712d62,0d407da874e79fe763; fma.rn.f64 %r193,%r192,%r89,0d40a3f219cedf3be6; .loc 1 298 0 fma.rn.f64 %r194,%r193,%r89,0d40a8ffb7688c246a; fma.rn.f64 %r195,%r194,%r89,0d409802eb189d5118; fma.rn.f64 %r196,%r195,%r89,0d40745cae221b9f0a; fma.rn.f64 %r197,%r196,%r89,0d403e568b261d5190; fma.rn.f64 %r85,%r197,%r89,0d3ff0000000000000; $L11: .loc 1 302 0 mov.b64 %r121,%r170; and.b64 %r198,%r121,-4294967296; mov.b64 %r90,%r198; .loc 1 303 0 neg.f64 %r200,%r90; fma.rn.f64 %r201,%r200,%r90,0dbfe2000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r201; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r202,[%value_in]; } sub.f64 %r204,%r90,%r170; div.rn.f64 %r205,%r84,%r85; add.f64 %r206,%r170,%r90; fma.rn.f64 %r207,%r204,%r206,%r205; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r207; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r208,[%value_in]; } mul.f64 %r91,%r202,%r208; .loc 1 304 0 setp.lt.s32 %r209,%r86,0; @ %r209 bra $L12; div.rn.f64 %r210,%r91,%r170; mov.f64 %r211,0d3ff0000000000000; sub.f64 %r122,%r211,%r210; bra $L1; $L12: div.rn.f64 %r212,%r91,%r170; mov.f64 %r213,0d3ff0000000000000; sub.f64 %r122,%r212,%r213; $L1: .loc 1 305 0 mov.f64 %value,%r122; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: erfc .visible .func (.param .f64 %value_out) erfc (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r86; .reg .f64 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r99; .reg .f64 %r113; .reg .u64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r135; .reg .pred %r136; .reg .pred %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .pred %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .pred %r156; .reg .f64 %r158; .reg .f64 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .f64 %r163; .reg .f64 %r164; .reg .f64 %r165; .reg .f64 %r166; .reg .f64 %r167; .reg .f64 %r168; .reg .f64 %r169; .reg .pred %r170; .reg .f64 %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .f64 %r174; .reg .pred %r175; .reg .f64 %r177; .reg .f64 %r178; .reg .f64 %r179; .reg .pred %r180; .reg .f64 %r181; .reg .f64 %r182; .reg .f64 %r183; .reg .f64 %r184; .reg .f64 %r185; .reg .f64 %r186; .reg .f64 %r187; .reg .f64 %r188; .reg .f64 %r189; .reg .f64 %r190; .reg .f64 %r191; .reg .f64 %r192; .reg .f64 %r193; .reg .u32 %r195; .reg .u32 %r197; .reg .u32 %r198; .reg .u16 %r200; .reg .u16 %r201; .reg .u16 %r202; .reg .u32 %r203; .reg .u16 %r204; .reg .pred %r205; .reg .f64 %r206; .reg .f64 %r207; .reg .f64 %r208; .reg .f64 %r209; .reg .f64 %r210; .reg .f64 %r211; .reg .f64 %r212; .reg .f64 %r213; .reg .f64 %r214; .reg .f64 %r215; .reg .f64 %r216; .reg .u64 %r217; .reg .f64 %r219; .reg .f64 %r220; .reg .f64 %r221; .reg .f64 %r223; .reg .f64 %r224; .reg .f64 %r225; .reg .f64 %r226; .reg .f64 %r227; .reg .pred %r228; .reg .f64 %r229; .reg .f64 %r230; .reg .pred %r231; mov.f64 %r127,%ar0; mov.b64 %r128,%r127; shr.u64 %r129,%r128,32; cvt.u32.u64 %r90,%r129; .loc 1 316 0 cvt.u32.u64 %r88,%r129; .loc 1 317 0 and.b32 %r89,%r90,2147483647; .loc 1 318 0 setp.le.s32 %r130,%r89,2146435071; @ %r130 bra $L15; .loc 1 320 0 shr.u32 %r131,%r90,31; add.u32 %r132,%r131,%r131; cvt.rn.f64.s32 %r133,%r132; mov.f64 %r135,0d3ff0000000000000; div.rn.f64 %r134,%r135,%r127; add.f64 %r126,%r133,%r134; bra $L14; $L15: .loc 1 323 0 setp.gt.s32 %r136,%r89,1072365567; @ %r136 bra $L17; .loc 1 324 0 setp.gt.s32 %r137,%r89,1013972991; @ %r137 bra $L18; .loc 1 325 0 mov.f64 %r138,0d3ff0000000000000; sub.f64 %r126,%r138,%r127; bra $L14; $L18: .loc 1 326 0 mul.f64 %r99,%r127,%r127; .loc 1 327 0 fma.rn.f64 %r139,%r99,0dbef8ead6120016ac,0dbf77a291236668e4; fma.rn.f64 %r140,%r139,%r99,0dbf9d2a51dbd7194f; fma.rn.f64 %r141,%r140,%r99,0dbfd4cd7d691cb913; fma.rn.f64 %r142,%r141,%r99,0d3fc06eba8214db68; .loc 1 328 0 fma.rn.f64 %r143,%r99,0dbed09c4342a26120,0d3f215dc9221c1a10; fma.rn.f64 %r144,%r143,%r99,0d3f74d022c4d36b0f; fma.rn.f64 %r145,%r144,%r99,0d3fb0a54c5536ceba; fma.rn.f64 %r146,%r145,%r99,0d3fd97779cddadc09; fma.rn.f64 %r147,%r146,%r99,0d3ff0000000000000; .loc 1 329 0 div.rn.f64 %r148,%r142,%r147; mul.f64 %r113,%r148,%r127; .loc 1 330 0 setp.gt.s32 %r149,%r90,1070596095; @ %r149 bra $L19; .loc 1 331 0 add.f64 %r150,%r127,%r113; mov.f64 %r151,0d3ff0000000000000; sub.f64 %r126,%r151,%r150; bra $L14; $L19: .loc 1 334 0 mov.f64 %r153,0d3fe0000000000000; sub.f64 %r152,%r127,%r153; add.f64 %r154,%r152,%r113; .loc 1 335 0 sub.f64 %r126,%r153,%r154; bra $L14; $L17: .loc 1 338 0 setp.gt.s32 %r156,%r89,1072955391; @ %r156 bra $L20; .loc 1 339 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r127; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r158,[%value_in]; } mov.f64 %r159,0d3ff0000000000000; sub.f64 %r95,%r158,%r159; .loc 1 340 0 fma.rn.f64 %r160,%r95,0dbf61bf380a96073f,0d3fa22a36599795eb; fma.rn.f64 %r161,%r160,%r95,0dbfbc63983d3e28ec; fma.rn.f64 %r162,%r161,%r95,0d3fd45fca805120e4; fma.rn.f64 %r163,%r162,%r95,0dbfd7d240fbb8c3f1; fma.rn.f64 %r164,%r163,%r95,0d3fda8d00ad92b34d; fma.rn.f64 %r96,%r164,%r95,0dbf6359b8bef77538; .loc 1 341 0 fma.rn.f64 %r165,%r95,0d3f888b545735151d,0d3f8bedc26b51dd1c; fma.rn.f64 %r166,%r165,%r95,0d3fc02660e763351f; fma.rn.f64 %r167,%r166,%r95,0d3fb2635cd99fe9a7; fma.rn.f64 %r168,%r167,%r95,0d3fe14af092eb6f33; fma.rn.f64 %r169,%r168,%r95,0d3fbb3e6618eee323; fma.rn.f64 %r97,%r169,%r95,0d3ff0000000000000; .loc 1 342 0 setp.lt.s32 %r170,%r90,0; @ %r170 bra $L21; .loc 1 343 0 div.rn.f64 %r171,%r96,%r97; mov.f64 %r172,0d3fc3d4fa80000000; sub.f64 %r126,%r172,%r171; bra $L14; $L21: .loc 1 345 0 div.rn.f64 %r173,%r96,%r97; add.f64 %r174,%r173,0d3feb0ac160000000; add.f64 %r126,%r174,0d3ff0000000000000; bra $L14; $L20: .loc 1 348 0 setp.gt.s32 %r175,%r89,1077673983; @ %r175 bra $L22; .loc 1 349 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r127; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r177,[%value_in]; } .loc 1 350 0 mul.f64 %r178,%r177,%r177; mov.f64 %r179,0d3ff0000000000000; div.rn.f64 %r92,%r179,%r178; .loc 1 351 0 setp.gt.s32 %r180,%r89,1074191212; @ %r180 bra $L23; .loc 1 353 0 fma.rn.f64 %r181,%r92,0dc023a0efc69ac25c,0dc054526557e4d2f2; fma.rn.f64 %r182,%r181,%r92,0dc067135cebccabb2; .loc 1 352 0 fma.rn.f64 %r183,%r182,%r92,0dc0644cb184282266; fma.rn.f64 %r184,%r183,%r92,0dc04f300ae4cba38d; fma.rn.f64 %r185,%r184,%r92,0dc0251e0441b0e726; fma.rn.f64 %r186,%r185,%r92,0dbfe63416e4ba7360; fma.rn.f64 %r86,%r186,%r92,0dbf843412600d6435; .loc 1 355 0 fma.rn.f64 %r187,%r92,0dbfaeeff2ee749a62,0d401a47ef8e484a93; fma.rn.f64 %r188,%r187,%r92,0d405b28a3ee48ae2c; fma.rn.f64 %r189,%r188,%r92,0d407ad02157700314; .loc 1 354 0 fma.rn.f64 %r190,%r189,%r92,0d40842b1921ec2868; fma.rn.f64 %r191,%r190,%r92,0d407b290dd58a1a71; fma.rn.f64 %r192,%r191,%r92,0d4061350c526ae721; fma.rn.f64 %r193,%r192,%r92,0d4033a6b9bd707687; fma.rn.f64 %r87,%r193,%r92,0d3ff0000000000000; bra $L24; $L23: .loc 1 357 0 shr.u32 %r195,%r88,31; set.u32.gt.s32 %r197,%r89,1075314687; neg.s32 %r198,%r197; cvt.u16.u32 %r201,%r195; cvt.u16.u32 %r202,%r198; and.b16 %r200,%r201,%r202; cvt.u32.u16 %r203,%r200; cvt.u16.u8 %r204,%r203; setp.ne.u16 %r205,%r204,0; @ %r205 bra $L25; .loc 1 359 0 fma.rn.f64 %r206,%r92,0dc07e384e9bdc383f,0dc09004616a2e5992; .loc 1 358 0 fma.rn.f64 %r207,%r206,%r92,0dc083ec881375f228; fma.rn.f64 %r208,%r207,%r92,0dc064145d43c5ed98; fma.rn.f64 %r209,%r208,%r92,0dc031c209555f995a; fma.rn.f64 %r210,%r209,%r92,0dbfe993ba70c285de; fma.rn.f64 %r86,%r210,%r92,0dbf84341239e86f4a; .loc 1 361 0 fma.rn.f64 %r211,%r92,0dc03670e242712d62,0d407da874e79fe763; fma.rn.f64 %r212,%r211,%r92,0d40a3f219cedf3be6; .loc 1 360 0 fma.rn.f64 %r213,%r212,%r92,0d40a8ffb7688c246a; fma.rn.f64 %r214,%r213,%r92,0d409802eb189d5118; fma.rn.f64 %r215,%r214,%r92,0d40745cae221b9f0a; fma.rn.f64 %r216,%r215,%r92,0d403e568b261d5190; fma.rn.f64 %r87,%r216,%r92,0d3ff0000000000000; $L24: .loc 1 364 0 mov.b64 %r125,%r177; and.b64 %r217,%r125,-4294967296; mov.b64 %r93,%r217; .loc 1 365 0 neg.f64 %r219,%r93; fma.rn.f64 %r220,%r219,%r93,0dbfe2000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r220; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r221,[%value_in]; } .loc 1 366 0 sub.f64 %r223,%r93,%r177; div.rn.f64 %r224,%r86,%r87; add.f64 %r225,%r177,%r93; fma.rn.f64 %r226,%r223,%r225,%r224; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r226; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r227,[%value_in]; } .loc 1 365 0 mul.f64 %r94,%r221,%r227; .loc 1 367 0 setp.le.s32 %r228,%r88,0; @ %r228 bra $L26; div.rn.f64 %r126,%r94,%r177; bra $L14; $L26: div.rn.f64 %r229,%r94,%r177; mov.f64 %r230,0d4000000000000000; sub.f64 %r126,%r230,%r229; bra $L14; $L22: .loc 1 369 0 setp.gt.s32 %r231,%r90,0; @ %r231 bra $L27; $L25: mov.f64 %r126,0d4000000000000000; bra $L14; $L27: mov.f64 %r126,0d0000000000000000; $L14: .loc 1 371 0 mov.f64 %value,%r126; st.param.f64 [%value_out],%value; ret; } lib_a-s_exp10.o/0 0 0 644 925 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp10 .visible .func (.param .f64 %value_out) exp10 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_exp10.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp10 .visible .func (.param .f64 %value_out) exp10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r23,%ar0; .loc 1 77 0 mov.f64 %r24,0d4024000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r23; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 78 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } lib_a-s_expm1.o/0 0 0 644 7800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expm1 .visible .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_expm1.c" // BEGIN GLOBAL FUNCTION DEF: expm1 .visible .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f64 %r37; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .u32 %r59; .reg .f64 %r60; .reg .u32 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .u32 %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r83; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r96; .reg .u64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .u32 %r106; .reg .u32 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .pred %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .f64 %r119; .reg .pred %r120; .reg .f64 %r121; .reg .f64 %r123; .reg .pred %r124; .reg .f64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .pred %r135; .reg .f64 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .pred %r139; .reg .f64 %r140; .reg .pred %r141; .reg .pred %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .u32 %r146; .reg .pred %r147; .reg .f64 %r148; .reg .f64 %r149; .reg .u64 %r151; .reg .u32 %r152; .reg .u32 %r153; .reg .u64 %r154; .reg .u64 %r155; .reg .u64 %r156; .reg .u64 %r157; .reg .pred %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .u32 %r162; .reg .u32 %r163; .reg .u64 %r164; .reg .u64 %r165; .reg .f64 %r168; .reg .u64 %r170; .reg .u32 %r171; .reg .u32 %r172; .reg .u64 %r173; .reg .u64 %r174; .reg .u64 %r175; .reg .u64 %r176; .reg .u32 %r177; .reg .u32 %r178; .reg .u32 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .f64 %r184; .reg .u64 %r186; .reg .u32 %r187; .reg .u32 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .pred %r194; mov.f64 %r100,%ar0; mov.b64 %r101,%r100; shr.u64 %r102,%r101,32; cvt.u32.u64 %r64,%r102; .loc 1 187 0 cvt.u32.u64 %r22,%r102; .loc 1 189 0 and.b32 %r61,%r64,2147483647; .loc 1 192 0 setp.le.u32 %r103,%r61,1078159481; @ %r103 bra $L2; .loc 1 193 0 setp.le.u32 %r104,%r61,1082535489; @ %r104 bra $L3; .loc 1 194 0 setp.le.u32 %r105,%r61,2146435071; @ %r105 bra $L4; .loc 1 197 0 and.b32 %r106,%r64,1048575; cvt.u32.u64 %r109,%r101; or.b32 %r108,%r106,%r109; setp.eq.u32 %r110,%r108,0; @ %r110 bra $L5; .loc 1 198 0 add.f64 %r99,%r100,%r100; bra $L1; $L5: .loc 1 199 0 setp.lt.s32 %r111,%r64,0; selp.f64 %r99,0dbff0000000000000,%r100,%r111; bra $L1; $L4: .loc 1 201 0 setp.gt.f64 %r112,%r100,0d40862e42fefa39ef; @ ! %r112 bra $L3; mov.f64 %r113,0d7e37e43c8800759c; mul.f64 %r99,%r113,0d7e37e43c8800759c; bra $L1; $L22: .loc 1 204 0 add.f64 %r114,%r100,0d01a56e1fc2f8f359; setp.lt.f64 %r115,%r114,0d0000000000000000; @ ! %r115 bra $L30; bra $L25; $L2: .loc 1 210 0 setp.le.u32 %r116,%r61,1071001154; @ %r116 bra $L9; .loc 1 211 0 setp.gt.u32 %r117,%r61,1072734897; @ %r117 bra $L10; .loc 1 212 0 setp.lt.s32 %r118,%r64,0; @ %r118 bra $L11; .loc 1 213 0 mov.f64 %r119,0d3fe62e42fee00000; sub.f64 %r56,%r100,%r119; mov.u32 %r59,1; mov.f64 %r57,0d3dea39ef35793c76; bra $L12; $L11: .loc 1 215 0 add.f64 %r56,%r100,0d3fe62e42fee00000; mov.u32 %r59,-1; mov.f64 %r57,0dbdea39ef35793c76; bra $L12; $L10: .loc 1 217 0 mul.f64 %r83,%r100,0d3ff71547652b82fe; setp.lt.s32 %r120,%r64,0; selp.f64 %r60,0dbfe0000000000000,0d3fe0000000000000,%r120; $L13: add.f64 %r121,%r60,%r83; cvt.rzi.s32.f64 %r59,%r121; .loc 1 218 0 cvt.rn.f64.s32 %r63,%r59; .loc 1 219 0 fma.rn.f64 %r56,%r63,0dbfe62e42fee00000,%r100; .loc 1 220 0 mul.f64 %r57,%r63,0d3dea39ef35793c76; $L12: .loc 1 222 0 sub.f64 %r100,%r56,%r57; .loc 1 223 0 sub.f64 %r123,%r56,%r100; sub.f64 %r58,%r123,%r57; bra $L14; $L9: .loc 1 225 0 setp.gt.u32 %r124,%r61,1016070143; @ %r124 bra $L27; .loc 1 226 0 add.f64 %r62,%r100,0d7e37e43c8800759c; .loc 1 227 0 sub.f64 %r125,%r62,%r62; sub.f64 %r99,%r100,%r125; bra $L1; $L27: .loc 1 229 0 mov.u32 %r59,0; $L14: .loc 1 232 0 mul.f64 %r66,%r100,0d3fe0000000000000; .loc 1 233 0 mul.f64 %r67,%r100,%r66; .loc 1 234 0 fma.rn.f64 %r126,%r67,0dbe8afdb76e09c32d,0d3ed0cfca86e65239; fma.rn.f64 %r127,%r126,%r67,0dbf14ce199eaadbb7; fma.rn.f64 %r128,%r127,%r67,0d3f5a01a019fe5585; fma.rn.f64 %r129,%r128,%r67,0dbfa11111111110f4; fma.rn.f64 %r68,%r129,%r67,0d3ff0000000000000; .loc 1 235 0 neg.f64 %r130,%r66; fma.rn.f64 %r69,%r130,%r68,0d4008000000000000; .loc 1 236 0 sub.f64 %r131,%r68,%r69; neg.f64 %r132,%r100; fma.rn.f64 %r133,%r132,%r69,0d4018000000000000; div.rn.f64 %r134,%r131,%r133; mul.f64 %r70,%r134,%r67; .loc 1 237 0 setp.ne.u32 %r135,%r59,0; @ %r135 bra $L15; neg.f64 %r136,%r67; fma.rn.f64 %r137,%r100,%r70,%r136; sub.f64 %r99,%r100,%r137; bra $L1; $L15: .loc 1 239 0 sub.f64 %r37,%r70,%r58; neg.f64 %r138,%r58; fma.rn.f64 %r71,%r37,%r100,%r138; .loc 1 240 0 sub.f64 %r72,%r71,%r67; .loc 1 241 0 setp.ne.u32 %r139,%r59,-1; @ %r139 bra $L16; sub.f64 %r140,%r100,%r72; fma.rn.f64 %r99,%r140,0d3fe0000000000000,0dbfe0000000000000; bra $L1; $L16: .loc 1 242 0 setp.ne.u32 %r141,%r59,1; @ %r141 bra $L17; .loc 1 243 0 setp.lt.f64 %r142,%r100,0dbfd0000000000000; @ ! %r142 bra $L31; add.f64 %r143,%r100,0d3fe0000000000000; sub.f64 %r144,%r72,%r143; mul.f64 %r99,%r144,0dc000000000000000; bra $L1; $L31: .loc 1 244 0 sub.f64 %r145,%r100,%r72; fma.rn.f64 %r99,%r145,0d4000000000000000,0d3ff0000000000000; bra $L1; $L17: shl.b32 %r93,%r59,20; .loc 1 246 0 add.u32 %r146,%r59,1; setp.le.u32 %r147,%r146,57; @ %r147 bra $L20; .loc 1 248 0 sub.f64 %r148,%r72,%r100; mov.f64 %r149,0d3ff0000000000000; sub.f64 %r80,%r149,%r148; .loc 1 250 0 mov.b64 %r94,%r80; shr.u64 %r151,%r94,32; cvt.u32.u64 %r153,%r151; add.u32 %r152,%r93,%r153; cvt.u64.u32 %r154,%r152; shl.b64 %r155,%r154,32; and.b64 %r156,%r94,4294967295; or.b64 %r157,%r156,%r155; mov.b64 %r81,%r157; .loc 1 251 0 sub.f64 %r99,%r81,%r149; bra $L1; $L20: .loc 1 254 0 setp.gt.s32 %r159,%r59,19; @ %r159 bra $L21; .loc 1 256 0 mov.u32 %r161,2097152; shr.s32 %r160,%r161,%r59; mov.u32 %r163,1072693248; sub.u32 %r162,%r163,%r160; cvt.u64.u32 %r164,%r162; shl.b64 %r165,%r164,32; mov.b64 %r77,%r165; .loc 1 257 0 sub.f64 %r168,%r72,%r100; sub.f64 %r78,%r77,%r168; .loc 1 259 0 mov.b64 %r96,%r78; shr.u64 %r170,%r96,32; cvt.u32.u64 %r172,%r170; add.u32 %r171,%r93,%r172; cvt.u64.u32 %r173,%r171; shl.b64 %r174,%r173,32; and.b64 %r175,%r96,4294967295; or.b64 %r176,%r175,%r174; mov.b64 %r99,%r176; bra $L1; $L21: .loc 1 262 0 mov.u32 %r178,1023; sub.u32 %r177,%r178,%r59; shl.b32 %r179,%r177,20; cvt.u64.u32 %r180,%r179; shl.b64 %r181,%r180,32; mov.b64 %r74,%r181; .loc 1 263 0 add.f64 %r184,%r72,%r74; sub.f64 %r75,%r100,%r184; .loc 1 264 0 add.f64 %r76,%r75,0d3ff0000000000000; .loc 1 266 0 mov.b64 %r98,%r76; shr.u64 %r186,%r98,32; cvt.u32.u64 %r188,%r186; add.u32 %r187,%r93,%r188; cvt.u64.u32 %r189,%r187; shl.b64 %r190,%r189,32; and.b64 %r191,%r98,4294967295; or.b64 %r192,%r191,%r190; mov.b64 %r99,%r192; bra $L1; $L25: .loc 1 199 0 mov.f64 %r99,0dbff0000000000000; bra $L1; $L32: .loc 1 217 0 mul.f64 %r83,%r100,0d3ff71547652b82fe; mov.f64 %r60,0d3fe0000000000000; bra $L13; $L30: mul.f64 %r83,%r100,0d3ff71547652b82fe; mov.f64 %r60,0dbfe0000000000000; bra $L13; $L3: .loc 1 203 0 setp.lt.s32 %r194,%r22,0; @ %r194 bra $L22; bra $L32; $L1: .loc 1 270 0 mov.f64 %value,%r99; st.param.f64 [%value_out],%value; ret; } lib_a-s_fabs.o/ 0 0 0 644 841 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fabs .visible .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_fabs.c" // BEGIN GLOBAL FUNCTION DEF: fabs .visible .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .f64 %r26; .reg .u64 %r28; .reg .u32 %r29; .reg .u32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; mov.f64 %r26,%ar0; .loc 1 69 0 mov.b64 %r24,%r26; shr.u64 %r28,%r24,32; cvt.u32.u64 %r30,%r28; and.b32 %r29,%r30,2147483647; cvt.u64.u32 %r31,%r29; shl.b64 %r32,%r31,32; and.b64 %r33,%r24,4294967295; or.b64 %r34,%r33,%r32; mov.b64 %value,%r34; .loc 1 71 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_fdim.o/ 0 0 0 644 1589 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fdim .visible .func (.param .f64 %value_out) fdim (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_fdim.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fdim .visible .func (.param .f64 %value_out) fdim (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r25; .reg .f64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 52 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r28,[%value_in]; } .loc 1 53 0 setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 54 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 55 0 setp.eq.u32 %r33,%r28,1; @ %r33 bra $L5; .loc 1 58 0 setp.gt.f64 %r34,%r25,%r26; @ ! %r34 bra $L11; sub.f64 %r25,%r25,%r26; bra $L2; $L4: .loc 1 54 0 mov.f64 %r25,%r26; bra $L2; $L5: .loc 1 56 0 mov.f64 %r25,0d7ff0000000000000; bra $L2; $L11: .loc 1 58 0 mov.f64 %r25,0d0000000000000000; $L2: .loc 1 59 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /489 0 0 0 644 753 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_finite.c" // BEGIN GLOBAL FUNCTION DEF: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; mov.f64 %r29,%ar0; .loc 1 31 0 mov.b64 %r31,%r29; shr.u64 %r32,%r31,32; .loc 1 32 0 cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; add.u32 %r35,%r33,-2146435072; shr.u32 %value,%r35,31; .loc 1 33 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_floor.o/0 0 0 644 3663 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: floor .visible .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_floor.c" // BEGIN GLOBAL FUNCTION DEF: floor .visible .func (.param .f64 %value_out) floor (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .f64 %r50; .reg .f64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .pred %r57; .reg .f64 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .f64 %r68; .reg .pred %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r78; .reg .pred %r79; .reg .f64 %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .pred %r88; .reg .u32 %r89; .reg .u64 %r90; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; mov.f64 %r51,%ar0; mov.b64 %r52,%r51; shr.u64 %r53,%r52,32; cvt.u32.u64 %r46,%r53; .loc 1 95 0 cvt.u32.u64 %r41,%r53; cvt.u32.u64 %r47,%r52; .loc 1 96 0 shr.s32 %r55,%r46,20; and.b32 %r23,%r55,2047; add.u32 %r43,%r23,-1023; .loc 1 97 0 setp.gt.s32 %r56,%r43,19; @ %r56 bra $L2; .loc 1 98 0 setp.ge.s32 %r57,%r43,0; @ %r57 bra $L3; .loc 1 99 0 add.f64 %r58,%r51,0d7e37e43c8800759c; setp.gt.f64 %r59,%r58,0d0000000000000000; @ ! %r59 bra $L4; .loc 1 100 0 setp.ge.s32 %r60,%r46,0; @ %r60 bra $L13; .loc 1 101 0 and.b32 %r61,%r46,2147483647; or.b32 %r62,%r61,%r47; setp.eq.u32 %r63,%r62,0; mov.u32 %r47,0; selp.u32 %r46,%r46,-1074790400,%r63; bra $L4; $L3: .loc 1 105 0 mov.u32 %r64,1048575; shr.s32 %r48,%r64,%r43; .loc 1 106 0 and.b32 %r65,%r41,%r48; or.b32 %r66,%r65,%r47; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L15; .loc 1 107 0 add.f64 %r68,%r51,0d7e37e43c8800759c; setp.gt.f64 %r69,%r68,0d0000000000000000; @ ! %r69 bra $L4; .loc 1 108 0 setp.ge.s32 %r70,%r41,0; @ %r70 bra $L8; mov.u32 %r72,1048576; shr.s32 %r71,%r72,%r43; add.u32 %r41,%r41,%r71; $L8: .loc 1 109 0 not.b32 %r73,%r48; and.b32 %r46,%r73,%r41; mov.u32 %r47,0; bra $L4; $L2: .loc 1 112 0 setp.le.s32 %r74,%r43,51; @ %r74 bra $L9; .loc 1 113 0 setp.ne.u32 %r75,%r43,1024; @ %r75 bra $L16; add.f64 %r50,%r51,%r51; bra $L1; $L9: .loc 1 116 0 add.u32 %r76,%r23,-1043; mov.u32 %r77,-1; shr.u32 %r44,%r77,%r76; .loc 1 117 0 and.b32 %r78,%r44,%r47; setp.eq.u32 %r79,%r78,0; @ %r79 bra $L17; .loc 1 118 0 add.f64 %r80,%r51,0d7e37e43c8800759c; setp.gt.f64 %r81,%r80,0d0000000000000000; @ ! %r81 bra $L4; .loc 1 119 0 setp.ge.s32 %r82,%r41,0; @ %r82 bra $L11; .loc 1 120 0 setp.ne.u32 %r83,%r43,20; @ %r83 bra $L12; add.u32 %r41,%r41,1; bra $L11; $L12: .loc 1 122 0 mov.u32 %r85,52; sub.u32 %r84,%r85,%r43; mov.u32 %r87,1; shl.b32 %r86,%r87,%r84; add.u32 %r45,%r86,%r47; .loc 1 123 0 setp.ge.u32 %r88,%r45,%r47; @ %r88 bra $L18; add.u32 %r41,%r41,1; mov.u32 %r47,%r45; bra $L11; $L18: mov.u32 %r47,%r45; $L11: .loc 1 127 0 not.b32 %r89,%r44; and.b32 %r47,%r47,%r89; mov.u32 %r46,%r41; bra $L4; $L13: mov.u32 %r47,0; mov.u32 %r46,%r47; $L4: .loc 1 130 0 cvt.u64.u32 %r90,%r46; cvt.u64.u32 %r94,%r47; shl.b64 %r95,%r90,32; or.b64 %r96,%r95,%r94; mov.b64 %r50,%r96; .loc 1 131 0 bra $L1; $L15: .loc 1 106 0 mov.f64 %r50,%r51; bra $L1; $L16: mov.f64 %r50,%r51; bra $L1; $L17: mov.f64 %r50,%r51; $L1: .loc 1 132 0 mov.f64 %value,%r50; st.param.f64 [%value_out],%value; ret; } lib_a-s_fma.o/ 0 0 0 644 775 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fma .visible .func (.param .f64 %value_out) fma (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../newlib/libm/common/s_fma.c" // BEGIN GLOBAL FUNCTION DEF: fma .visible .func (.param .f64 %value_out) fma (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; mov.f64 %r25,%ar2; .loc 1 53 0 fma.rn.f64 %value,%r23,%r24,%r25; .loc 1 54 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_fmax.o/ 0 0 0 644 1434 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmax .visible .func (.param .f64 %value_out) fmax (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_fmax.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fmax .visible .func (.param .f64 %value_out) fmax (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 44 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 46 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 49 0 setp.gt.f64 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f64 %r24,%r26; bra $L1; $L4: .loc 1 47 0 mov.f64 %r24,%r25; bra $L1; $L5: mov.f64 %r24,%r25; $L1: .loc 1 50 0 mov.f64 %value,%r24; st.param.f64 [%value_out],%value; ret; } lib_a-s_fmin.o/ 0 0 0 644 1434 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmin .visible .func (.param .f64 %value_out) fmin (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_fmin.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fmin .visible .func (.param .f64 %value_out) fmin (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 44 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 46 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 49 0 setp.lt.f64 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f64 %r24,%r26; bra $L1; $L4: .loc 1 47 0 mov.f64 %r24,%r25; bra $L1; $L5: mov.f64 %r24,%r25; $L1: .loc 1 50 0 mov.f64 %value,%r24; st.param.f64 [%value_out],%value; ret; } /507 0 0 0 644 1958 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r32; .reg .f64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .u16 %r45; .reg .u16 %r46; .reg .u16 %r47; .reg .u32 %r48; .reg .u16 %r49; .reg .pred %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .u32 %r55; .reg .u32 %r56; .reg .u16 %r57; .reg .u16 %r58; .reg .u32 %r60; mov.f64 %r33,%ar0; mov.b64 %r34,%r33; shr.u64 %r35,%r34,32; cvt.u32.u64 %r27,%r35; cvt.u32.u64 %r28,%r34; .loc 1 16 0 or.b32 %r37,%r27,%r28; setp.eq.u32 %r38,%r37,0; @ %r38 bra $L3; .loc 1 17 0 set.u32.eq.u32 %r40,%r28,0; neg.s32 %r41,%r40; cvt.u32.u32 %r39,%r41; set.u32.eq.u32 %r43,%r27,-2147483648; neg.s32 %r44,%r43; cvt.u16.u32 %r46,%r44; cvt.u16.u8 %r47,%r39; and.b16 %r45,%r46,%r47; .loc 1 16 0 cvt.u32.u16 %r48,%r45; cvt.u16.u8 %r49,%r48; setp.ne.u16 %r50,%r49,0; @ %r50 bra $L4; .loc 1 19 0 and.b32 %r30,%r27,2147483647; add.u32 %r51,%r30,-1048576; setp.le.u32 %r52,%r51,2145386495; @ %r52 bra $L5; .loc 1 22 0 setp.le.u32 %r53,%r30,1048575; @ %r53 bra $L6; .loc 1 26 0 set.u32.eq.u32 %r55,%r30,2146435072; neg.s32 %r56,%r55; cvt.u16.u32 %r58,%r56; and.b16 %r57,%r58,%r47; .loc 1 18 0 cvt.u32.u16 %r60,%r57; cvt.u32.u8 %r32,%r60; bra $L1; $L3: mov.u32 %r32,2; bra $L1; $L4: mov.u32 %r32,2; bra $L1; $L5: .loc 1 21 0 mov.u32 %r32,4; bra $L1; $L6: .loc 1 25 0 mov.u32 %r32,3; $L1: .loc 1 31 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-s_frexp.o/0 0 0 644 1956 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/s_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r29; .reg .u32 %r30; .reg .u32 %r35; .reg .u64 %r36; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 98 0 mov.b64 %r40,%r38; shr.u64 %r41,%r40,32; cvt.u32.u64 %r29,%r41; .loc 1 99 0 and.b32 %r30,%r29,2147483647; .loc 1 100 0 mov.u32 %r42,0; st.u32 [%r39],%r42; .loc 1 101 0 setp.gt.s32 %r43,%r30,2146435071; @ %r43 bra $L2; cvt.u32.u64 %r46,%r40; or.b32 %r45,%r30,%r46; setp.eq.u32 %r47,%r45,0; @ %r47 bra $L2; .loc 1 102 0 setp.gt.s32 %r48,%r30,1048575; @ %r48 bra $L4; .loc 1 103 0 mul.f64 %r38,%r38,0d4350000000000000; .loc 1 104 0 mov.b64 %r49,%r38; shr.u64 %r50,%r49,32; cvt.u32.u64 %r29,%r50; .loc 1 105 0 and.b32 %r30,%r29,2147483647; mov.u32 %r35,-54; bra $L3; $L4: mov.u32 %r35,%r42; $L3: .loc 1 108 0 shr.s32 %r51,%r30,20; add.u32 %r52,%r51,-1022; add.u32 %r53,%r52,%r35; st.u32 [%r39],%r53; .loc 1 110 0 mov.b64 %r36,%r38; .loc 1 109 0 and.b32 %r54,%r29,-2146435073; or.b32 %r55,%r54,1071644672; .loc 1 110 0 cvt.u64.u32 %r56,%r55; shl.b64 %r57,%r56,32; and.b64 %r58,%r36,4294967295; or.b64 %r59,%r58,%r57; mov.b64 %r38,%r59; $L2: .loc 1 112 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } lib_a-s_ilogb.o/0 0 0 644 1724 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ilogb .visible .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_ilogb.c" // BEGIN GLOBAL FUNCTION DEF: ilogb .visible .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; .reg .u32 %r36; .reg .f64 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r47; .reg .pred %r49; .reg .pred %r50; .reg .u32 %r51; mov.f64 %r37,%ar0; .loc 1 86 0 mov.b64 %r38,%r37; shr.u64 %r39,%r38,32; cvt.u32.u64 %r31,%r39; .loc 1 87 0 and.b32 %r32,%r31,2147483647; .loc 1 88 0 setp.gt.s32 %r40,%r32,1048575; @ %r40 bra $L2; .loc 1 86 0 cvt.u32.u64 %r30,%r38; .loc 1 89 0 or.b32 %r42,%r30,%r32; setp.eq.u32 %r43,%r42,0; @ %r43 bra $L7; .loc 1 92 0 setp.ne.u32 %r44,%r32,0; @ %r44 bra $L4; .loc 1 93 0 setp.le.s32 %r45,%r30,0; @ %r45 bra $L8; mov.u32 %r36,-1043; $L5: add.u32 %r36,%r36,-1; add.u32 %r30,%r30,%r30; setp.gt.s32 %r47,%r30,0; @ %r47 bra $L5; bra $L1; $L4: .loc 1 95 0 shl.b32 %r33,%r32,11; mov.u32 %r36,-1022; $L6: add.u32 %r36,%r36,-1; add.u32 %r33,%r33,%r33; setp.gt.s32 %r49,%r33,0; @ %r49 bra $L6; bra $L1; $L2: .loc 1 99 0 setp.gt.s32 %r50,%r32,2146435071; @ %r50 bra $L9; shr.s32 %r51,%r32,20; add.u32 %r36,%r51,-1023; bra $L1; $L7: .loc 1 90 0 mov.u32 %r36,-2147483647; bra $L1; $L8: .loc 1 93 0 mov.u32 %r36,-1043; bra $L1; $L9: .loc 1 103 0 mov.u32 %r36,2147483647; $L1: .loc 1 104 0 mov.u32 %value,%r36; st.param.u32 [%value_out],%value; ret; } /529 0 0 0 644 393 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL VAR DEF: __infinity .visible .const .align 8 .u64 __infinity[1] = {9218868437227405312 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: __infinityld .visible .const .align 8 .u64 __infinityld[2] = {9218868437227405312 }; // BEGIN GLOBAL VAR DEF: __infinityf .visible .const .align 4 .u32 __infinityf[1] = {2139095040 }; /549 0 0 0 644 433 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: infinity .visible .func (.param .f64 %value_out) infinity; .file 1 "../../../../../newlib/libm/common/s_infinity.c" // BEGIN GLOBAL FUNCTION DEF: infinity .visible .func (.param .f64 %value_out) infinity { .reg .f64 %value; .loc 1 45 0 mov.f64 %value,0d7ff0000000000000; .loc 1 47 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_isinf.o/0 0 0 644 1166 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 22 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 24 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 23 0 and.b32 %r48,%r33,2147483647; .loc 1 24 0 or.b32 %r27,%r47,%r48; .loc 1 25 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 26 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 27 0 st.param.u32 [%value_out],%value; ret; } /569 0 0 0 644 1179 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isinfd.c" // BEGIN GLOBAL FUNCTION DEF: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 16 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 18 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 17 0 and.b32 %r48,%r33,2147483647; .loc 1 18 0 or.b32 %r27,%r47,%r48; .loc 1 19 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 20 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 21 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_isnan.o/0 0 0 644 1027 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 199 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 201 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 200 0 and.b32 %r45,%r30,2147483647; .loc 1 201 0 or.b32 %r27,%r44,%r45; .loc 1 202 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 203 0 shr.u32 %value,%r47,31; .loc 1 204 0 st.param.u32 [%value_out],%value; ret; } /587 0 0 0 644 1040 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isnand.c" // BEGIN GLOBAL FUNCTION DEF: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 115 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 117 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 116 0 and.b32 %r45,%r30,2147483647; .loc 1 117 0 or.b32 %r27,%r44,%r45; .loc 1 118 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 119 0 shr.u32 %value,%r47,31; .loc 1 120 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_ldexp.o/0 0 0 644 2584 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/math/s_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f64 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f64 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 75 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f64 %r37,%r32,0d0000000000000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } mov.f64 %r32,%r50; .loc 1 77 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f64 %r54,%r32,0d0000000000000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 79 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } /605 0 0 0 644 177 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL VAR DEF: __fdlib_version .visible .global .align 4 .u32 __fdlib_version[1] = {1 }; /624 0 0 0 644 4061 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llrint .visible .func (.param .u64 %value_out) llrint (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_llrint.c" // BEGIN VAR DEF: TWO52 .const .align 8 .u64 TWO52[2] = {4841369599423283200,-4382002437431492608 }; // BEGIN GLOBAL FUNCTION DEF: llrint .visible .func (.param .u64 %value_out) llrint (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .u32 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .u32 %r45; .reg .u32 %r48; .reg .u32 %r53; .reg .f64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r65; .reg .u64 %r70; .reg .f64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .f64 %r81; .reg .u64 %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .pred %r93; .reg .pred %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u64 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u32 %r101; .reg .u32 %r102; .reg .u32 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u64 %r113; .reg .u32 %r114; .reg .u32 %r116; .reg .pred %r117; .reg .u32 %r119; .reg .u32 %r120; .reg .u64 %r121; .reg .pred %r122; mov.f64 %r71,%ar0; mov.b64 %r72,%r71; shr.u64 %r73,%r72,32; cvt.u32.u64 %r65,%r73; .loc 1 60 0 shr.u32 %r22,%r65,31; .loc 1 63 0 shr.s32 %r74,%r65,20; and.b32 %r24,%r74,2047; add.u32 %r53,%r24,-1023; .loc 1 66 0 setp.gt.s32 %r75,%r53,19; @ %r75 bra $L2; .loc 1 69 0 setp.ge.s32 %r76,%r53,-1; @ %r76 bra $L3; $L5: .loc 1 70 0 mov.u64 %r70,0; bra $L1; $L3: .loc 1 75 0 cvta.const.u64 %r77,TWO52; cvt.s64.s32 %r78,%r22; shl.b64 %r79,%r78,3; add.u64 %r80,%r77,%r79; ld.f64 %r25,[%r80]; add.f64 %r26,%r25,%r71; st.f64 [%frame],%r26; .loc 1 76 0 ld.f64 %r27,[%frame]; sub.f64 %r81,%r27,%r25; .loc 1 77 0 mov.b64 %r82,%r81; shr.u64 %r83,%r82,32; cvt.u32.u64 %r61,%r83; .loc 1 80 0 and.b32 %r84,%r61,2147483647; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L5; .loc 1 84 0 and.b32 %r63,%r61,1048575; .loc 1 85 0 or.b32 %r86,%r63,1048576; .loc 1 83 0 shr.s32 %r87,%r61,20; and.b32 %r88,%r87,2047; .loc 1 87 0 mov.u32 %r91,1043; sub.u32 %r90,%r91,%r88; shr.s32 %r92,%r86,%r90; cvt.s64.s32 %r70,%r92; bra $L6; $L2: .loc 1 90 0 setp.gt.s32 %r93,%r53,62; @ %r93 bra $L7; .loc 1 93 0 setp.le.s32 %r94,%r53,51; @ %r94 bra $L8; .loc 1 96 0 and.b32 %r95,%r65,983039; or.b32 %r96,%r95,65536; cvt.s64.s32 %r97,%r96; add.u32 %r98,%r24,-1043; shl.b64 %r99,%r97,%r98; .loc 1 98 0 add.u32 %r101,%r24,-1075; cvt.u32.u64 %r103,%r72; shl.b32 %r102,%r103,%r101; cvt.u64.u32 %r104,%r102; .loc 1 96 0 or.b64 %r70,%r99,%r104; bra $L6; $L8: .loc 1 102 0 cvta.const.u64 %r105,TWO52; cvt.s64.s32 %r106,%r22; shl.b64 %r107,%r106,3; add.u64 %r108,%r105,%r107; ld.f64 %r41,[%r108]; add.f64 %r42,%r41,%r71; st.f64 [%frame],%r42; .loc 1 103 0 ld.f64 %r43,[%frame]; sub.f64 %r54,%r43,%r41; .loc 1 104 0 mov.b64 %r109,%r54; shr.u64 %r110,%r109,32; cvt.u32.u64 %r55,%r110; .loc 1 105 0 shr.s32 %r111,%r55,20; and.b32 %r45,%r111,2047; .loc 1 106 0 and.b32 %r57,%r55,1048575; .loc 1 107 0 or.b32 %r112,%r57,1048576; .loc 1 112 0 cvt.s64.s32 %r113,%r112; add.u32 %r114,%r45,-1043; shl.b64 %r70,%r113,%r114; .loc 1 113 0 mov.u32 %r116,1075; sub.u32 %r48,%r116,%r45; setp.gt.u32 %r117,%r48,31; @ %r117 bra $L6; cvt.u32.u64 %r120,%r109; shr.u32 %r119,%r120,%r48; cvt.u64.u32 %r121,%r119; or.b64 %r70,%r70,%r121; bra $L6; $L7: .loc 1 118 0 cvt.rzi.s64.f64 %r70,%r71; bra $L1; $L6: .loc 1 121 0 setp.eq.u32 %r122,%r22,0; @ %r122 bra $L1; neg.s64 %r70,%r70; $L1: .loc 1 122 0 mov.u64 %value,%r70; st.param.u64 [%value_out],%value; ret; } /642 0 0 0 644 2811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llround .visible .func (.param .u64 %value_out) llround (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_llround.c" // BEGIN GLOBAL FUNCTION DEF: llround .visible .func (.param .u64 %value_out) llround (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r38; .reg .u32 %r41; .reg .u64 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r50; .reg .u64 %r51; .reg .f64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .pred %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .pred %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .u64 %r82; .reg .u64 %r83; mov.f64 %r52,%ar0; mov.b64 %r53,%r52; shr.u64 %r54,%r53,32; cvt.u32.u64 %r30,%r54; .loc 1 28 0 setp.ge.s32 %r55,%r30,0; selp.u32 %r43,1,-1,%r55; .loc 1 30 0 shr.u32 %r56,%r30,20; and.b32 %r57,%r56,2047; add.u32 %r44,%r57,-1023; .loc 1 31 0 and.b32 %r45,%r30,1048575; .loc 1 32 0 or.b32 %r41,%r45,1048576; .loc 1 35 0 setp.gt.s32 %r58,%r44,19; @ %r58 bra $L3; .loc 1 38 0 setp.ge.s32 %r59,%r44,0; @ %r59 bra $L4; .loc 1 40 0 setp.ne.u32 %r60,%r44,-1; @ %r60 bra $L12; .loc 1 43 0 cvt.s64.s32 %r51,%r43; bra $L1; $L4: .loc 1 49 0 mov.u32 %r62,524288; shr.s32 %r61,%r62,%r44; add.u32 %r63,%r61,%r41; .loc 1 51 0 mov.u32 %r65,20; sub.u32 %r64,%r65,%r44; shr.u32 %r66,%r63,%r64; cvt.u64.u32 %r42,%r66; bra $L6; $L3: .loc 1 54 0 setp.gt.u32 %r67,%r44,62; @ %r67 bra $L7; cvt.u32.u64 %r47,%r53; add.u32 %r50,%r57,-1043; .loc 1 57 0 setp.le.s32 %r69,%r44,51; @ %r69 bra $L8; .loc 1 62 0 add.u32 %r70,%r57,-1075; shl.b32 %r71,%r47,%r70; cvt.u64.u32 %r72,%r71; .loc 1 60 0 cvt.u64.u32 %r73,%r41; shl.b64 %r74,%r73,%r50; or.b64 %r42,%r72,%r74; bra $L6; $L8: .loc 1 68 0 mov.u32 %r76,-2147483648; shr.u32 %r75,%r76,%r50; .loc 1 66 0 add.u32 %r46,%r75,%r47; .loc 1 69 0 setp.ge.u32 %r77,%r46,%r47; @ %r77 bra $L9; .loc 1 70 0 add.u32 %r41,%r41,1; $L9: .loc 1 72 0 cvt.u64.u32 %r78,%r41; shl.b64 %r42,%r78,%r50; .loc 1 74 0 mov.u32 %r79,52; sub.u32 %r38,%r79,%r44; setp.eq.u32 %r80,%r38,32; @ %r80 bra $L6; shr.u32 %r81,%r46,%r38; cvt.u64.u32 %r82,%r81; or.b64 %r42,%r42,%r82; bra $L6; $L7: .loc 1 79 0 cvt.rzi.s64.f64 %r51,%r52; bra $L1; $L6: .loc 1 81 0 cvt.s64.s32 %r83,%r43; mul.lo.u64 %r51,%r83,%r42; bra $L1; $L12: .loc 1 41 0 mov.u64 %r51,0; $L1: .loc 1 82 0 mov.u64 %value,%r51; st.param.u64 [%value_out],%value; ret; } lib_a-s_log1p.o/0 0 0 644 6642 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log1p .visible .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_log1p.c" // BEGIN GLOBAL FUNCTION DEF: log1p .visible .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r22; .reg .u32 %r34; .reg .f64 %r36; .reg .f64 %r38; .reg .f64 %r50; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .f64 %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r78; .reg .u64 %r80; .reg .u64 %r81; .reg .f64 %r82; .reg .f64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .pred %r89; .reg .f64 %r90; .reg .pred %r91; .reg .f64 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r97; .reg .u32 %r98; .reg .u16 %r99; .reg .u16 %r100; .reg .u16 %r101; .reg .u32 %r102; .reg .u16 %r103; .reg .pred %r104; .reg .f64 %r105; .reg .u32 %r107; .reg .pred %r108; .reg .f64 %r109; .reg .pred %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u32 %r113; .reg .pred %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .u32 %r119; .reg .pred %r120; .reg .u32 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u32 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u32 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .pred %r136; .reg .f64 %r137; .reg .f64 %r139; .reg .pred %r140; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .f64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .pred %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .f64 %r158; .reg .f64 %r159; mov.f64 %r83,%ar0; mov.b64 %r84,%r83; shr.u64 %r85,%r84,32; cvt.u32.u64 %r64,%r85; .loc 1 159 0 cvt.u32.u64 %r59,%r85; .loc 1 163 0 setp.le.s32 %r86,%r59,1071284857; @ %r86 bra $L2; .loc 1 178 0 setp.gt.s32 %r87,%r59,2146435071; @ ! %r87 bra $L22; bra $L3; $L2: .loc 1 160 0 and.b32 %r63,%r64,2147483647; .loc 1 164 0 setp.le.s32 %r88,%r63,1072693247; @ %r88 bra $L5; .loc 1 165 0 setp.neu.f64 %r89,%r83,0dbff0000000000000; @ %r89 bra $L6; mov.f64 %r90,0dc350000000000000; div.rn.f64 %r82,%r90,0d0000000000000000; bra $L1; $L6: .loc 1 166 0 sub.f64 %r22,%r83,%r83; div.rn.f64 %r82,%r22,%r22; bra $L1; $L5: .loc 1 168 0 setp.gt.s32 %r91,%r63,1042284543; @ %r91 bra $L8; .loc 1 169 0 add.f64 %r92,%r83,0d4350000000000000; set.u32.gt.f64 %r94,%r92,0d0000000000000000; neg.s32 %r95,%r94; .loc 1 170 0 set.u32.le.s32 %r97,%r63,1016070143; neg.s32 %r98,%r97; cvt.u16.u32 %r100,%r95; cvt.u16.u32 %r101,%r98; and.b16 %r99,%r100,%r101; cvt.u32.u16 %r102,%r99; cvt.u16.u8 %r103,%r102; setp.ne.u16 %r104,%r103,0; @ %r104 bra $L20; .loc 1 173 0 mul.f64 %r105,%r83,%r83; fma.rn.f64 %r82,%r105,0dbfe0000000000000,%r83; bra $L1; $L8: .loc 1 175 0 add.u32 %r107,%r64,1076707644; setp.le.u32 %r108,%r107,1076707644; @ %r108 bra $L9; .loc 1 202 0 mul.f64 %r109,%r83,0d3fe0000000000000; mul.f64 %r66,%r109,%r83; .loc 1 176 0 mov.u32 %r58,0; bra $L10; $L3: .loc 1 178 0 add.f64 %r82,%r83,%r83; bra $L1; $L22: .loc 1 180 0 setp.gt.s32 %r110,%r59,1128267775; @ %r110 bra $L11; $L9: .loc 1 181 0 add.f64 %r56,%r83,0d3ff0000000000000; .loc 1 182 0 mov.b64 %r111,%r56; shr.u64 %r112,%r111,32; cvt.u32.u64 %r59,%r112; .loc 1 183 0 shr.s32 %r113,%r59,20; add.u32 %r58,%r113,-1023; .loc 1 184 0 setp.le.s32 %r114,%r58,0; @ %r114 bra $L12; sub.f64 %r115,%r56,%r83; mov.f64 %r116,0d3ff0000000000000; sub.f64 %r61,%r116,%r115; bra $L13; $L12: mov.f64 %r118,0d3ff0000000000000; sub.f64 %r117,%r56,%r118; sub.f64 %r61,%r83,%r117; $L13: .loc 1 185 0 div.rn.f64 %r55,%r61,%r56; bra $L14; $L11: .loc 1 189 0 shr.s32 %r119,%r59,20; add.u32 %r58,%r119,-1023; .loc 1 187 0 mov.f64 %r56,%r83; .loc 1 190 0 mov.f64 %r55,0d0000000000000000; $L14: .loc 1 192 0 and.b32 %r60,%r59,1048575; .loc 1 193 0 setp.gt.s32 %r120,%r60,434333; @ %r120 bra $L15; .loc 1 194 0 mov.b64 %r80,%r56; or.b32 %r121,%r60,1072693248; cvt.u64.u32 %r122,%r121; shl.b64 %r123,%r122,32; and.b64 %r124,%r80,4294967295; or.b64 %r125,%r124,%r123; mov.b64 %r57,%r125; bra $L16; $L15: .loc 1 196 0 add.u32 %r58,%r58,1; .loc 1 197 0 mov.b64 %r81,%r56; or.b32 %r126,%r60,1071644672; cvt.u64.u32 %r127,%r126; shl.b64 %r128,%r127,32; and.b64 %r129,%r81,4294967295; or.b64 %r130,%r129,%r128; mov.b64 %r57,%r130; .loc 1 198 0 mov.u32 %r131,1048576; sub.u32 %r34,%r131,%r60; shr.s32 %r60,%r34,2; $L16: .loc 1 200 0 mov.f64 %r132,0d3ff0000000000000; sub.f64 %r83,%r57,%r132; .loc 1 202 0 mul.f64 %r133,%r83,0d3fe0000000000000; mul.f64 %r66,%r133,%r83; .loc 1 203 0 setp.ne.u32 %r134,%r60,0; @ %r134 bra $L10; .loc 1 204 0 setp.neu.f64 %r135,%r83,0d0000000000000000; @ %r135 bra $L17; setp.eq.u32 %r136,%r58,0; @ %r136 bra $L21; .loc 1 205 0 cvt.rn.f64.s32 %r36,%r58; fma.rn.f64 %r137,%r36,0d3dea39ef35793c76,%r55; fma.rn.f64 %r82,%r36,0d3fe62e42fee00000,%r137; bra $L1; $L17: .loc 1 206 0 fma.rn.f64 %r139,%r83,0dbfe5555555555555,0d3ff0000000000000; mul.f64 %r69,%r139,%r66; .loc 1 207 0 setp.ne.u32 %r140,%r58,0; @ %r140 bra $L18; sub.f64 %r82,%r83,%r69; bra $L1; $L18: .loc 1 208 0 cvt.rn.f64.s32 %r38,%r58; fma.rn.f64 %r141,%r38,0d3dea39ef35793c76,%r55; sub.f64 %r142,%r69,%r141; sub.f64 %r143,%r142,%r83; neg.f64 %r144,%r143; fma.rn.f64 %r82,%r38,0d3fe62e42fee00000,%r144; bra $L1; $L10: .loc 1 210 0 add.f64 %r145,%r83,0d4000000000000000; div.rn.f64 %r67,%r83,%r145; .loc 1 211 0 mul.f64 %r68,%r67,%r67; .loc 1 212 0 fma.rn.f64 %r146,%r68,0d3fc2f112df3e5244,0d3fc39a09d078c69f; fma.rn.f64 %r147,%r146,%r68,0d3fc7466496cb03de; fma.rn.f64 %r148,%r147,%r68,0d3fcc71c51d8e78af; fma.rn.f64 %r149,%r148,%r68,0d3fd2492494229359; fma.rn.f64 %r150,%r149,%r68,0d3fd999999997fa04; fma.rn.f64 %r151,%r150,%r68,0d3fe5555555555593; fma.rn.f64 %r152,%r151,%r68,%r66; mul.f64 %r78,%r152,%r67; .loc 1 213 0 setp.ne.u32 %r153,%r58,0; @ %r153 bra $L19; sub.f64 %r154,%r66,%r78; sub.f64 %r82,%r83,%r154; bra $L1; $L19: .loc 1 214 0 cvt.rn.f64.s32 %r50,%r58; fma.rn.f64 %r155,%r50,0d3dea39ef35793c76,%r55; add.f64 %r156,%r155,%r78; sub.f64 %r157,%r66,%r156; sub.f64 %r158,%r157,%r83; neg.f64 %r159,%r158; fma.rn.f64 %r82,%r50,0d3fe62e42fee00000,%r159; bra $L1; $L20: .loc 1 171 0 mov.f64 %r82,%r83; bra $L1; $L21: .loc 1 204 0 mov.f64 %r82,0d0000000000000000; $L1: .loc 1 215 0 mov.f64 %value,%r82; st.param.f64 [%value_out],%value; ret; } lib_a-s_log2.o/ 0 0 0 644 808 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log2 .visible .func (.param .f64 %value_out) log2 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_log2.c" // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log2 .visible .func (.param .f64 %value_out) log2 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r24,%ar0; .loc 1 82 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),log,(%out_arg1); ld.param.f64 %r26,[%value_in]; } div.rn.f64 %value,%r26,0d3fe62e42fefa39ef; .loc 1 83 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_logb.o/ 0 0 0 644 2349 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: logb .visible .func (.param .f64 %value_out) logb (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_logb.c" // BEGIN GLOBAL FUNCTION DEF: logb .visible .func (.param .f64 %value_out) logb (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r39; .reg .u32 %r40; .reg .f64 %r44; .reg .f64 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .pred %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r56; .reg .pred %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .u32 %r67; .reg .u16 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u32 %r71; .reg .u16 %r72; .reg .pred %r73; mov.f64 %r45,%ar0; .loc 1 88 0 mov.b64 %r46,%r45; shr.u64 %r47,%r46,32; cvt.u32.u64 %r36,%r47; cvt.u32.u64 %r34,%r46; .loc 1 89 0 and.b32 %r37,%r36,2147483647; .loc 1 90 0 setp.gt.s32 %r49,%r37,1048575; @ %r49 bra $L2; .loc 1 91 0 or.b32 %r50,%r34,%r37; setp.ne.u32 %r51,%r50,0; @ %r51 bra $L3; .loc 1 95 0 mov.f64 %r52,0dbff0000000000000; div.rn.f64 %r44,%r52,0d0000000000000000; bra $L1; $L3: .loc 1 98 0 setp.ne.u32 %r53,%r37,0; @ %r53 bra $L5; .loc 1 99 0 setp.le.s32 %r54,%r34,0; @ %r54 bra $L10; mov.u32 %r35,-1043; $L7: add.u32 %r35,%r35,-1; add.u32 %r34,%r34,%r34; setp.gt.s32 %r56,%r34,0; @ %r56 bra $L7; cvt.rn.f64.s32 %r44,%r35; bra $L1; $L5: .loc 1 101 0 shl.b32 %r40,%r37,11; mov.u32 %r39,-1022; $L8: add.u32 %r39,%r39,-1; add.u32 %r40,%r40,%r40; setp.gt.s32 %r58,%r40,0; @ %r58 bra $L8; cvt.rn.f64.s32 %r44,%r39; bra $L1; $L10: .loc 1 99 0 mov.f64 %r44,0dc0904c0000000000; .loc 1 103 0 bra $L1; $L2: .loc 1 105 0 setp.gt.s32 %r59,%r37,2146435071; @ %r59 bra $L9; shr.s32 %r60,%r37,20; add.u32 %r61,%r60,-1023; cvt.rn.f64.s32 %r44,%r61; bra $L1; $L9: .loc 1 106 0 set.u32.gt.s32 %r63,%r37,2146435072; neg.s32 %r64,%r63; set.u32.ne.u32 %r66,%r34,0; neg.s32 %r67,%r66; cvt.u16.u32 %r69,%r64; cvt.u16.u32 %r70,%r67; or.b16 %r68,%r69,%r70; cvt.u32.u16 %r71,%r68; cvt.u16.u8 %r72,%r71; setp.eq.u16 %r73,%r72,0; selp.f64 %r44,0d7ff0000000000000,%r45,%r73; $L1: .loc 1 108 0 mov.f64 %value,%r44; st.param.f64 [%value_out],%value; ret; } lib_a-s_lrint.o/0 0 0 644 4119 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lrint .visible .func (.param .u64 %value_out) lrint (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_lrint.c" // BEGIN VAR DEF: TWO52 .const .align 8 .u64 TWO52[2] = {4841369599423283200,-4382002437431492608 }; // BEGIN GLOBAL FUNCTION DEF: lrint .visible .func (.param .u64 %value_out) lrint (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .u32 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .u32 %r46; .reg .u32 %r49; .reg .u32 %r54; .reg .f64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .u32 %r62; .reg .u32 %r64; .reg .u32 %r66; .reg .u64 %r71; .reg .f64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r81; .reg .f64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .pred %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u32 %r100; .reg .u64 %r101; .reg .u32 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r118; .reg .pred %r119; .reg .u32 %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .pred %r124; mov.f64 %r72,%ar0; mov.b64 %r73,%r72; shr.u64 %r74,%r73,32; cvt.u32.u64 %r66,%r74; .loc 1 97 0 shr.u32 %r22,%r66,31; .loc 1 100 0 shr.s32 %r75,%r66,20; and.b32 %r24,%r75,2047; add.u32 %r54,%r24,-1023; .loc 1 103 0 setp.gt.s32 %r76,%r54,19; @ %r76 bra $L2; .loc 1 106 0 setp.ge.s32 %r77,%r54,-1; @ %r77 bra $L3; $L5: .loc 1 107 0 mov.u64 %r71,0; bra $L1; $L3: .loc 1 112 0 cvta.const.u64 %r78,TWO52; cvt.s64.s32 %r79,%r22; shl.b64 %r80,%r79,3; add.u64 %r81,%r78,%r80; ld.f64 %r25,[%r81]; add.f64 %r26,%r25,%r72; st.f64 [%frame],%r26; .loc 1 113 0 ld.f64 %r27,[%frame]; sub.f64 %r82,%r27,%r25; .loc 1 114 0 mov.b64 %r83,%r82; shr.u64 %r84,%r83,32; cvt.u32.u64 %r62,%r84; .loc 1 117 0 cvt.s64.s32 %r85,%r62; and.b64 %r86,%r85,-2147483649; setp.eq.u64 %r87,%r86,0; @ %r87 bra $L5; .loc 1 121 0 and.b32 %r64,%r62,1048575; .loc 1 122 0 or.b32 %r88,%r64,1048576; .loc 1 120 0 shr.s32 %r89,%r62,20; and.b32 %r90,%r89,2047; .loc 1 124 0 mov.u32 %r93,1043; sub.u32 %r92,%r93,%r90; shr.s32 %r94,%r88,%r92; cvt.s64.s32 %r71,%r94; bra $L6; $L2: .loc 1 127 0 setp.gt.s32 %r95,%r54,62; @ %r95 bra $L7; .loc 1 131 0 setp.le.s32 %r96,%r54,51; @ %r96 bra $L8; .loc 1 134 0 and.b32 %r97,%r66,983039; or.b32 %r98,%r97,65536; cvt.s64.s32 %r99,%r98; add.u32 %r100,%r24,-1043; shl.b64 %r101,%r99,%r100; .loc 1 136 0 add.u32 %r103,%r24,-1075; cvt.u32.u64 %r105,%r73; shl.b32 %r104,%r105,%r103; cvt.u64.u32 %r106,%r104; .loc 1 134 0 or.b64 %r71,%r101,%r106; bra $L6; $L8: .loc 1 141 0 cvta.const.u64 %r107,TWO52; cvt.s64.s32 %r108,%r22; shl.b64 %r109,%r108,3; add.u64 %r110,%r107,%r109; ld.f64 %r42,[%r110]; add.f64 %r43,%r42,%r72; st.f64 [%frame],%r43; .loc 1 142 0 ld.f64 %r44,[%frame]; sub.f64 %r55,%r44,%r42; .loc 1 143 0 mov.b64 %r111,%r55; shr.u64 %r112,%r111,32; cvt.u32.u64 %r56,%r112; .loc 1 144 0 shr.s32 %r113,%r56,20; and.b32 %r46,%r113,2047; .loc 1 145 0 and.b32 %r58,%r56,1048575; .loc 1 146 0 or.b32 %r114,%r58,1048576; .loc 1 154 0 cvt.s64.s32 %r115,%r114; add.u32 %r116,%r46,-1043; shl.b64 %r71,%r115,%r116; .loc 1 155 0 mov.u32 %r118,1075; sub.u32 %r49,%r118,%r46; setp.gt.u32 %r119,%r49,31; @ %r119 bra $L6; cvt.u32.u64 %r122,%r111; shr.u32 %r121,%r122,%r49; cvt.u64.u32 %r123,%r121; or.b64 %r71,%r71,%r123; bra $L6; $L7: .loc 1 160 0 cvt.rzi.s64.f64 %r71,%r72; bra $L1; $L6: .loc 1 163 0 setp.eq.u32 %r124,%r22,0; @ %r124 bra $L1; neg.s64 %r71,%r71; $L1: .loc 1 164 0 mov.u64 %value,%r71; st.param.u64 [%value_out],%value; ret; } /661 0 0 0 644 2817 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lround .visible .func (.param .u64 %value_out) lround (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_lround.c" // BEGIN GLOBAL FUNCTION DEF: lround .visible .func (.param .u64 %value_out) lround (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r38; .reg .u32 %r41; .reg .u64 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r50; .reg .u64 %r51; .reg .f64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .pred %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .pred %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .u64 %r82; .reg .u64 %r83; mov.f64 %r52,%ar0; mov.b64 %r53,%r52; shr.u64 %r54,%r53,32; cvt.u32.u64 %r30,%r54; .loc 1 69 0 setp.ge.s32 %r55,%r30,0; selp.u32 %r43,1,-1,%r55; .loc 1 71 0 shr.u32 %r56,%r30,20; and.b32 %r57,%r56,2047; add.u32 %r44,%r57,-1023; .loc 1 72 0 and.b32 %r45,%r30,1048575; .loc 1 73 0 or.b32 %r41,%r45,1048576; .loc 1 75 0 setp.gt.s32 %r58,%r44,19; @ %r58 bra $L3; .loc 1 78 0 setp.ge.s32 %r59,%r44,0; @ %r59 bra $L4; .loc 1 80 0 setp.ne.u32 %r60,%r44,-1; @ %r60 bra $L12; .loc 1 83 0 cvt.s64.s32 %r51,%r43; bra $L1; $L4: .loc 1 89 0 mov.u32 %r62,524288; shr.s32 %r61,%r62,%r44; add.u32 %r63,%r61,%r41; .loc 1 91 0 mov.u32 %r65,20; sub.u32 %r64,%r65,%r44; shr.u32 %r66,%r63,%r64; cvt.u64.u32 %r42,%r66; bra $L6; $L3: .loc 1 94 0 setp.gt.u32 %r67,%r44,62; @ %r67 bra $L7; cvt.u32.u64 %r47,%r53; add.u32 %r50,%r57,-1043; .loc 1 98 0 setp.le.s32 %r69,%r44,51; @ %r69 bra $L8; .loc 1 103 0 add.u32 %r70,%r57,-1075; shl.b32 %r71,%r47,%r70; cvt.u64.u32 %r72,%r71; .loc 1 101 0 cvt.u64.u32 %r73,%r41; shl.b64 %r74,%r73,%r50; or.b64 %r42,%r72,%r74; bra $L6; $L8: .loc 1 111 0 mov.u32 %r76,-2147483648; shr.u32 %r75,%r76,%r50; .loc 1 108 0 add.u32 %r46,%r75,%r47; .loc 1 112 0 setp.ge.u32 %r77,%r46,%r47; @ %r77 bra $L9; .loc 1 113 0 add.u32 %r41,%r41,1; $L9: .loc 1 116 0 cvt.u64.u32 %r78,%r41; shl.b64 %r42,%r78,%r50; .loc 1 119 0 mov.u32 %r79,52; sub.u32 %r38,%r79,%r44; setp.eq.u32 %r80,%r38,32; @ %r80 bra $L6; shr.u32 %r81,%r46,%r38; cvt.u64.u32 %r82,%r81; or.b64 %r42,%r42,%r82; bra $L6; $L7: .loc 1 124 0 cvt.rzi.s64.f64 %r51,%r52; bra $L1; $L6: .loc 1 126 0 cvt.s64.s32 %r83,%r43; mul.lo.u64 %r51,%r83,%r42; bra $L1; $L12: .loc 1 81 0 mov.u64 %r51,0; $L1: .loc 1 127 0 mov.u64 %value,%r51; st.param.u64 [%value_out],%value; ret; } /679 0 0 0 644 489 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: matherr .visible .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_matherr.c" // BEGIN GLOBAL FUNCTION DEF: matherr .visible .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; mov.u32 %value,0; .loc 1 123 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_modf.o/ 0 0 0 644 3138 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_modf.c" // BEGIN GLOBAL FUNCTION DEF: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r23; .reg .f64 %r32; .reg .u32 %r38; .reg .f64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .f64 %r52; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u64 %r62; .reg .u64 %r66; .reg .f64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u64 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .u32 %r96; .reg .u64 %r97; .reg .u64 %r101; .reg .u64 %r102; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; mov.f64 %r53,%ar0; mov.u64 %r54,%ar1; mov.b64 %r55,%r53; shr.u64 %r56,%r55,32; cvt.u32.u64 %r38,%r56; cvt.u32.u64 %r44,%r55; .loc 1 92 0 shr.s32 %r58,%r38,20; and.b32 %r23,%r58,2047; add.u32 %r42,%r23,-1023; .loc 1 93 0 setp.gt.s32 %r59,%r42,19; @ %r59 bra $L2; .loc 1 94 0 setp.ge.s32 %r60,%r42,0; @ %r60 bra $L3; .loc 1 95 0 and.b32 %r61,%r38,-2147483648; cvt.u64.u32 %r62,%r61; shl.b64 %r66,%r62,32; mov.b64 %r67,%r66; st.f64 [%r54],%r67; .loc 1 96 0 mov.f64 %r52,%r53; bra $L1; $L3: .loc 1 98 0 mov.u32 %r68,1048575; shr.s32 %r45,%r68,%r42; .loc 1 99 0 and.b32 %r69,%r38,%r45; or.b32 %r70,%r69,%r44; setp.ne.u32 %r71,%r70,0; @ %r71 bra $L5; .loc 1 101 0 st.f64 [%r54],%r53; .loc 1 103 0 and.b32 %r72,%r38,-2147483648; cvt.u64.u32 %r73,%r72; shl.b64 %r77,%r73,32; mov.b64 %r52,%r77; .loc 1 104 0 bra $L1; $L5: .loc 1 106 0 not.b32 %r78,%r45; and.b32 %r79,%r78,%r38; cvt.u64.u32 %r80,%r79; shl.b64 %r84,%r80,32; mov.b64 %r32,%r84; st.f64 [%r54],%r32; .loc 1 107 0 sub.f64 %r52,%r53,%r32; bra $L1; $L2: .loc 1 110 0 setp.le.s32 %r85,%r42,51; @ %r85 bra $L6; .loc 1 112 0 st.f64 [%r54],%r53; .loc 1 114 0 and.b32 %r86,%r38,-2147483648; cvt.u64.u32 %r87,%r86; shl.b64 %r91,%r87,32; mov.b64 %r52,%r91; .loc 1 115 0 bra $L1; $L6: .loc 1 117 0 add.u32 %r92,%r23,-1043; mov.u32 %r93,-1; shr.u32 %r43,%r93,%r92; .loc 1 118 0 and.b32 %r94,%r43,%r44; setp.ne.u32 %r95,%r94,0; @ %r95 bra $L7; .loc 1 120 0 st.f64 [%r54],%r53; .loc 1 122 0 and.b32 %r96,%r38,-2147483648; cvt.u64.u32 %r97,%r96; shl.b64 %r101,%r97,32; mov.b64 %r52,%r101; .loc 1 123 0 bra $L1; $L7: .loc 1 125 0 cvt.u64.u32 %r102,%r38; not.b32 %r106,%r43; and.b32 %r107,%r106,%r44; cvt.u64.u32 %r108,%r107; shl.b64 %r109,%r102,32; or.b64 %r110,%r109,%r108; mov.b64 %r40,%r110; st.f64 [%r54],%r40; .loc 1 126 0 sub.f64 %r52,%r53,%r40; $L1: .loc 1 129 0 mov.f64 %value,%r52; st.param.f64 [%value_out],%value; ret; } lib_a-s_nan.o/ 0 0 0 644 497 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_nan.c" // BEGIN GLOBAL FUNCTION DEF: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 49 0 mov.f64 %value,0d7ff8000000000000; .loc 1 50 0 st.param.f64 [%value_out],%value; ret; } /698 0 0 0 644 814 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nearbyint .visible .func (.param .f64 %value_out) nearbyint (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_nearbyint.c" // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nearbyint .visible .func (.param .f64 %value_out) nearbyint (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 61 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),rint,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 62 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /719 0 0 0 644 5160 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nextafter .visible .func (.param .f64 %value_out) nextafter (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_nextafter.c" // BEGIN GLOBAL FUNCTION DEF: nextafter .visible .func (.param .f64 %value_out) nextafter (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .f64 %r47; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r62; .reg .u64 %r63; .reg .pred %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .pred %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r81; .reg .u64 %r82; .reg .pred %r83; .reg .pred %r84; .reg .pred %r85; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u16 %r94; .reg .u32 %r95; .reg .u16 %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r101; .reg .u32 %r102; .reg .u32 %r104; .reg .u32 %r105; .reg .u16 %r107; .reg .u16 %r108; .reg .u16 %r109; .reg .u32 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .u32 %r114; .reg .u32 %r115; .reg .u32 %r117; .reg .u32 %r118; .reg .u16 %r119; .reg .u16 %r120; .reg .u16 %r121; .reg .u32 %r122; .reg .u16 %r123; .reg .pred %r124; .reg .pred %r125; .reg .pred %r126; .reg .pred %r127; .reg .pred %r128; .reg .f64 %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r142; .reg .u64 %r143; .reg .u64 %r144; mov.f64 %r57,%ar0; mov.f64 %r58,%ar1; .loc 1 77 0 mov.b64 %r59,%r57; shr.u64 %r60,%r59,32; cvt.u32.u64 %r40,%r60; cvt.u32.u64 %r49,%r59; mov.b64 %r62,%r58; shr.u64 %r63,%r62,32; cvt.u32.u64 %r50,%r63; .loc 1 78 0 cvt.u32.u64 %r42,%r63; cvt.u32.u64 %r51,%r62; .loc 1 79 0 and.b32 %r43,%r40,2147483647; .loc 1 80 0 and.b32 %r44,%r50,2147483647; .loc 1 82 0 setp.le.s32 %r65,%r43,2146435071; @ %r65 bra $L2; add.u32 %r66,%r43,-2146435072; or.b32 %r67,%r66,%r49; setp.ne.u32 %r68,%r67,0; @ %r68 bra $L3; $L2: setp.le.s32 %r69,%r44,2146435071; @ %r69 bra $L4; .loc 1 83 0 add.u32 %r70,%r44,-2146435072; or.b32 %r71,%r70,%r51; setp.eq.u32 %r72,%r71,0; @ %r72 bra $L4; $L3: .loc 1 84 0 add.f64 %r56,%r57,%r58; bra $L1; $L4: .loc 1 85 0 setp.eq.f64 %r73,%r57,%r58; @ %r73 bra $L17; .loc 1 86 0 or.b32 %r74,%r43,%r49; setp.ne.u32 %r75,%r74,0; @ %r75 bra $L6; .loc 1 87 0 and.b32 %r76,%r50,-2147483648; cvt.u64.u32 %r77,%r76; shl.b64 %r81,%r77,32; or.b64 %r82,%r81,1; mov.b64 %r56,%r82; .loc 1 88 0 mul.f64 %r47,%r56,%r56; .loc 1 89 0 setp.neu.f64 %r83,%r56,%r47; selp.f64 %r56,%r56,%r47,%r83; bra $L1; $L6: .loc 1 91 0 setp.lt.s32 %r84,%r40,0; @ %r84 bra $L7; .loc 1 92 0 setp.gt.s32 %r85,%r40,%r42; @ %r85 bra $L8; set.u32.eq.u32 %r87,%r40,%r42; neg.s32 %r88,%r87; set.u32.gt.u32 %r90,%r49,%r51; neg.s32 %r91,%r90; cvt.u16.u32 %r93,%r88; cvt.u16.u32 %r94,%r91; and.b16 %r92,%r93,%r94; cvt.u32.u16 %r95,%r92; cvt.u16.u8 %r96,%r95; setp.ne.u16 %r97,%r96,0; @ %r97 bra $L9; bra $L21; $L8: .loc 1 93 0 setp.ne.u32 %r98,%r49,0; @ %r98 bra $L9; add.u32 %r40,%r40,-1; $L9: .loc 1 94 0 add.u32 %r41,%r49,-1; bra $L11; $L21: .loc 1 96 0 add.u32 %r41,%r49,1; .loc 1 97 0 setp.ne.u32 %r99,%r41,0; @ %r99 bra $L11; add.u32 %r40,%r40,1; bra $L11; $L7: .loc 1 100 0 not.b32 %r101,%r42; shr.u32 %r102,%r101,31; set.u32.gt.s32 %r104,%r40,%r42; neg.s32 %r105,%r104; cvt.u16.u32 %r108,%r102; cvt.u16.u32 %r109,%r105; or.b16 %r107,%r108,%r109; cvt.u32.u16 %r110,%r107; cvt.u16.u8 %r111,%r110; setp.ne.u16 %r112,%r111,0; @ %r112 bra $L12; set.u32.eq.u32 %r114,%r40,%r42; neg.s32 %r115,%r114; set.u32.gt.u32 %r117,%r49,%r51; neg.s32 %r118,%r117; cvt.u16.u32 %r120,%r115; cvt.u16.u32 %r121,%r118; and.b16 %r119,%r120,%r121; cvt.u32.u16 %r122,%r119; cvt.u16.u8 %r123,%r122; setp.ne.u16 %r124,%r123,0; @ %r124 bra $L13; bra $L22; $L12: .loc 1 101 0 setp.ne.u32 %r125,%r49,0; @ %r125 bra $L13; add.u32 %r40,%r40,-1; $L13: .loc 1 102 0 add.u32 %r41,%r49,-1; bra $L11; $L22: .loc 1 104 0 add.u32 %r41,%r49,1; .loc 1 105 0 setp.ne.u32 %r126,%r41,0; @ %r126 bra $L11; add.u32 %r40,%r40,1; $L11: .loc 1 108 0 and.b32 %r45,%r40,2146435072; .loc 1 109 0 setp.ne.u32 %r127,%r45,2146435072; @ %r127 bra $L15; add.f64 %r56,%r57,%r57; bra $L1; $L15: .loc 1 110 0 setp.gt.s32 %r128,%r45,1048575; @ %r128 bra $L16; .loc 1 111 0 mul.f64 %r129,%r57,%r57; .loc 1 112 0 setp.eq.f64 %r130,%r57,%r129; @ %r130 bra $L16; .loc 1 113 0 cvt.u64.u32 %r131,%r40; cvt.u64.u32 %r135,%r41; shl.b64 %r136,%r131,32; or.b64 %r137,%r136,%r135; mov.b64 %r56,%r137; .loc 1 114 0 bra $L1; $L16: .loc 1 117 0 cvt.u64.u32 %r138,%r40; cvt.u64.u32 %r142,%r41; shl.b64 %r143,%r138,32; or.b64 %r144,%r143,%r142; mov.b64 %r56,%r144; .loc 1 118 0 bra $L1; $L17: .loc 1 85 0 mov.f64 %r56,%r57; $L1: .loc 1 119 0 mov.f64 %value,%r56; st.param.f64 [%value_out],%value; ret; } lib_a-s_pow10.o/0 0 0 644 925 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: pow10 .visible .func (.param .f64 %value_out) pow10 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_pow10.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: pow10 .visible .func (.param .f64 %value_out) pow10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r23,%ar0; .loc 1 76 0 mov.f64 %r24,0d4024000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r23; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 77 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } /740 0 0 0 644 12382 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remquo .visible .func (.param .f64 %value_out) remquo (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/common/s_remquo.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN VAR DEF: Zero .const .align 8 .u64 Zero[2] = {0,-9223372036854775808 }; // BEGIN GLOBAL FUNCTION DEF: remquo .visible .func (.param .f64 %value_out) remquo (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r39; .reg .f64 %r46; .reg .u32 %r54; .reg .u32 %r62; .reg .u32 %r87; .reg .u32 %r90; .reg .u32 %r97; .reg .f64 %r101; .reg .f64 %r103; .reg .f64 %r108; .reg .u32 %r109; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .u32 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u32 %r133; .reg .u32 %r134; .reg .u32 %r136; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r147; .reg .u64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .u64 %r153; .reg .u64 %r154; .reg .u64 %r155; .reg .u64 %r156; .reg .u64 %r157; .reg .u32 %r159; .reg .u32 %r161; .reg .u32 %r162; .reg .u32 %r164; .reg .u32 %r165; .reg .u16 %r166; .reg .u16 %r167; .reg .u16 %r168; .reg .u32 %r169; .reg .u16 %r170; .reg .pred %r171; .reg .u32 %r172; .reg .u32 %r173; .reg .u32 %r174; .reg .u32 %r175; .reg .pred %r176; .reg .u32 %r177; .reg .pred %r179; .reg .u32 %r181; .reg .u32 %r182; .reg .u32 %r184; .reg .u32 %r185; .reg .u16 %r186; .reg .u16 %r187; .reg .u16 %r188; .reg .u32 %r189; .reg .u16 %r190; .reg .pred %r191; .reg .pred %r192; .reg .pred %r193; .reg .u64 %r194; .reg .u32 %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u64 %r198; .reg .pred %r199; .reg .pred %r200; .reg .pred %r201; .reg .pred %r203; .reg .pred %r205; .reg .u32 %r206; .reg .pred %r207; .reg .pred %r208; .reg .pred %r209; .reg .pred %r211; .reg .pred %r213; .reg .u32 %r214; .reg .pred %r215; .reg .u32 %r216; .reg .pred %r217; .reg .u32 %r218; .reg .u32 %r219; .reg .u32 %r220; .reg .u32 %r221; .reg .u32 %r222; .reg .u32 %r224; .reg .pred %r225; .reg .u32 %r226; .reg .u32 %r227; .reg .u32 %r228; .reg .u32 %r229; .reg .u32 %r230; .reg .pred %r231; .reg .pred %r232; .reg .pred %r233; .reg .pred %r234; .reg .u32 %r235; .reg .u32 %r236; .reg .u32 %r238; .reg .u32 %r239; .reg .pred %r242; .reg .pred %r243; .reg .pred %r244; .reg .u32 %r245; .reg .pred %r246; .reg .pred %r247; .reg .pred %r248; .reg .u64 %r249; .reg .u32 %r250; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .u32 %r254; .reg .u32 %r255; .reg .pred %r257; .reg .u32 %r259; .reg .u32 %r260; .reg .u32 %r261; .reg .pred %r262; .reg .u32 %r263; .reg .u32 %r264; .reg .pred %r265; .reg .u32 %r266; .reg .u32 %r267; .reg .u32 %r268; .reg .u32 %r269; .reg .u64 %r270; .reg .u64 %r274; .reg .u64 %r275; .reg .u64 %r276; .reg .f64 %r278; .reg .pred %r279; .reg .pred %r280; .reg .pred %r281; .reg .u32 %r282; .reg .pred %r283; .reg .pred %r284; .reg .pred %r285; .reg .u32 %r286; .reg .pred %r287; .reg .u64 %r289; .reg .u32 %r290; .reg .u32 %r291; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u64 %r295; .reg .pred %r296; .reg .pred %r298; mov.f64 %r151,%ar0; mov.f64 %r152,%ar1; mov.u64 %r153,%ar2; .loc 1 88 0 mov.b64 %r154,%r151; shr.u64 %r155,%r154,32; cvt.u32.u64 %r121,%r155; .loc 1 89 0 mov.b64 %r156,%r152; shr.u64 %r157,%r156,32; cvt.u32.u64 %r122,%r157; cvt.u32.u64 %r116,%r156; .loc 1 92 0 and.b32 %r110,%r121,2147483647; .loc 1 93 0 and.b32 %r124,%r122,2147483647; .loc 1 96 0 or.b32 %r159,%r124,%r116; set.u32.eq.u32 %r161,%r159,0; neg.s32 %r162,%r161; set.u32.gt.s32 %r164,%r110,2146435071; neg.s32 %r165,%r164; cvt.u16.u32 %r167,%r162; cvt.u16.u32 %r168,%r165; or.b16 %r166,%r167,%r168; cvt.u32.u16 %r169,%r166; cvt.u16.u8 %r170,%r169; setp.ne.u16 %r171,%r170,0; @ %r171 bra $L2; .loc 1 97 0 neg.s32 %r172,%r116; or.b32 %r173,%r172,%r116; shr.u32 %r174,%r173,31; or.b32 %r175,%r174,%r124; .loc 1 96 0 setp.le.u32 %r176,%r175,2146435072; @ %r176 bra $L3; $L2: .loc 1 98 0 mov.u32 %r177,0; st.u32 [%r153],%r177; .loc 1 99 0 mul.f64 %r46,%r151,%r152; div.rn.f64 %r150,%r46,%r46; bra $L1; $L3: cvt.u32.u64 %r115,%r154; .loc 1 90 0 xor.b32 %r39,%r121,%r122; .loc 1 91 0 and.b32 %r123,%r121,-2147483648; .loc 1 101 0 setp.gt.s32 %r179,%r110,%r124; @ %r179 bra $L5; .loc 1 102 0 set.u32.lt.s32 %r181,%r110,%r124; neg.s32 %r182,%r181; set.u32.lt.u32 %r184,%r115,%r116; neg.s32 %r185,%r184; cvt.u16.u32 %r187,%r182; cvt.u16.u32 %r188,%r185; or.b16 %r186,%r187,%r188; cvt.u32.u16 %r189,%r186; cvt.u16.u8 %r190,%r189; setp.ne.u16 %r191,%r190,0; @ %r191 bra $L48; .loc 1 106 0 setp.ne.u32 %r192,%r115,%r116; @ %r192 bra $L5; .loc 1 107 0 setp.ge.s32 %r193,%r39,0; selp.u32 %r118,1,-1,%r193; st.u32 [%r153],%r118; .loc 1 108 0 cvta.const.u64 %r194,Zero; shr.u32 %r195,%r123,31; cvt.u64.u32 %r196,%r195; shl.b64 %r197,%r196,3; add.u64 %r198,%r194,%r197; ld.f64 %r150,[%r198]; bra $L1; $L5: .loc 1 113 0 setp.gt.s32 %r199,%r110,1048575; @ %r199 bra $L8; .loc 1 114 0 setp.ne.u32 %r200,%r110,0; @ %r200 bra $L9; .loc 1 115 0 mov.u32 %r127,%r115; setp.le.s32 %r201,%r115,0; @ %r201 bra $L50; mov.u32 %r125,-1043; $L11: add.u32 %r125,%r125,-1; add.u32 %r127,%r127,%r127; setp.gt.s32 %r203,%r127,0; @ %r203 bra $L11; bra $L10; $L9: .loc 1 117 0 shl.b32 %r126,%r110,11; mov.u32 %r125,-1022; $L12: add.u32 %r125,%r125,-1; add.u32 %r126,%r126,%r126; setp.gt.s32 %r205,%r126,0; @ %r205 bra $L12; bra $L10; $L8: .loc 1 119 0 shr.s32 %r206,%r110,20; add.u32 %r125,%r206,-1023; bra $L10; $L50: .loc 1 115 0 mov.u32 %r125,-1043; $L10: .loc 1 122 0 setp.gt.s32 %r207,%r124,1048575; @ %r207 bra $L13; .loc 1 123 0 setp.ne.u32 %r208,%r124,0; @ %r208 bra $L14; .loc 1 124 0 mov.u32 %r130,%r116; setp.le.s32 %r209,%r116,0; @ %r209 bra $L51; mov.u32 %r138,-1043; $L16: add.u32 %r138,%r138,-1; add.u32 %r130,%r130,%r130; setp.gt.s32 %r211,%r130,0; @ %r211 bra $L16; bra $L15; $L14: .loc 1 126 0 shl.b32 %r129,%r124,11; mov.u32 %r138,-1022; $L17: add.u32 %r138,%r138,-1; add.u32 %r129,%r129,%r129; setp.gt.s32 %r213,%r129,0; @ %r213 bra $L17; bra $L15; $L13: .loc 1 128 0 shr.s32 %r214,%r124,20; add.u32 %r138,%r214,-1023; bra $L15; $L51: .loc 1 124 0 mov.u32 %r138,-1043; $L15: .loc 1 131 0 setp.lt.s32 %r215,%r125,-1022; @ %r215 bra $L18; .loc 1 132 0 and.b32 %r54,%r121,1048575; or.b32 %r109,%r54,1048576; bra $L19; $L18: .loc 1 134 0 mov.u32 %r216,-1022; sub.u32 %r131,%r216,%r125; .loc 1 135 0 setp.gt.s32 %r217,%r131,31; @ %r217 bra $L20; .loc 1 136 0 add.u32 %r218,%r125,1054; shr.u32 %r219,%r115,%r218; shl.b32 %r220,%r110,%r131; or.b32 %r109,%r219,%r220; .loc 1 137 0 shl.b32 %r115,%r115,%r131; bra $L19; $L20: .loc 1 139 0 mov.u32 %r222,-1054; sub.u32 %r221,%r222,%r125; shl.b32 %r109,%r115,%r221; .loc 1 140 0 mov.u32 %r115,0; $L19: .loc 1 143 0 setp.lt.s32 %r298,%r138,-1022; @ %r298 bra $L21; .loc 1 144 0 and.b32 %r62,%r122,1048575; or.b32 %r111,%r62,1048576; sub.u32 %r144,%r115,%r116; bra $L22; $L21: .loc 1 146 0 mov.u32 %r224,-1022; sub.u32 %r133,%r224,%r138; .loc 1 147 0 setp.gt.s32 %r225,%r133,31; @ %r225 bra $L23; .loc 1 148 0 add.u32 %r226,%r138,1054; shr.u32 %r227,%r116,%r226; shl.b32 %r228,%r124,%r133; or.b32 %r111,%r227,%r228; .loc 1 149 0 shl.b32 %r116,%r116,%r133; sub.u32 %r144,%r115,%r116; bra $L22; $L23: .loc 1 151 0 mov.u32 %r230,-1054; sub.u32 %r229,%r230,%r138; shl.b32 %r111,%r116,%r229; .loc 1 157 0 sub.u32 %r147,%r125,%r138; .loc 1 159 0 add.u32 %r136,%r147,-1; setp.ne.u32 %r231,%r147,0; @ %r231 bra $L52; bra $L68; $L22: .loc 1 157 0 sub.u32 %r134,%r125,%r138; .loc 1 159 0 add.u32 %r136,%r134,-1; setp.eq.u32 %r232,%r134,0; @ ! %r232 bra $L24; bra $L53; $L52: .loc 1 152 0 mov.u32 %r116,0; $L24: mov.u32 %r117,0; $L30: .loc 1 160 0 sub.u32 %r112,%r109,%r111; setp.ge.u32 %r233,%r115,%r116; @ %r233 bra $L27; add.u32 %r112,%r112,-1; $L27: .loc 1 161 0 setp.ge.s32 %r234,%r112,0; @ %r234 bra $L28; add.u32 %r235,%r109,%r109; shr.u32 %r236,%r115,31; add.u32 %r109,%r235,%r236; add.u32 %r115,%r115,%r115; bra $L29; $L28: .loc 1 160 0 sub.u32 %r140,%r115,%r116; .loc 1 162 0 add.u32 %r238,%r112,%r112; shr.u32 %r239,%r140,31; add.u32 %r109,%r238,%r239; add.u32 %r115,%r140,%r140; add.u32 %r117,%r117,1; $L29: .loc 1 163 0 add.u32 %r117,%r117,%r117; .loc 1 159 0 add.u32 %r136,%r136,-1; setp.ne.u32 %r242,%r136,-1; @ %r242 bra $L30; sub.u32 %r144,%r115,%r116; bra $L26; $L53: .loc 1 158 0 mov.u32 %r117,%r134; $L26: .loc 1 165 0 sub.u32 %r113,%r109,%r111; setp.ge.u32 %r243,%r115,%r116; @ %r243 bra $L31; add.u32 %r113,%r113,-1; $L31: .loc 1 166 0 setp.lt.s32 %r244,%r113,0; @ %r244 bra $L32; add.u32 %r117,%r117,1; mov.u32 %r115,%r144; mov.u32 %r109,%r113; $L32: .loc 1 169 0 or.b32 %r245,%r109,%r115; setp.eq.u32 %r246,%r245,0; @ %r246 bra $L33; .loc 1 174 0 setp.le.s32 %r247,%r109,1048575; @ %r247 bra $L34; bra $L35; $L33: .loc 1 170 0 and.b32 %r139,%r117,2147483647; .loc 1 171 0 setp.ge.s32 %r248,%r39,0; @ %r248 bra $L36; neg.s32 %r119,%r139; bra $L37; $L36: mov.u32 %r119,%r139; $L37: st.u32 [%r153],%r119; .loc 1 172 0 cvta.const.u64 %r249,Zero; shr.u32 %r250,%r123,31; cvt.u64.u32 %r251,%r250; shl.b64 %r252,%r251,3; add.u64 %r253,%r249,%r252; ld.f64 %r150,[%r253]; bra $L1; $L34: .loc 1 175 0 add.u32 %r254,%r109,%r109; shr.u32 %r255,%r115,31; add.u32 %r109,%r254,%r255; add.u32 %r115,%r115,%r115; .loc 1 176 0 add.u32 %r138,%r138,-1; .loc 1 174 0 setp.le.s32 %r257,%r109,1048575; @ %r257 bra $L34; setp.lt.s32 %r298,%r138,-1022; $L35: .loc 1 178 0 @ %r298 bra $L38; .loc 1 179 0 add.u32 %r87,%r109,-1048576; add.u32 %r259,%r138,1023; shl.b32 %r260,%r259,20; or.b32 %r110,%r260,%r87; bra $L6; $L38: .loc 1 181 0 mov.u32 %r261,-1022; sub.u32 %r137,%r261,%r138; .loc 1 182 0 setp.gt.s32 %r262,%r137,20; @ %r262 bra $L39; .loc 1 183 0 shr.u32 %r90,%r115,%r137; add.u32 %r263,%r138,1054; shl.b32 %r264,%r109,%r263; or.b32 %r115,%r264,%r90; .loc 1 184 0 shr.s32 %r110,%r109,%r137; bra $L6; $L39: .loc 1 185 0 setp.gt.s32 %r265,%r137,31; @ %r265 bra $L40; .loc 1 186 0 shr.u32 %r97,%r115,%r137; add.u32 %r266,%r138,1054; shl.b32 %r267,%r109,%r266; or.b32 %r115,%r267,%r97; mov.u32 %r110,%r123; bra $L6; $L40: .loc 1 188 0 mov.u32 %r269,-1054; sub.u32 %r268,%r269,%r138; shr.s32 %r115,%r109,%r268; mov.u32 %r110,%r123; bra $L6; $L48: .loc 1 103 0 mov.u32 %r117,0; $L6: .loc 1 192 0 cvt.u64.u32 %r270,%r110; cvt.u64.u32 %r274,%r115; shl.b64 %r275,%r270,32; or.b64 %r276,%r275,%r274; mov.b64 %r108,%r276; .loc 1 193 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r152; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r278,[%value_in]; } .loc 1 194 0 setp.lt.f64 %r279,%r278,0d0020000000000000; @ ! %r279 bra $L69; .loc 1 195 0 add.f64 %r101,%r108,%r108; setp.gt.f64 %r280,%r101,%r278; @ %r280 bra $L43; setp.neu.f64 %r281,%r101,%r278; @ %r281 bra $L44; and.b32 %r282,%r117,1; setp.eq.u32 %r283,%r282,0; @ %r283 bra $L44; $L43: .loc 1 196 0 add.u32 %r117,%r117,1; .loc 1 197 0 sub.f64 %r108,%r108,%r278; bra $L44; $L69: .loc 1 199 0 mul.f64 %r103,%r278,0d3fe0000000000000; setp.lt.f64 %r284,%r103,%r108; @ %r284 bra $L45; setp.neu.f64 %r285,%r103,%r108; @ %r285 bra $L44; and.b32 %r286,%r117,1; setp.eq.u32 %r287,%r286,0; @ %r287 bra $L44; $L45: .loc 1 200 0 add.u32 %r117,%r117,1; .loc 1 201 0 sub.f64 %r108,%r108,%r278; $L44: .loc 1 204 0 mov.b64 %r149,%r108; .loc 1 203 0 shr.u64 %r289,%r149,32; .loc 1 204 0 cvt.u32.u64 %r291,%r289; xor.b32 %r290,%r123,%r291; cvt.u64.u32 %r292,%r290; shl.b64 %r293,%r292,32; and.b64 %r294,%r149,4294967295; or.b64 %r295,%r294,%r293; mov.b64 %r150,%r295; .loc 1 205 0 and.b32 %r143,%r117,2147483647; .loc 1 206 0 setp.ge.s32 %r296,%r39,0; @ %r296 bra $L46; neg.s32 %r120,%r143; bra $L47; $L46: mov.u32 %r120,%r143; $L47: st.u32 [%r153],%r120; .loc 1 207 0 bra $L1; $L68: .loc 1 165 0 sub.u32 %r113,%r109,%r111; mov.u32 %r144,%r115; .loc 1 158 0 mov.u32 %r117,%r147; bra $L31; $L1: .loc 1 208 0 mov.f64 %value,%r150; st.param.f64 [%value_out],%value; ret; } lib_a-s_rint.o/ 0 0 0 644 5027 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rint .visible .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_rint.c" // BEGIN VAR DEF: TWO52 .const .align 8 .u64 TWO52[2] = {4841369599423283200,-4382002437431492608 }; // BEGIN GLOBAL FUNCTION DEF: rint .visible .func (.param .f64 %value_out) rint (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .u32 %r42; .reg .u32 %r45; .reg .u32 %r53; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r72; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r77; .reg .u64 %r79; .reg .f64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u32 %r86; .reg .pred %r87; .reg .pred %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r108; .reg .u32 %r109; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .pred %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .pred %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .pred %r133; .reg .u32 %r134; .reg .pred %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .u64 %r144; .reg .u64 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u64 %r148; .reg .u64 %r149; .reg .u64 %r150; mov.f64 %r82,%ar0; mov.b64 %r83,%r82; shr.u64 %r84,%r83,32; cvt.u32.u64 %r42,%r84; .loc 1 93 0 cvt.u32.u64 %r64,%r84; cvt.u32.u64 %r45,%r83; .loc 1 94 0 shr.u32 %r65,%r42,31; .loc 1 95 0 shr.s32 %r86,%r42,20; and.b32 %r24,%r86,2047; add.u32 %r66,%r24,-1023; .loc 1 96 0 setp.gt.s32 %r87,%r66,19; @ %r87 bra $L2; .loc 1 97 0 setp.ge.s32 %r88,%r66,0; @ %r88 bra $L3; .loc 1 98 0 and.b32 %r89,%r42,2147483647; or.b32 %r90,%r89,%r45; setp.eq.u32 %r91,%r90,0; @ %r91 bra $L4; .loc 1 99 0 and.b32 %r92,%r42,1048575; or.b32 %r72,%r92,%r45; .loc 1 101 0 neg.s32 %r93,%r72; or.b32 %r94,%r93,%r72; shr.u32 %r95,%r94,12; and.b32 %r96,%r95,524288; .loc 1 100 0 and.b32 %r97,%r42,-131072; .loc 1 101 0 or.b32 %r98,%r96,%r97; .loc 1 102 0 cvt.u64.u32 %r99,%r98; shl.b64 %r100,%r99,32; and.b64 %r101,%r83,4294967295; or.b64 %r102,%r101,%r100; mov.b64 %r74,%r102; .loc 1 103 0 cvta.const.u64 %r103,TWO52; cvt.s64.s32 %r104,%r65; shl.b64 %r105,%r104,3; add.u64 %r106,%r103,%r105; ld.f64 %r34,[%r106]; add.f64 %r35,%r34,%r74; st.f64 [%frame],%r35; .loc 1 104 0 ld.f64 %r36,[%frame]; sub.f64 %r75,%r36,%r34; .loc 1 106 0 mov.b64 %r79,%r75; .loc 1 105 0 shr.u64 %r108,%r79,32; .loc 1 106 0 cvt.u32.u64 %r110,%r108; and.b32 %r109,%r110,2147483647; shl.b32 %r111,%r65,31; or.b32 %r112,%r109,%r111; cvt.u64.u32 %r113,%r112; shl.b64 %r114,%r113,32; and.b64 %r115,%r79,4294967295; or.b64 %r116,%r115,%r114; mov.b64 %r82,%r116; .loc 1 107 0 bra $L4; $L3: .loc 1 109 0 mov.u32 %r117,1048575; shr.s32 %r69,%r117,%r66; .loc 1 110 0 and.b32 %r118,%r64,%r69; or.b32 %r119,%r118,%r45; setp.eq.u32 %r120,%r119,0; @ %r120 bra $L4; .loc 1 111 0 shr.u32 %r70,%r69,1; .loc 1 112 0 and.b32 %r121,%r64,%r70; or.b32 %r122,%r121,%r45; setp.eq.u32 %r123,%r122,0; @ %r123 bra $L8; .loc 1 114 0 setp.eq.u32 %r124,%r66,19; selp.u32 %r45,-2147483648,0,%r124; .loc 1 115 0 not.b32 %r125,%r70; and.b32 %r126,%r125,%r64; mov.u32 %r128,262144; shr.s32 %r127,%r128,%r66; or.b32 %r64,%r126,%r127; bra $L5; $L2: .loc 1 118 0 setp.le.s32 %r129,%r66,51; @ %r129 bra $L7; .loc 1 119 0 setp.ne.u32 %r130,%r66,1024; @ %r130 bra $L4; add.f64 %r82,%r82,%r82; bra $L4; $L7: .loc 1 122 0 add.u32 %r53,%r24,-1043; mov.u32 %r131,-1; shr.u32 %r67,%r131,%r53; .loc 1 123 0 and.b32 %r132,%r45,%r67; setp.eq.u32 %r133,%r132,0; @ %r133 bra $L4; .loc 1 124 0 shr.u32 %r68,%r67,1; .loc 1 125 0 and.b32 %r134,%r45,%r68; setp.eq.u32 %r135,%r134,0; @ %r135 bra $L5; not.b32 %r136,%r68; and.b32 %r137,%r136,%r45; mov.u32 %r139,1073741824; shr.s32 %r138,%r139,%r53; or.b32 %r45,%r137,%r138; bra $L5; $L8: mov.u32 %r45,%r122; $L5: .loc 1 127 0 cvt.u64.u32 %r140,%r64; cvt.u64.u32 %r144,%r45; shl.b64 %r145,%r140,32; or.b64 %r146,%r145,%r144; mov.b64 %r77,%r146; .loc 1 128 0 cvta.const.u64 %r147,TWO52; cvt.s64.s32 %r148,%r65; shl.b64 %r149,%r148,3; add.u64 %r150,%r147,%r149; ld.f64 %r61,[%r150]; add.f64 %r62,%r61,%r77; st.f64 [%frame],%r62; .loc 1 129 0 ld.f64 %r63,[%frame]; sub.f64 %r82,%r63,%r61; $L4: .loc 1 130 0 mov.f64 %value,%r82; st.param.f64 [%value_out],%value; ret; } lib_a-s_round.o/0 0 0 644 2842 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: round .visible .func (.param .f64 %value_out) round (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_round.c" // BEGIN GLOBAL FUNCTION DEF: round .visible .func (.param .f64 %value_out) round (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r25; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r45; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .pred %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r81; .reg .u64 %r82; .reg .u64 %r83; mov.f64 %r49,%ar0; mov.b64 %r50,%r49; shr.u64 %r51,%r50,32; .loc 1 59 0 cvt.u32.u64 %r39,%r51; cvt.u32.u64 %r25,%r50; .loc 1 62 0 shr.s32 %r53,%r39,20; and.b32 %r23,%r53,2047; add.u32 %r41,%r23,-1023; .loc 1 64 0 setp.gt.s32 %r54,%r41,19; @ %r54 bra $L2; .loc 1 66 0 setp.ge.s32 %r55,%r41,0; @ %r55 bra $L3; .loc 1 68 0 and.b32 %r39,%r39,-2147483648; .loc 1 69 0 setp.ne.u32 %r56,%r41,-1; @ %r56 bra $L8; .loc 1 71 0 or.b32 %r39,%r39,1072693248; .loc 1 72 0 mov.u32 %r40,0; bra $L4; $L3: .loc 1 76 0 mov.u32 %r57,1048575; shr.s32 %r45,%r57,%r41; .loc 1 77 0 and.b32 %r58,%r39,%r45; or.b32 %r59,%r58,%r25; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L9; .loc 1 81 0 mov.u32 %r62,524288; shr.s32 %r61,%r62,%r41; add.u32 %r63,%r61,%r39; .loc 1 82 0 not.b32 %r64,%r45; and.b32 %r39,%r63,%r64; .loc 1 83 0 mov.u32 %r40,0; bra $L4; $L2: .loc 1 86 0 setp.le.s32 %r65,%r41,51; @ %r65 bra $L6; .loc 1 88 0 setp.ne.u32 %r66,%r41,1024; @ %r66 bra $L10; .loc 1 90 0 add.f64 %r48,%r49,%r49; bra $L1; $L6: .loc 1 96 0 add.u32 %r67,%r23,-1043; mov.u32 %r68,-1; shr.u32 %r42,%r68,%r67; .loc 1 99 0 and.b32 %r69,%r25,%r42; setp.eq.u32 %r70,%r69,0; @ %r70 bra $L11; .loc 1 103 0 mov.u32 %r72,51; sub.u32 %r71,%r72,%r41; mov.u32 %r74,1; shl.b32 %r73,%r74,%r71; add.u32 %r43,%r73,%r25; .loc 1 104 0 setp.le.u32 %r75,%r25,%r43; @ %r75 bra $L7; .loc 1 105 0 add.u32 %r39,%r39,1; $L7: .loc 1 108 0 not.b32 %r76,%r42; and.b32 %r40,%r76,%r43; bra $L4; $L8: .loc 1 72 0 mov.u32 %r40,0; $L4: .loc 1 110 0 cvt.u64.u32 %r77,%r39; cvt.u64.u32 %r81,%r40; shl.b64 %r82,%r77,32; or.b64 %r83,%r82,%r81; mov.b64 %r48,%r83; .loc 1 112 0 bra $L1; $L9: .loc 1 79 0 mov.f64 %r48,%r49; bra $L1; $L10: mov.f64 %r48,%r49; bra $L1; $L11: mov.f64 %r48,%r49; $L1: .loc 1 113 0 mov.f64 %value,%r48; st.param.f64 [%value_out],%value; ret; } /758 0 0 0 644 4362 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbln .visible .func (.param .f64 %value_out) scalbln (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_scalbln.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbln .visible .func (.param .f64 %value_out) scalbln (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r29; .reg .u32 %r48; .reg .u32 %r50; .reg .f64 %r53; .reg .u64 %r55; .reg .u64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r79; .reg .u32 %r80; .reg .u16 %r81; .reg .u16 %r82; .reg .u16 %r83; .reg .u32 %r84; .reg .u16 %r85; .reg .pred %r86; .reg .f64 %r87; .reg .f64 %r89; .reg .pred %r90; .reg .f64 %r91; .reg .f64 %r93; .reg .pred %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .f64 %r103; .reg .f64 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; mov.f64 %r58,%ar0; mov.u64 %r59,%ar1; .loc 1 42 0 mov.b64 %r60,%r58; shr.u64 %r61,%r60,32; cvt.u32.u64 %r48,%r61; .loc 1 43 0 shr.s32 %r62,%r48,20; and.b32 %r50,%r62,2047; .loc 1 44 0 setp.ne.u32 %r63,%r50,0; @ %r63 bra $L2; .loc 1 45 0 and.b32 %r64,%r48,2147483647; cvt.u32.u64 %r67,%r60; or.b32 %r66,%r64,%r67; setp.eq.u32 %r68,%r66,0; @ %r68 bra $L9; .loc 1 46 0 mul.f64 %r58,%r58,0d4350000000000000; .loc 1 47 0 mov.b64 %r69,%r58; shr.u64 %r70,%r69,32; cvt.u32.u64 %r48,%r70; .loc 1 48 0 shr.s32 %r71,%r48,20; and.b32 %r72,%r71,2047; add.u32 %r50,%r72,-54; bra $L4; $L2: .loc 1 50 0 setp.ne.u32 %r73,%r50,2047; @ %r73 bra $L4; add.f64 %r57,%r58,%r58; bra $L1; $L4: .loc 1 51 0 cvt.u32.u64 %r74,%r59; add.u32 %r29,%r50,%r74; .loc 1 52 0 set.u32.gt.s64 %r76,%r59,50000; neg.s32 %r77,%r76; set.u32.gt.s32 %r79,%r29,2046; neg.s32 %r80,%r79; cvt.u16.u32 %r82,%r77; cvt.u16.u32 %r83,%r80; or.b16 %r81,%r82,%r83; cvt.u32.u16 %r84,%r81; cvt.u16.u8 %r85,%r84; setp.eq.u16 %r86,%r85,0; @ %r86 bra $L5; .loc 1 53 0 mov.f64 %r87,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r87; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r58; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r89,[%value_in]; } mul.f64 %r57,%r89,0d7e37e43c8800759c; bra $L1; $L5: .loc 1 54 0 setp.ge.s64 %r90,%r59,-50000; @ %r90 bra $L6; mov.f64 %r91,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r91; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r58; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r93,[%value_in]; } mul.f64 %r57,%r93,0d01a56e1fc2f8f359; bra $L1; $L6: .loc 1 55 0 setp.le.s32 %r94,%r29,0; @ %r94 bra $L7; .loc 1 56 0 mov.b64 %r55,%r58; and.b32 %r95,%r48,-2146435073; shl.b32 %r96,%r29,20; or.b32 %r97,%r95,%r96; cvt.u64.u32 %r98,%r97; shl.b64 %r99,%r98,32; and.b64 %r100,%r55,4294967295; or.b64 %r101,%r100,%r99; mov.b64 %r57,%r101; bra $L1; $L7: .loc 1 57 0 setp.ge.s32 %r102,%r29,-53; @ %r102 bra $L8; .loc 1 58 0 mov.f64 %r103,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r103; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r58; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r105,[%value_in]; } mul.f64 %r57,%r105,0d01a56e1fc2f8f359; bra $L1; $L8: .loc 1 60 0 mov.b64 %r56,%r58; .loc 1 59 0 add.u32 %r106,%r29,54; .loc 1 60 0 shl.b32 %r107,%r106,20; and.b32 %r108,%r48,-2146435073; or.b32 %r109,%r107,%r108; cvt.u64.u32 %r110,%r109; shl.b64 %r111,%r110,32; and.b64 %r112,%r56,4294967295; or.b64 %r113,%r112,%r111; mov.b64 %r53,%r113; .loc 1 61 0 mul.f64 %r57,%r53,0d3c90000000000000; bra $L1; $L9: .loc 1 45 0 mov.f64 %r57,%r58; $L1: .loc 1 62 0 mov.f64 %value,%r57; st.param.f64 [%value_out],%value; ret; } /777 0 0 0 644 4051 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .f64 %r46; .reg .u64 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .pred %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .pred %r81; .reg .pred %r82; .reg .f64 %r83; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; mov.f64 %r52,%ar0; mov.u32 %r53,%ar1; .loc 1 86 0 mov.b64 %r54,%r52; shr.u64 %r55,%r54,32; cvt.u32.u64 %r41,%r55; .loc 1 87 0 shr.s32 %r56,%r41,20; and.b32 %r43,%r56,2047; .loc 1 88 0 setp.ne.u32 %r57,%r43,0; @ %r57 bra $L2; .loc 1 89 0 and.b32 %r58,%r41,2147483647; cvt.u32.u64 %r61,%r54; or.b32 %r60,%r58,%r61; setp.eq.u32 %r62,%r60,0; @ %r62 bra $L10; .loc 1 90 0 mul.f64 %r52,%r52,0d4350000000000000; .loc 1 93 0 setp.ge.s32 %r63,%r53,-50000; @ %r63 bra $L4; mul.f64 %r51,%r52,0d01a56e1fc2f8f359; bra $L1; $L2: .loc 1 95 0 setp.ne.u32 %r64,%r43,2047; @ %r64 bra $L5; add.f64 %r51,%r52,%r52; bra $L1; $L4: .loc 1 91 0 mov.b64 %r65,%r52; shr.u64 %r66,%r65,32; cvt.u32.u64 %r41,%r66; .loc 1 92 0 shr.s32 %r67,%r41,20; and.b32 %r68,%r67,2047; add.u32 %r43,%r68,-54; $L5: .loc 1 96 0 add.u32 %r44,%r53,%r43; .loc 1 97 0 setp.le.s32 %r69,%r44,2046; @ %r69 bra $L6; mov.f64 %r70,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r70; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r72,[%value_in]; } mul.f64 %r51,%r72,0d7e37e43c8800759c; bra $L1; $L6: .loc 1 98 0 setp.le.s32 %r73,%r44,0; @ %r73 bra $L7; .loc 1 99 0 mov.b64 %r49,%r52; and.b32 %r74,%r41,-2146435073; shl.b32 %r75,%r44,20; or.b32 %r76,%r74,%r75; cvt.u64.u32 %r77,%r76; shl.b64 %r78,%r77,32; and.b64 %r79,%r49,4294967295; or.b64 %r80,%r79,%r78; mov.b64 %r51,%r80; bra $L1; $L7: .loc 1 100 0 setp.ge.s32 %r81,%r44,-53; @ %r81 bra $L8; .loc 1 101 0 setp.le.s32 %r82,%r53,50000; @ %r82 bra $L9; .loc 1 102 0 mov.f64 %r83,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r83; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r85,[%value_in]; } mul.f64 %r51,%r85,0d7e37e43c8800759c; bra $L1; $L9: .loc 1 103 0 mov.f64 %r86,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r88,[%value_in]; } mul.f64 %r51,%r88,0d01a56e1fc2f8f359; bra $L1; $L8: .loc 1 106 0 mov.b64 %r50,%r52; .loc 1 105 0 add.u32 %r89,%r44,54; .loc 1 106 0 shl.b32 %r90,%r89,20; and.b32 %r91,%r41,-2146435073; or.b32 %r92,%r90,%r91; cvt.u64.u32 %r93,%r92; shl.b64 %r94,%r93,32; and.b64 %r95,%r50,4294967295; or.b64 %r96,%r95,%r94; mov.b64 %r46,%r96; .loc 1 107 0 mul.f64 %r51,%r46,0d3c90000000000000; bra $L1; $L10: .loc 1 89 0 mov.f64 %r51,%r52; $L1: .loc 1 108 0 mov.f64 %value,%r51; st.param.f64 [%value_out],%value; ret; } /795 0 0 0 644 1137 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __signbitf .visible .func (.param .u32 %value_out) __signbitf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_signbit.c" // BEGIN GLOBAL FUNCTION DECL: __signbitd .visible .func (.param .u32 %value_out) __signbitd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __signbitf .visible .func (.param .u32 %value_out) __signbitf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r25; .reg .u32 %r27; mov.f32 %r25,%ar0; .loc 1 48 0 mov.b32 %r27,%r25; and.b32 %value,%r27,-2147483648; .loc 1 49 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __signbitd .visible .func (.param .u32 %value_out) __signbitd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r25; .reg .u64 %r27; .reg .u64 %r28; .reg .u32 %r29; mov.f64 %r25,%ar0; .loc 1 58 0 mov.b64 %r27,%r25; shr.u64 %r28,%r27,32; cvt.u32.u64 %r29,%r28; and.b32 %value,%r29,-2147483648; .loc 1 59 0 st.param.u32 [%value_out],%value; ret; } /814 0 0 0 644 1281 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: significand .visible .func (.param .f64 %value_out) significand (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_signif.c" // BEGIN GLOBAL FUNCTION DECL: ilogb .extern .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalb .extern .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: significand .visible .func (.param .f64 %value_out) significand (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r26; .reg .u32 %r28; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; mov.f64 %r26,%ar0; .loc 1 31 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),ilogb,(%out_arg1); ld.param.u32 %r28,[%value_in]; } neg.s32 %r31,%r28; cvt.rn.f64.s32 %r32,%r31; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),__ieee754_scalb,(%out_arg1,%out_arg2); ld.param.f64 %r33,[%value_in]; } .loc 1 32 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } lib_a-s_sin.o/ 0 0 0 644 3956 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sin .visible .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_sin.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .extern .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .extern .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .extern .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: sin .visible .func (.param .f64 %value_out) sin (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r33; .reg .u32 %r34; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .u32 %r44; .reg .f64 %r45; .reg .pred %r46; .reg .u32 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .f64 %r54; .reg .u32 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .u32 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r70; .reg .f64 %r71; mov.f64 %r38,%ar0; .loc 1 110 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r33,%r40; .loc 1 113 0 and.b32 %r34,%r33,2147483647; .loc 1 114 0 setp.gt.s32 %r41,%r34,1072243195; @ %r41 bra $L2; mov.u32 %r44,0; mov.f64 %r43,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r44; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r45,[%value_in]; } mov.f64 %r37,%r45; bra $L1; $L2: .loc 1 117 0 setp.le.s32 %r46,%r34,2146435071; @ %r46 bra $L4; sub.f64 %r37,%r38,%r38; bra $L1; $L4: .loc 1 121 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2,(%out_arg1,%out_arg2); ld.param.u32 %r49,[%value_in]; } .loc 1 122 0 and.b32 %r50,%r49,3; setp.eq.u32 %r51,%r50,1; @ %r51 bra $L6; setp.eq.u32 %r52,%r50,2; @ %r52 bra $L7; setp.eq.u32 %r53,%r50,0; @ ! %r53 bra $L9; .loc 1 123 0 ld.f64 %r57,[%frame+8]; mov.u32 %r56,1; ld.f64 %r54,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r54; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r57; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r56; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r58,[%value_in]; } mov.f64 %r37,%r58; bra $L1; $L6: .loc 1 124 0 ld.f64 %r61,[%frame+8]; ld.f64 %r59,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r61; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r62,[%value_in]; } mov.f64 %r37,%r62; bra $L1; $L7: .loc 1 125 0 ld.f64 %r66,[%frame+8]; mov.u32 %r65,1; ld.f64 %r63,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r63; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r66; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r65; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r67,[%value_in]; } neg.f64 %r37,%r67; bra $L1; $L9: .loc 1 127 0 ld.f64 %r70,[%frame+8]; ld.f64 %r68,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r68; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r70; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r71,[%value_in]; } neg.f64 %r37,%r71; $L1: .loc 1 130 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } lib_a-s_tan.o/ 0 0 0 644 2533 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tan .visible .func (.param .f64 %value_out) tan (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_tan.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_tan .extern .func (.param .f64 %value_out) __kernel_tan (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .extern .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: tan .visible .func (.param .f64 %value_out) tan (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r27; .reg .u32 %r28; .reg .f64 %r31; .reg .f64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .pred %r35; .reg .f64 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .pred %r40; .reg .u32 %r43; .reg .f64 %r44; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .f64 %r51; .reg .f64 %r52; mov.f64 %r32,%ar0; .loc 1 97 0 mov.b64 %r33,%r32; shr.u64 %r34,%r33,32; cvt.u32.u64 %r27,%r34; .loc 1 100 0 and.b32 %r28,%r27,2147483647; .loc 1 101 0 setp.gt.s32 %r35,%r28,1072243195; @ %r35 bra $L2; mov.u32 %r38,1; mov.f64 %r37,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r37; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r38; call (%value_in),__kernel_tan,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r39,[%value_in]; } mov.f64 %r31,%r39; bra $L1; $L2: .loc 1 104 0 setp.le.s32 %r40,%r28,2146435071; @ %r40 bra $L4; sub.f64 %r31,%r32,%r32; bra $L1; $L4: .loc 1 108 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2,(%out_arg1,%out_arg2); ld.param.u32 %r43,[%value_in]; } .loc 1 109 0 add.u32 %r47,%r43,%r43; and.b32 %r48,%r47,2; mov.u32 %r50,1; sub.u32 %r49,%r50,%r48; ld.f64 %r51,[%frame+8]; ld.f64 %r44,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r51; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r49; call (%value_in),__kernel_tan,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r52,[%value_in]; } mov.f64 %r31,%r52; $L1: .loc 1 112 0 mov.f64 %value,%r31; st.param.f64 [%value_out],%value; ret; } lib_a-s_tanh.o/ 0 0 0 644 2918 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanh .visible .func (.param .f64 %value_out) tanh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/s_tanh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanh .visible .func (.param .f64 %value_out) tanh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r31; .reg .u32 %r32; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .f64 %r42; .reg .pred %r43; .reg .pred %r45; .reg .pred %r46; .reg .f64 %r47; .reg .pred %r48; .reg .f64 %r50; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .pred %r65; mov.f64 %r38,%ar0; .loc 1 101 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r31,%r40; .loc 1 102 0 and.b32 %r32,%r31,2147483647; .loc 1 105 0 setp.le.s32 %r41,%r32,2146435071; @ %r41 bra $L2; mov.f64 %r42,0d3ff0000000000000; div.rn.f64 %r36,%r42,%r38; .loc 1 106 0 setp.lt.s32 %r43,%r31,0; @ %r43 bra $L3; add.f64 %r37,%r36,0d3ff0000000000000; bra $L1; $L3: .loc 1 107 0 sub.f64 %r37,%r36,%r42; bra $L1; $L2: .loc 1 111 0 setp.gt.s32 %r45,%r32,1077280767; @ %r45 bra $L8; .loc 1 112 0 setp.gt.s32 %r46,%r32,1015021567; @ %r46 bra $L6; .loc 1 113 0 add.f64 %r47,%r38,0d3ff0000000000000; mul.f64 %r37,%r47,%r38; bra $L1; $L6: .loc 1 114 0 setp.le.s32 %r48,%r32,1072693247; @ %r48 bra $L7; .loc 1 115 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r50,[%value_in]; } add.f64 %r52,%r50,%r50; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r53,[%value_in]; } .loc 1 116 0 add.f64 %r54,%r53,0d4000000000000000; mov.f64 %r56,0d4000000000000000; div.rn.f64 %r55,%r56,%r54; mov.f64 %r57,0d3ff0000000000000; sub.f64 %r37,%r57,%r55; bra $L5; $L7: .loc 1 118 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r59,[%value_in]; } mul.f64 %r61,%r59,0dc000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r61; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r62,[%value_in]; } .loc 1 119 0 neg.f64 %r63,%r62; add.f64 %r64,%r62,0d4000000000000000; div.rn.f64 %r37,%r63,%r64; bra $L5; $L8: .loc 1 123 0 mov.f64 %r37,0d3ff0000000000000; $L5: .loc 1 125 0 setp.ge.s32 %r65,%r31,0; @ %r65 bra $L1; neg.f64 %r37,%r37; $L1: .loc 1 126 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } lib_a-s_trunc.o/0 0 0 644 2018 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: trunc .visible .func (.param .f64 %value_out) trunc (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_trunc.c" // BEGIN GLOBAL FUNCTION DEF: trunc .visible .func (.param .f64 %value_out) trunc (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r41; .reg .f64 %r42; .reg .u64 %r43; .reg .u64 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r62; .reg .pred %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; mov.f64 %r42,%ar0; mov.b64 %r43,%r42; shr.u64 %r44,%r43,32; cvt.u32.u64 %r36,%r44; .loc 1 64 0 shr.s32 %r45,%r36,20; and.b32 %r23,%r45,2047; add.u32 %r35,%r23,-1023; .loc 1 66 0 setp.gt.s32 %r46,%r35,19; @ %r46 bra $L2; .loc 1 69 0 setp.ge.s32 %r47,%r35,0; @ %r47 bra $L3; .loc 1 61 0 and.b32 %r48,%r36,-2147483648; .loc 1 72 0 cvt.u64.u32 %r49,%r48; shl.b64 %r53,%r49,32; mov.b64 %r41,%r53; bra $L1; $L3: .loc 1 77 0 mov.u32 %r55,1048575; shr.s32 %r54,%r55,%r35; not.b32 %r56,%r54; and.b32 %r57,%r56,%r36; cvt.u64.u32 %r58,%r57; shl.b64 %r62,%r58,32; mov.b64 %r41,%r62; bra $L1; $L2: .loc 1 80 0 setp.le.s32 %r63,%r35,51; @ %r63 bra $L5; .loc 1 82 0 setp.ne.u32 %r64,%r35,1024; @ %r64 bra $L6; .loc 1 85 0 add.f64 %r41,%r42,%r42; bra $L1; $L5: .loc 1 93 0 cvt.u64.u32 %r65,%r36; add.u32 %r69,%r23,-1043; mov.u32 %r71,-1; shr.u32 %r70,%r71,%r69; not.b32 %r72,%r70; cvt.u32.u64 %r75,%r43; and.b32 %r74,%r72,%r75; cvt.u64.u32 %r76,%r74; shl.b64 %r77,%r65,32; or.b64 %r78,%r77,%r76; mov.b64 %r41,%r78; bra $L1; $L6: mov.f64 %r41,%r42; $L1: .loc 1 96 0 mov.f64 %value,%r41; st.param.f64 [%value_out],%value; ret; } /832 0 0 0 644 1023 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalblnl .visible .func (.param .f64 %value_out) scalblnl (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/scalblnl.c" // BEGIN GLOBAL FUNCTION DECL: scalbln .extern .func (.param .f64 %value_out) scalbln (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalblnl .visible .func (.param .f64 %value_out) scalblnl (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),scalbln,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-scalbnl.o/0 0 0 644 1015 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbnl .visible .func (.param .f64 %value_out) scalbnl (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/common/scalbnl.c" // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbnl .visible .func (.param .f64 %value_out) scalbnl (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u32 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } /850 0 0 0 644 3690 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinhf .visible .func (.param .f32 %value_out) asinhf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_asinh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1pf .extern .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinhf .visible .func (.param .f32 %value_out) asinhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r36; .reg .u32 %r37; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .f32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .f32 %r49; .reg .f32 %r51; .reg .pred %r52; .reg .f32 %r54; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .pred %r74; mov.f32 %r42,%ar0; .loc 1 36 0 mov.b32 %r36,%r42; .loc 1 37 0 and.b32 %r37,%r36,2147483647; .loc 1 38 0 setp.le.s32 %r43,%r37,2139095039; @ %r43 bra $L2; add.f32 %r41,%r42,%r42; bra $L1; $L2: .loc 1 39 0 setp.gt.s32 %r44,%r37,830472191; @ %r44 bra $L4; .loc 1 40 0 add.f32 %r45,%r42,0f7149f2ca; setp.gt.f32 %r46,%r45,0f3f800000; @ %r46 bra $L8; bra $L5; $L4: .loc 1 42 0 setp.le.s32 %r47,%r37,1300234240; @ %r47 bra $L6; .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r49; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r51,[%value_in]; } add.f32 %r41,%r51,0f3f317218; bra $L7; $L6: .loc 1 44 0 setp.le.s32 %r52,%r37,1073741824; @ %r52 bra $L5; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r54,[%value_in]; } .loc 1 46 0 fma.rn.f32 %r56,%r42,%r42,0f3f800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r56; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r57,[%value_in]; } add.f32 %r59,%r57,%r54; mov.f32 %r61,0f3f800000; div.rn.f32 %r60,%r61,%r59; fma.rn.f32 %r62,%r54,0f40000000,%r60; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r63,[%value_in]; } mov.f32 %r41,%r63; bra $L7; $L5: .loc 1 48 0 mul.f32 %r39,%r42,%r42; .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r65,[%value_in]; } add.f32 %r67,%r39,0f3f800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } add.f32 %r70,%r68,0f3f800000; div.rn.f32 %r71,%r39,%r70; add.f32 %r72,%r71,%r65; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r72; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r73,[%value_in]; } mov.f32 %r41,%r73; $L7: .loc 1 51 0 setp.gt.s32 %r74,%r36,0; @ %r74 bra $L1; neg.f32 %r41,%r41; bra $L1; $L8: .loc 1 40 0 mov.f32 %r41,%r42; $L1: .loc 1 52 0 mov.f32 %value,%r41; st.param.f32 [%value_out],%value; ret; } lib_a-sf_atan.o/0 0 0 644 4194 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atanf .visible .func (.param .f32 %value_out) atanf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_atan.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN VAR DEF: atanhi .const .align 4 .u32 atanhi[4] = {1055744824,1061752794,1065064542,1070141402 }; // BEGIN VAR DEF: atanlo .const .align 4 .u32 atanlo[4] = {833369961,857874792,856952756,866263400 }; // BEGIN GLOBAL FUNCTION DEF: atanf .visible .func (.param .f32 %value_out) atanf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r27; .reg .f32 %r28; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .pred %r61; .reg .pred %r62; .reg .pred %r63; .reg .f32 %r64; .reg .pred %r65; .reg .f32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .f32 %r70; .reg .pred %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r83; .reg .f32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .pred %r98; mov.f32 %r58,%ar0; .loc 1 77 0 mov.b32 %r43,%r58; .loc 1 78 0 and.b32 %r44,%r43,2147483647; .loc 1 79 0 setp.le.s32 %r59,%r44,1350565887; @ %r59 bra $L2; .loc 1 80 0 setp.le.s32 %r60,%r44,2139095040; @ %r60 bra $L3; .loc 1 81 0 add.f32 %r57,%r58,%r58; bra $L1; $L3: .loc 1 82 0 setp.le.s32 %r61,%r43,0; selp.f32 %r57,0fbfc90fdb,0f3fc90fdb,%r61; bra $L1; $L2: .loc 1 84 0 setp.gt.s32 %r62,%r44,1054867455; @ %r62 bra $L5; .loc 1 85 0 setp.gt.s32 %r63,%r44,822083583; @ %r63 bra $L12; .loc 1 86 0 add.f32 %r64,%r58,0f7149f2ca; setp.gt.f32 %r65,%r64,0f3f800000; @ %r65 bra $L13; .loc 1 88 0 mov.u32 %r42,-1; bra $L6; $L5: .loc 1 90 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r67,[%value_in]; } .loc 1 91 0 setp.gt.s32 %r68,%r44,1066926079; @ %r68 bra $L7; .loc 1 92 0 setp.gt.s32 %r69,%r44,1060110335; @ %r69 bra $L8; .loc 1 93 0 fma.rn.f32 %r23,%r67,0f40000000,0fbf800000; add.f32 %r24,%r67,0f40000000; div.rn.f32 %r58,%r23,%r24; mov.u32 %r42,0; bra $L6; $L8: .loc 1 95 0 mov.f32 %r70,0f3f800000; sub.f32 %r25,%r67,%r70; add.f32 %r26,%r67,0f3f800000; div.rn.f32 %r58,%r25,%r26; mov.u32 %r42,1; bra $L6; $L7: .loc 1 98 0 setp.gt.s32 %r71,%r44,1075576831; @ %r71 bra $L9; .loc 1 99 0 mov.f32 %r72,0f3fc00000; sub.f32 %r27,%r67,%r72; fma.rn.f32 %r28,%r67,0f3fc00000,0f3f800000; div.rn.f32 %r58,%r27,%r28; mov.u32 %r42,2; bra $L6; $L9: .loc 1 101 0 mov.f32 %r73,0fbf800000; div.rn.f32 %r58,%r73,%r67; mov.u32 %r42,3; bra $L6; $L12: .loc 1 88 0 mov.u32 %r42,-1; $L6: .loc 1 105 0 mul.f32 %r47,%r58,%r58; .loc 1 106 0 mul.f32 %r48,%r47,%r47; .loc 1 108 0 fma.rn.f32 %r74,%r48,0f3c8569d7,0f3d4bda59; fma.rn.f32 %r75,%r74,%r48,0f3d886b35; fma.rn.f32 %r76,%r75,%r48,0f3dba2e6e; fma.rn.f32 %r77,%r76,%r48,0f3e124925; fma.rn.f32 %r78,%r77,%r48,0f3eaaaaab; .loc 1 109 0 fma.rn.f32 %r79,%r48,0fbd15a221,0fbd6ef16b; fma.rn.f32 %r80,%r79,%r48,0fbd9d8795; fma.rn.f32 %r81,%r80,%r48,0fbde38e38; fma.rn.f32 %r82,%r81,%r48,0fbe4ccccd; mul.f32 %r83,%r82,%r48; fma.rn.f32 %r84,%r78,%r47,%r83; mul.f32 %r56,%r84,%r58; .loc 1 110 0 setp.ne.u32 %r85,%r42,-1; @ %r85 bra $L10; sub.f32 %r57,%r58,%r56; bra $L1; $L10: .loc 1 112 0 cvta.const.u64 %r86,atanhi; cvt.s64.s32 %r87,%r42; shl.b64 %r88,%r87,2; add.u64 %r89,%r86,%r88; cvta.const.u64 %r90,atanlo; add.u64 %r93,%r90,%r88; ld.f32 %r95,[%r93]; sub.f32 %r94,%r56,%r95; sub.f32 %r96,%r94,%r58; ld.f32 %r97,[%r89]; sub.f32 %r57,%r97,%r96; .loc 1 113 0 setp.ge.s32 %r98,%r43,0; @ %r98 bra $L1; neg.f32 %r57,%r57; bra $L1; $L13: .loc 1 86 0 mov.f32 %r57,%r58; $L1: .loc 1 115 0 mov.f32 %value,%r57; st.param.f32 [%value_out],%value; ret; } lib_a-sf_cbrt.o/0 0 0 644 2040 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cbrtf .visible .func (.param .f32 %value_out) cbrtf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_cbrt.c" // BEGIN GLOBAL FUNCTION DEF: cbrtf .visible .func (.param .f32 %value_out) cbrtf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .u32 %r24; .reg .u32 %r27; .reg .u32 %r37; .reg .f32 %r38; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .f32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r58; .reg .u32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .u32 %r70; .reg .u32 %r71; mov.f32 %r47,%ar0; .loc 1 53 0 mov.b32 %r22,%r47; .loc 1 55 0 and.b32 %r24,%r22,2147483647; .loc 1 56 0 setp.le.u32 %r48,%r24,2139095039; @ %r48 bra $L2; .loc 1 57 0 add.f32 %r46,%r47,%r47; bra $L1; $L2: .loc 1 58 0 setp.eq.u32 %r49,%r24,0; @ %r49 bra $L6; .loc 1 61 0 mov.b32 %r41,%r24; .loc 1 63 0 setp.gt.s32 %r50,%r24,8388607; @ %r50 bra $L4; .loc 1 65 0 mul.f32 %r51,%r41,0f4b800000; mov.b32 %r53,%r51; div.u32 %r54,%r53,3; add.u32 %r27,%r54,642849266; mov.b32 %r38,%r27; bra $L5; $L4: .loc 1 68 0 div.s32 %r58,%r24,3; add.u32 %r59,%r58,709958130; mov.b32 %r38,%r59; $L5: .loc 1 72 0 mul.f32 %r60,%r38,%r38; div.rn.f32 %r61,%r60,%r41; .loc 1 73 0 fma.rn.f32 %r44,%r38,%r61,0f3f0af8b0; .loc 1 74 0 add.f32 %r62,%r44,0f3fb50750; mov.f32 %r64,0fbf348ef1; div.rn.f32 %r63,%r64,%r44; add.f32 %r65,%r62,%r63; mov.f32 %r67,0f3fcdb6db; div.rn.f32 %r66,%r67,%r65; add.f32 %r68,%r66,0f3eb6db6e; mul.f32 %r69,%r68,%r38; .loc 1 54 0 and.b32 %r70,%r22,-2147483648; .loc 1 78 0 mov.b32 %r71,%r69; or.b32 %r37,%r70,%r71; mov.b32 %r46,%r37; .loc 1 79 0 bra $L1; $L6: .loc 1 59 0 mov.f32 %r46,%r47; $L1: .loc 1 80 0 mov.f32 %value,%r46; st.param.f32 [%value_out],%value; ret; } lib_a-sf_ceil.o/0 0 0 644 2151 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ceilf .visible .func (.param .f32 %value_out) ceilf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_ceil.c" // BEGIN GLOBAL FUNCTION DEF: ceilf .visible .func (.param .f32 %value_out) ceilf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .pred %r56; mov.f32 %r38,%ar0; .loc 1 33 0 mov.b32 %r22,%r38; .loc 1 34 0 and.b32 %r34,%r22,2147483647; .loc 1 35 0 shr.u32 %r39,%r34,23; add.u32 %r35,%r39,-127; .loc 1 36 0 setp.gt.s32 %r40,%r35,22; @ %r40 bra $L2; .loc 1 33 0 mov.u32 %r33,%r22; .loc 1 37 0 setp.ge.s32 %r41,%r35,0; @ %r41 bra $L3; .loc 1 38 0 add.f32 %r42,%r38,0f7149f2ca; setp.gt.f32 %r43,%r42,0f00000000; @ ! %r43 bra $L17; .loc 1 39 0 setp.lt.s32 %r44,%r22,0; @ %r44 bra $L10; .loc 1 40 0 setp.eq.u32 %r45,%r34,0; selp.f32 %r37,%r38,0f3f800000,%r45; bra $L1; $L3: .loc 1 43 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r35; .loc 1 44 0 and.b32 %r47,%r22,%r36; setp.eq.u32 %r48,%r47,0; @ %r48 bra $L12; .loc 1 45 0 add.f32 %r49,%r38,0f7149f2ca; setp.gt.f32 %r50,%r49,0f00000000; @ ! %r50 bra $L18; .loc 1 46 0 setp.le.s32 %r51,%r33,0; @ %r51 bra $L8; mov.u32 %r53,8388608; shr.s32 %r52,%r53,%r35; add.u32 %r33,%r33,%r52; $L8: .loc 1 47 0 not.b32 %r54,%r36; and.b32 %r55,%r54,%r33; mov.b32 %r37,%r55; bra $L1; $L2: .loc 1 51 0 setp.le.u32 %r56,%r34,2139095039; @ %r56 bra $L14; add.f32 %r37,%r38,%r38; bra $L1; $L17: mov.f32 %r37,%r38; bra $L1; $L10: mov.f32 %r37,0f80000000; bra $L1; $L18: mov.f32 %r37,%r38; .loc 1 55 0 bra $L1; $L12: .loc 1 44 0 mov.f32 %r37,%r38; bra $L1; $L14: mov.f32 %r37,%r38; $L1: .loc 1 56 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /868 0 0 0 644 884 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r24; .reg .f32 %r28; .reg .f32 %r29; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; mov.f32 %r28,%ar0; mov.f32 %r29,%ar1; .loc 1 34 0 mov.b32 %r31,%r28; and.b32 %r30,%r31,2147483647; mov.b32 %r33,%r29; and.b32 %r32,%r33,-2147483648; or.b32 %r24,%r30,%r32; .loc 1 35 0 mov.b32 %value,%r24; .loc 1 36 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_cos.o/ 0 0 0 644 3748 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cosf .visible .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_cos.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .extern .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .extern .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .extern .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: cosf .visible .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .pred %r39; .reg .f32 %r41; .reg .f32 %r42; .reg .pred %r43; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .f32 %r51; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .u32 %r66; .reg .f32 %r67; .reg .f32 %r68; mov.f32 %r38,%ar0; .loc 1 34 0 mov.b32 %r34,%r38; .loc 1 37 0 and.b32 %r35,%r34,2147483647; .loc 1 38 0 setp.gt.s32 %r39,%r35,1061752792; @ %r39 bra $L2; mov.f32 %r41,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r42,[%value_in]; } mov.f32 %r37,%r42; bra $L1; $L2: .loc 1 41 0 setp.le.s32 %r43,%r35,2139095039; @ %r43 bra $L4; sub.f32 %r37,%r38,%r38; bra $L1; $L4: .loc 1 45 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2f,(%out_arg1,%out_arg2); ld.param.u32 %r46,[%value_in]; } .loc 1 46 0 and.b32 %r47,%r46,3; setp.eq.u32 %r48,%r47,1; @ %r48 bra $L6; setp.eq.u32 %r49,%r47,2; @ %r49 bra $L7; setp.eq.u32 %r50,%r47,0; @ ! %r50 bra $L9; .loc 1 47 0 ld.f32 %r53,[%frame+4]; ld.f32 %r51,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r54,[%value_in]; } mov.f32 %r37,%r54; bra $L1; $L6: .loc 1 48 0 ld.f32 %r58,[%frame+4]; ld.f32 %r55,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r55; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r58; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r47; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r59,[%value_in]; } neg.f32 %r37,%r59; bra $L1; $L7: .loc 1 49 0 ld.f32 %r62,[%frame+4]; ld.f32 %r60,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r60; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r62; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r63,[%value_in]; } neg.f32 %r37,%r63; bra $L1; $L9: .loc 1 51 0 ld.f32 %r67,[%frame+4]; mov.u32 %r66,1; ld.f32 %r64,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r64; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r67; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r66; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r68,[%value_in]; } mov.f32 %r37,%r68; $L1: .loc 1 54 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_erf.o/ 0 0 0 644 14917 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erff .visible .func (.param .f32 %value_out) erff (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_erf.c" // BEGIN GLOBAL FUNCTION DECL: erfcf .visible .func (.param .f32 %value_out) erfcf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erff .visible .func (.param .f32 %value_out) erff (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r86; .reg .f32 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r123; .reg .f32 %r124; .reg .pred %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .pred %r133; .reg .pred %r134; .reg .pred %r135; .reg .f32 %r136; .reg .f32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .pred %r148; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r152; .reg .f32 %r153; .reg .f32 %r154; .reg .f32 %r155; .reg .f32 %r156; .reg .f32 %r157; .reg .f32 %r158; .reg .f32 %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .pred %r162; .reg .f32 %r163; .reg .f32 %r164; .reg .f32 %r165; .reg .pred %r166; .reg .pred %r167; .reg .f32 %r169; .reg .f32 %r170; .reg .f32 %r171; .reg .pred %r172; .reg .f32 %r173; .reg .f32 %r174; .reg .f32 %r175; .reg .f32 %r176; .reg .f32 %r177; .reg .f32 %r178; .reg .f32 %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r182; .reg .f32 %r183; .reg .f32 %r184; .reg .f32 %r185; .reg .f32 %r186; .reg .f32 %r187; .reg .f32 %r188; .reg .f32 %r189; .reg .f32 %r190; .reg .f32 %r191; .reg .f32 %r192; .reg .f32 %r193; .reg .f32 %r194; .reg .f32 %r195; .reg .f32 %r196; .reg .u32 %r197; .reg .u32 %r198; .reg .f32 %r200; .reg .f32 %r201; .reg .f32 %r202; .reg .f32 %r204; .reg .f32 %r205; .reg .f32 %r206; .reg .f32 %r207; .reg .f32 %r208; .reg .pred %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r212; .reg .f32 %r213; mov.f32 %r124,%ar0; .loc 1 110 0 mov.b32 %r88,%r124; .loc 1 111 0 and.b32 %r89,%r88,2147483647; .loc 1 112 0 setp.le.s32 %r125,%r89,2139095039; @ %r125 bra $L2; .loc 1 113 0 shr.u32 %r126,%r88,31; add.u32 %r127,%r126,%r126; .loc 1 114 0 mov.u32 %r129,1; sub.u32 %r128,%r129,%r127; cvt.rn.f32.s32 %r130,%r128; mov.f32 %r132,0f3f800000; div.rn.f32 %r131,%r132,%r124; add.f32 %r123,%r130,%r131; bra $L1; $L2: .loc 1 117 0 setp.gt.s32 %r133,%r89,1062731775; @ %r133 bra $L4; .loc 1 118 0 setp.gt.s32 %r134,%r89,830472191; @ %r134 bra $L5; .loc 1 119 0 setp.gt.s32 %r135,%r89,67108863; @ %r135 bra $L6; .loc 1 121 0 mul.f32 %r136,%r124,0f3f8375d4; fma.rn.f32 %r137,%r124,0f41000000,%r136; mul.f32 %r123,%r137,0f3e000000; bra $L1; $L6: .loc 1 122 0 fma.rn.f32 %r123,%r124,0f3e0375d4,%r124; bra $L1; $L5: .loc 1 124 0 mul.f32 %r98,%r124,%r124; .loc 1 125 0 fma.rn.f32 %r138,%r98,0fb7c756b1,0fbbbd1489; fma.rn.f32 %r139,%r138,%r98,0fbce9528f; fma.rn.f32 %r140,%r139,%r98,0fbea66beb; fma.rn.f32 %r141,%r140,%r98,0f3e0375d4; .loc 1 126 0 fma.rn.f32 %r142,%r98,0fb684e21a,0f390aee49; fma.rn.f32 %r143,%r142,%r98,0f3ba68116; fma.rn.f32 %r144,%r143,%r98,0f3d852a63; fma.rn.f32 %r145,%r144,%r98,0f3ecbbbce; fma.rn.f32 %r146,%r145,%r98,0f3f800000; .loc 1 127 0 div.rn.f32 %r147,%r141,%r146; .loc 1 128 0 fma.rn.f32 %r123,%r124,%r147,%r124; bra $L1; $L4: .loc 1 130 0 setp.gt.s32 %r148,%r89,1067450367; @ %r148 bra $L7; .loc 1 131 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r124; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r150,[%value_in]; } mov.f32 %r151,0f3f800000; sub.f32 %r95,%r150,%r151; .loc 1 132 0 fma.rn.f32 %r152,%r95,0fbb0df9c0,0f3d1151b3; fma.rn.f32 %r153,%r152,%r95,0fbde31cc2; fma.rn.f32 %r154,%r153,%r95,0f3ea2fe54; fma.rn.f32 %r155,%r154,%r95,0fbebe9208; fma.rn.f32 %r156,%r155,%r95,0f3ed46805; fma.rn.f32 %r96,%r156,%r95,0fbb1acdc6; .loc 1 133 0 fma.rn.f32 %r157,%r95,0f3c445aa3,0f3c5f6e13; fma.rn.f32 %r158,%r157,%r95,0f3e013307; fma.rn.f32 %r159,%r158,%r95,0f3d931ae7; fma.rn.f32 %r160,%r159,%r95,0f3f0a5785; fma.rn.f32 %r161,%r160,%r95,0f3dd9f331; fma.rn.f32 %r97,%r161,%r95,0f3f800000; .loc 1 134 0 setp.lt.s32 %r162,%r88,0; @ %r162 bra $L8; div.rn.f32 %r163,%r96,%r97; add.f32 %r123,%r163,0f3f58560b; bra $L1; $L8: div.rn.f32 %r164,%r96,%r97; mov.f32 %r165,0fbf58560b; sub.f32 %r123,%r165,%r164; bra $L1; $L7: .loc 1 136 0 setp.le.s32 %r166,%r89,1086324735; @ %r166 bra $L9; .loc 1 137 0 setp.ge.s32 %r167,%r88,0; selp.f32 %r123,0f3f800000,0fbf800000,%r167; bra $L1; $L9: .loc 1 139 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r124; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r169,[%value_in]; } .loc 1 140 0 mul.f32 %r170,%r169,%r169; mov.f32 %r171,0f3f800000; div.rn.f32 %r91,%r171,%r170; .loc 1 141 0 setp.gt.s32 %r172,%r89,1077336941; @ %r172 bra $L10; .loc 1 143 0 fma.rn.f32 %r173,%r91,0fc11d077e,0fc2a2932b; fma.rn.f32 %r174,%r173,%r91,0fc3389ae7; .loc 1 142 0 fma.rn.f32 %r175,%r174,%r91,0fc322658c; fma.rn.f32 %r176,%r175,%r91,0fc2798057; fma.rn.f32 %r177,%r176,%r91,0fc128f022; fma.rn.f32 %r178,%r177,%r91,0fbf31a0b7; fma.rn.f32 %r86,%r178,%r91,0fbc21a093; .loc 1 145 0 fma.rn.f32 %r179,%r91,0fbd777f97,0f40d23f7c; fma.rn.f32 %r180,%r179,%r91,0f42d9451f; fma.rn.f32 %r181,%r180,%r91,0f43d6810b; .loc 1 144 0 fma.rn.f32 %r182,%r181,%r91,0f442158c9; fma.rn.f32 %r183,%r182,%r91,0f43d9486f; fma.rn.f32 %r184,%r183,%r91,0f4309a863; fma.rn.f32 %r185,%r184,%r91,0f419d35ce; fma.rn.f32 %r87,%r185,%r91,0f3f800000; bra $L11; $L10: .loc 1 148 0 fma.rn.f32 %r186,%r91,0fc3f1c275,0fc480230b; .loc 1 147 0 fma.rn.f32 %r187,%r186,%r91,0fc41f6441; fma.rn.f32 %r188,%r187,%r91,0fc320a2ea; fma.rn.f32 %r189,%r188,%r91,0fc18e104b; fma.rn.f32 %r190,%r189,%r91,0fbf4c9dd4; fma.rn.f32 %r86,%r190,%r91,0fbc21a092; .loc 1 150 0 fma.rn.f32 %r191,%r91,0fc1b38712,0f43ed43a7; fma.rn.f32 %r192,%r191,%r91,0f451f90ce; .loc 1 149 0 fma.rn.f32 %r193,%r192,%r91,0f4547fdbb; fma.rn.f32 %r194,%r193,%r91,0f44c01759; fma.rn.f32 %r195,%r194,%r91,0f43a2e571; fma.rn.f32 %r196,%r195,%r91,0f41f2b459; fma.rn.f32 %r87,%r196,%r91,0f3f800000; $L11: .loc 1 153 0 mov.b32 %r198,%r169; and.b32 %r197,%r198,-4096; mov.b32 %r92,%r197; .loc 1 154 0 neg.f32 %r200,%r92; fma.rn.f32 %r201,%r200,%r92,0fbf100000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r201; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r202,[%value_in]; } sub.f32 %r204,%r92,%r169; div.rn.f32 %r205,%r86,%r87; add.f32 %r206,%r169,%r92; fma.rn.f32 %r207,%r204,%r206,%r205; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r207; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r208,[%value_in]; } mul.f32 %r93,%r202,%r208; .loc 1 155 0 setp.lt.s32 %r209,%r88,0; @ %r209 bra $L12; div.rn.f32 %r210,%r93,%r169; mov.f32 %r211,0f3f800000; sub.f32 %r123,%r211,%r210; bra $L1; $L12: div.rn.f32 %r212,%r93,%r169; mov.f32 %r213,0f3f800000; sub.f32 %r123,%r212,%r213; $L1: .loc 1 156 0 mov.f32 %value,%r123; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: erfcf .visible .func (.param .f32 %value_out) erfcf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r87; .reg .f32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r101; .reg .f32 %r116; .reg .f32 %r127; .reg .f32 %r128; .reg .pred %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .pred %r135; .reg .pred %r136; .reg .f32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .pred %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r152; .reg .f32 %r153; .reg .pred %r155; .reg .f32 %r157; .reg .f32 %r158; .reg .f32 %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .f32 %r162; .reg .f32 %r163; .reg .f32 %r164; .reg .f32 %r165; .reg .f32 %r166; .reg .f32 %r167; .reg .f32 %r168; .reg .pred %r169; .reg .f32 %r170; .reg .f32 %r171; .reg .f32 %r172; .reg .f32 %r173; .reg .pred %r174; .reg .f32 %r176; .reg .f32 %r177; .reg .f32 %r178; .reg .pred %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r182; .reg .f32 %r183; .reg .f32 %r184; .reg .f32 %r185; .reg .f32 %r186; .reg .f32 %r187; .reg .f32 %r188; .reg .f32 %r189; .reg .f32 %r190; .reg .f32 %r191; .reg .f32 %r192; .reg .u32 %r194; .reg .u32 %r196; .reg .u32 %r197; .reg .u16 %r199; .reg .u16 %r200; .reg .u16 %r201; .reg .u32 %r202; .reg .u16 %r203; .reg .pred %r204; .reg .f32 %r205; .reg .f32 %r206; .reg .f32 %r207; .reg .f32 %r208; .reg .f32 %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r212; .reg .f32 %r213; .reg .f32 %r214; .reg .f32 %r215; .reg .u32 %r216; .reg .u32 %r217; .reg .f32 %r219; .reg .f32 %r220; .reg .f32 %r221; .reg .f32 %r223; .reg .f32 %r224; .reg .f32 %r225; .reg .f32 %r226; .reg .f32 %r227; .reg .pred %r228; .reg .f32 %r229; .reg .f32 %r230; .reg .pred %r231; mov.f32 %r128,%ar0; .loc 1 167 0 mov.b32 %r89,%r128; .loc 1 168 0 and.b32 %r90,%r89,2147483647; .loc 1 169 0 setp.le.s32 %r129,%r90,2139095039; @ %r129 bra $L15; .loc 1 171 0 shr.u32 %r130,%r89,31; add.u32 %r131,%r130,%r130; cvt.rn.f32.s32 %r132,%r131; mov.f32 %r134,0f3f800000; div.rn.f32 %r133,%r134,%r128; add.f32 %r127,%r132,%r133; bra $L14; $L15: .loc 1 174 0 setp.gt.s32 %r135,%r90,1062731775; @ %r135 bra $L17; .loc 1 175 0 setp.gt.s32 %r136,%r90,595591167; @ %r136 bra $L18; .loc 1 176 0 mov.f32 %r137,0f3f800000; sub.f32 %r127,%r137,%r128; bra $L14; $L18: .loc 1 177 0 mul.f32 %r101,%r128,%r128; .loc 1 178 0 fma.rn.f32 %r138,%r101,0fb7c756b1,0fbbbd1489; fma.rn.f32 %r139,%r138,%r101,0fbce9528f; fma.rn.f32 %r140,%r139,%r101,0fbea66beb; fma.rn.f32 %r141,%r140,%r101,0f3e0375d4; .loc 1 179 0 fma.rn.f32 %r142,%r101,0fb684e21a,0f390aee49; fma.rn.f32 %r143,%r142,%r101,0f3ba68116; fma.rn.f32 %r144,%r143,%r101,0f3d852a63; fma.rn.f32 %r145,%r144,%r101,0f3ecbbbce; fma.rn.f32 %r146,%r145,%r101,0f3f800000; .loc 1 180 0 div.rn.f32 %r147,%r141,%r146; mul.f32 %r116,%r147,%r128; .loc 1 181 0 setp.gt.s32 %r148,%r89,1048575999; @ %r148 bra $L19; .loc 1 182 0 add.f32 %r149,%r128,%r116; mov.f32 %r150,0f3f800000; sub.f32 %r127,%r150,%r149; bra $L14; $L19: .loc 1 185 0 mov.f32 %r152,0f3f000000; sub.f32 %r151,%r128,%r152; add.f32 %r153,%r151,%r116; .loc 1 186 0 sub.f32 %r127,%r152,%r153; bra $L14; $L17: .loc 1 189 0 setp.gt.s32 %r155,%r90,1067450367; @ %r155 bra $L20; .loc 1 190 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r128; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r157,[%value_in]; } mov.f32 %r158,0f3f800000; sub.f32 %r97,%r157,%r158; .loc 1 191 0 fma.rn.f32 %r159,%r97,0fbb0df9c0,0f3d1151b3; fma.rn.f32 %r160,%r159,%r97,0fbde31cc2; fma.rn.f32 %r161,%r160,%r97,0f3ea2fe54; fma.rn.f32 %r162,%r161,%r97,0fbebe9208; fma.rn.f32 %r163,%r162,%r97,0f3ed46805; fma.rn.f32 %r98,%r163,%r97,0fbb1acdc6; .loc 1 192 0 fma.rn.f32 %r164,%r97,0f3c445aa3,0f3c5f6e13; fma.rn.f32 %r165,%r164,%r97,0f3e013307; fma.rn.f32 %r166,%r165,%r97,0f3d931ae7; fma.rn.f32 %r167,%r166,%r97,0f3f0a5785; fma.rn.f32 %r168,%r167,%r97,0f3dd9f331; fma.rn.f32 %r99,%r168,%r97,0f3f800000; .loc 1 193 0 setp.lt.s32 %r169,%r89,0; @ %r169 bra $L21; .loc 1 194 0 div.rn.f32 %r170,%r98,%r99; mov.f32 %r171,0f3e1ea7d4; sub.f32 %r127,%r171,%r170; bra $L14; $L21: .loc 1 196 0 div.rn.f32 %r172,%r98,%r99; add.f32 %r173,%r172,0f3f58560b; add.f32 %r127,%r173,0f3f800000; bra $L14; $L20: .loc 1 199 0 setp.gt.s32 %r174,%r90,1105199103; @ %r174 bra $L22; .loc 1 200 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r128; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r176,[%value_in]; } .loc 1 201 0 mul.f32 %r177,%r176,%r176; mov.f32 %r178,0f3f800000; div.rn.f32 %r94,%r178,%r177; .loc 1 202 0 setp.gt.s32 %r179,%r90,1077336940; @ %r179 bra $L23; .loc 1 204 0 fma.rn.f32 %r180,%r94,0fc11d077e,0fc2a2932b; fma.rn.f32 %r181,%r180,%r94,0fc3389ae7; .loc 1 203 0 fma.rn.f32 %r182,%r181,%r94,0fc322658c; fma.rn.f32 %r183,%r182,%r94,0fc2798057; fma.rn.f32 %r184,%r183,%r94,0fc128f022; fma.rn.f32 %r185,%r184,%r94,0fbf31a0b7; fma.rn.f32 %r87,%r185,%r94,0fbc21a093; .loc 1 206 0 fma.rn.f32 %r186,%r94,0fbd777f97,0f40d23f7c; fma.rn.f32 %r187,%r186,%r94,0f42d9451f; fma.rn.f32 %r188,%r187,%r94,0f43d6810b; .loc 1 205 0 fma.rn.f32 %r189,%r188,%r94,0f442158c9; fma.rn.f32 %r190,%r189,%r94,0f43d9486f; fma.rn.f32 %r191,%r190,%r94,0f4309a863; fma.rn.f32 %r192,%r191,%r94,0f419d35ce; fma.rn.f32 %r88,%r192,%r94,0f3f800000; bra $L24; $L23: .loc 1 208 0 shr.u32 %r194,%r89,31; set.u32.gt.s32 %r196,%r90,1086324735; neg.s32 %r197,%r196; cvt.u16.u32 %r200,%r194; cvt.u16.u32 %r201,%r197; and.b16 %r199,%r200,%r201; cvt.u32.u16 %r202,%r199; cvt.u16.u8 %r203,%r202; setp.ne.u16 %r204,%r203,0; @ %r204 bra $L25; .loc 1 210 0 fma.rn.f32 %r205,%r94,0fc3f1c275,0fc480230b; .loc 1 209 0 fma.rn.f32 %r206,%r205,%r94,0fc41f6441; fma.rn.f32 %r207,%r206,%r94,0fc320a2ea; fma.rn.f32 %r208,%r207,%r94,0fc18e104b; fma.rn.f32 %r209,%r208,%r94,0fbf4c9dd4; fma.rn.f32 %r87,%r209,%r94,0fbc21a092; .loc 1 212 0 fma.rn.f32 %r210,%r94,0fc1b38712,0f43ed43a7; fma.rn.f32 %r211,%r210,%r94,0f451f90ce; .loc 1 211 0 fma.rn.f32 %r212,%r211,%r94,0f4547fdbb; fma.rn.f32 %r213,%r212,%r94,0f44c01759; fma.rn.f32 %r214,%r213,%r94,0f43a2e571; fma.rn.f32 %r215,%r214,%r94,0f41f2b459; fma.rn.f32 %r88,%r215,%r94,0f3f800000; $L24: .loc 1 215 0 mov.b32 %r217,%r176; and.b32 %r216,%r217,-4096; mov.b32 %r95,%r216; .loc 1 216 0 neg.f32 %r219,%r95; fma.rn.f32 %r220,%r219,%r95,0fbf100000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r220; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r221,[%value_in]; } .loc 1 217 0 sub.f32 %r223,%r95,%r176; div.rn.f32 %r224,%r87,%r88; add.f32 %r225,%r176,%r95; fma.rn.f32 %r226,%r223,%r225,%r224; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r226; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r227,[%value_in]; } .loc 1 216 0 mul.f32 %r96,%r221,%r227; .loc 1 218 0 setp.le.s32 %r228,%r89,0; @ %r228 bra $L26; div.rn.f32 %r127,%r96,%r176; bra $L14; $L26: div.rn.f32 %r229,%r96,%r176; mov.f32 %r230,0f40000000; sub.f32 %r127,%r230,%r229; bra $L14; $L22: .loc 1 220 0 setp.gt.s32 %r231,%r89,0; @ %r231 bra $L27; $L25: mov.f32 %r127,0f40000000; bra $L14; $L27: mov.f32 %r127,0f00000000; $L14: .loc 1 222 0 mov.f32 %value,%r127; st.param.f32 [%value_out],%value; ret; } /889 0 0 0 644 925 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp10f .visible .func (.param .f32 %value_out) exp10f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_exp10.c" // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp10f .visible .func (.param .f32 %value_out) exp10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r23,%ar0; .loc 1 32 0 mov.f32 %r24,0f41200000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r23; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 33 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } /907 0 0 0 644 6362 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expm1f .visible .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_expm1.c" // BEGIN GLOBAL FUNCTION DEF: expm1f .visible .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r27; .reg .f32 %r39; .reg .u32 %r47; .reg .u32 %r51; .reg .u32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .u32 %r59; .reg .f32 %r60; .reg .u32 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .f32 %r65; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r76; .reg .u32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r101; .reg .u32 %r102; .reg .u32 %r104; .reg .u32 %r105; .reg .u16 %r107; .reg .u16 %r108; .reg .u16 %r109; .reg .u32 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .pred %r119; .reg .f32 %r120; .reg .pred %r121; .reg .f32 %r122; .reg .f32 %r124; .reg .pred %r125; .reg .f32 %r126; .reg .f32 %r127; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .f32 %r135; .reg .pred %r136; .reg .f32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .pred %r140; .reg .f32 %r141; .reg .pred %r142; .reg .pred %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .u32 %r147; .reg .pred %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .u32 %r152; .reg .f32 %r153; .reg .pred %r155; .reg .u32 %r156; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .f32 %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .u32 %r165; .reg .u32 %r166; .reg .f32 %r167; .reg .f32 %r168; .reg .f32 %r169; .reg .u32 %r170; mov.f32 %r95,%ar0; .loc 1 51 0 mov.b32 %r63,%r95; .loc 1 54 0 and.b32 %r61,%r63,2147483647; .loc 1 57 0 setp.le.u32 %r96,%r61,1100331075; @ %r96 bra $L2; .loc 1 58 0 setp.le.u32 %r97,%r61,2139095040; @ %r97 bra $L3; .loc 1 59 0 add.f32 %r94,%r95,%r95; bra $L1; $L3: .loc 1 60 0 setp.ne.u32 %r98,%r61,2139095040; @ %r98 bra $L5; .loc 1 61 0 setp.lt.s32 %r99,%r63,0; selp.f32 %r94,0fbf800000,%r95,%r99; bra $L1; $L5: .loc 1 62 0 not.b32 %r101,%r63; shr.u32 %r102,%r101,31; set.u32.gt.u32 %r104,%r61,1118925335; neg.s32 %r105,%r104; cvt.u16.u32 %r108,%r102; cvt.u16.u32 %r109,%r105; and.b16 %r107,%r108,%r109; cvt.u32.u16 %r110,%r107; cvt.u16.u8 %r111,%r110; setp.eq.u16 %r112,%r111,0; @ %r112 bra $L6; .loc 1 63 0 mov.f32 %r113,0f7149f2ca; mul.f32 %r94,%r113,0f7149f2ca; bra $L1; $L6: .loc 1 64 0 setp.ge.s32 %r114,%r63,0; @ %r114 bra $L7; .loc 1 65 0 add.f32 %r115,%r95,0f0da24260; setp.lt.f32 %r116,%r115,0f00000000; @ ! %r116 bra $L7; bra $L21; $L2: .loc 1 71 0 setp.le.u32 %r117,%r61,1051816472; @ %r117 bra $L8; .loc 1 72 0 setp.gt.u32 %r118,%r61,1065686417; @ %r118 bra $L7; .loc 1 73 0 setp.lt.s32 %r119,%r63,0; @ %r119 bra $L9; .loc 1 74 0 mov.f32 %r120,0f3f317180; sub.f32 %r56,%r95,%r120; mov.u32 %r59,1; mov.f32 %r57,0f3717f7d1; bra $L10; $L9: .loc 1 76 0 add.f32 %r56,%r95,0f3f317180; mov.u32 %r59,-1; mov.f32 %r57,0fb717f7d1; bra $L10; $L7: .loc 1 78 0 mul.f32 %r27,%r95,0f3fb8aa3b; setp.lt.s32 %r121,%r63,0; selp.f32 %r60,0fbf000000,0f3f000000,%r121; add.f32 %r122,%r27,%r60; cvt.rzi.s32.f32 %r59,%r122; .loc 1 79 0 cvt.rn.f32.s32 %r65,%r59; .loc 1 80 0 fma.rn.f32 %r56,%r65,0fbf317180,%r95; .loc 1 81 0 mul.f32 %r57,%r65,0f3717f7d1; $L10: .loc 1 83 0 sub.f32 %r95,%r56,%r57; .loc 1 84 0 sub.f32 %r124,%r56,%r95; sub.f32 %r58,%r124,%r57; bra $L12; $L8: .loc 1 86 0 setp.gt.u32 %r125,%r61,855638015; @ %r125 bra $L23; .loc 1 87 0 add.f32 %r62,%r95,0f7149f2ca; .loc 1 88 0 sub.f32 %r126,%r62,%r62; sub.f32 %r94,%r95,%r126; bra $L1; $L23: .loc 1 90 0 mov.u32 %r59,0; $L12: .loc 1 93 0 mul.f32 %r68,%r95,0f3f000000; .loc 1 94 0 mul.f32 %r69,%r95,%r68; .loc 1 95 0 fma.rn.f32 %r127,%r69,0fb457edbb,0f36867e54; fma.rn.f32 %r128,%r127,%r69,0fb8a670cd; fma.rn.f32 %r129,%r128,%r69,0f3ad00d01; fma.rn.f32 %r130,%r129,%r69,0fbd088889; fma.rn.f32 %r70,%r130,%r69,0f3f800000; .loc 1 96 0 neg.f32 %r131,%r68; fma.rn.f32 %r71,%r131,%r70,0f40400000; .loc 1 97 0 sub.f32 %r132,%r70,%r71; neg.f32 %r133,%r95; fma.rn.f32 %r134,%r133,%r71,0f40c00000; div.rn.f32 %r135,%r132,%r134; mul.f32 %r72,%r135,%r69; .loc 1 98 0 setp.ne.u32 %r136,%r59,0; @ %r136 bra $L13; neg.f32 %r137,%r69; fma.rn.f32 %r138,%r95,%r72,%r137; sub.f32 %r94,%r95,%r138; bra $L1; $L13: .loc 1 100 0 sub.f32 %r39,%r72,%r58; neg.f32 %r139,%r58; fma.rn.f32 %r73,%r39,%r95,%r139; .loc 1 101 0 sub.f32 %r74,%r73,%r69; .loc 1 102 0 setp.ne.u32 %r140,%r59,-1; @ %r140 bra $L14; sub.f32 %r141,%r95,%r74; fma.rn.f32 %r94,%r141,0f3f000000,0fbf000000; bra $L1; $L14: .loc 1 103 0 setp.ne.u32 %r142,%r59,1; @ %r142 bra $L15; .loc 1 104 0 setp.lt.f32 %r143,%r95,0fbe800000; @ ! %r143 bra $L25; add.f32 %r144,%r95,0f3f000000; sub.f32 %r145,%r74,%r144; mul.f32 %r94,%r145,0fc0000000; bra $L1; $L25: .loc 1 105 0 sub.f32 %r146,%r95,%r74; fma.rn.f32 %r94,%r146,0f40000000,0f3f800000; bra $L1; $L15: shl.b32 %r93,%r59,23; .loc 1 107 0 add.u32 %r147,%r59,1; setp.le.u32 %r148,%r147,57; @ %r148 bra $L18; .loc 1 109 0 sub.f32 %r149,%r74,%r95; mov.f32 %r151,0f3f800000; sub.f32 %r150,%r151,%r149; .loc 1 111 0 mov.b32 %r152,%r150; add.u32 %r47,%r93,%r152; .loc 1 112 0 mov.b32 %r153,%r47; sub.f32 %r94,%r153,%r151; bra $L1; $L18: .loc 1 115 0 setp.gt.s32 %r155,%r59,22; @ %r155 bra $L19; .loc 1 117 0 mov.u32 %r157,16777216; shr.s32 %r156,%r157,%r59; mov.u32 %r159,1065353216; sub.u32 %r158,%r159,%r156; .loc 1 118 0 sub.f32 %r160,%r74,%r95; mov.b32 %r162,%r158; sub.f32 %r161,%r162,%r160; .loc 1 120 0 mov.b32 %r163,%r161; add.u32 %r51,%r93,%r163; mov.b32 %r94,%r51; bra $L1; $L19: .loc 1 123 0 mov.u32 %r165,127; sub.u32 %r164,%r165,%r59; shl.b32 %r166,%r164,23; .loc 1 124 0 mov.b32 %r168,%r166; add.f32 %r167,%r74,%r168; sub.f32 %r76,%r95,%r167; .loc 1 125 0 add.f32 %r169,%r76,0f3f800000; .loc 1 127 0 mov.b32 %r170,%r169; add.u32 %r55,%r93,%r170; mov.b32 %r94,%r55; bra $L1; $L21: .loc 1 61 0 mov.f32 %r94,0fbf800000; $L1: .loc 1 131 0 mov.f32 %value,%r94; st.param.f32 [%value_out],%value; ret; } lib_a-sf_fabs.o/0 0 0 644 619 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fabsf .visible .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_fabs.c" // BEGIN GLOBAL FUNCTION DEF: fabsf .visible .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f32 %r25; .reg .u32 %r26; mov.f32 %r25,%ar0; .loc 1 31 0 mov.b32 %r26,%r25; and.b32 %r22,%r26,2147483647; .loc 1 32 0 mov.b32 %value,%r22; .loc 1 33 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_fdim.o/0 0 0 644 1578 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fdimf .visible .func (.param .f32 %value_out) fdimf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_fdim.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fdimf .visible .func (.param .f32 %value_out) fdimf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .f32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 17 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } .loc 1 18 0 setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 19 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 20 0 setp.eq.u32 %r33,%r28,1; @ %r33 bra $L5; .loc 1 23 0 setp.gt.f32 %r34,%r25,%r26; @ ! %r34 bra $L11; sub.f32 %r25,%r25,%r26; bra $L2; $L4: .loc 1 19 0 mov.f32 %r25,%r26; bra $L2; $L5: .loc 1 21 0 mov.f32 %r25,0f7f800000; bra $L2; $L11: .loc 1 23 0 mov.f32 %r25,0f00000000; $L2: .loc 1 24 0 mov.f32 %value,%r25; st.param.f32 [%value_out],%value; ret; } /925 0 0 0 644 696 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_finite.c" // BEGIN GLOBAL FUNCTION DEF: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.le.s32 %r31,%r29,2139095039; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /944 0 0 0 644 2156 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: floorf .visible .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_floor.c" // BEGIN GLOBAL FUNCTION DEF: floorf .visible .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .pred %r56; mov.f32 %r38,%ar0; .loc 1 42 0 mov.b32 %r22,%r38; .loc 1 43 0 and.b32 %r34,%r22,2147483647; .loc 1 44 0 shr.u32 %r39,%r34,23; add.u32 %r35,%r39,-127; .loc 1 45 0 setp.gt.s32 %r40,%r35,22; @ %r40 bra $L2; .loc 1 42 0 mov.u32 %r33,%r22; .loc 1 46 0 setp.ge.s32 %r41,%r35,0; @ %r41 bra $L3; .loc 1 47 0 add.f32 %r42,%r38,0f7149f2ca; setp.gt.f32 %r43,%r42,0f00000000; @ ! %r43 bra $L17; .loc 1 48 0 setp.ge.s32 %r44,%r22,0; @ %r44 bra $L10; .loc 1 49 0 setp.eq.u32 %r45,%r34,0; selp.f32 %r37,%r38,0fbf800000,%r45; bra $L1; $L3: .loc 1 53 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r35; .loc 1 54 0 and.b32 %r47,%r22,%r36; setp.eq.u32 %r48,%r47,0; @ %r48 bra $L12; .loc 1 55 0 add.f32 %r49,%r38,0f7149f2ca; setp.gt.f32 %r50,%r49,0f00000000; @ ! %r50 bra $L18; .loc 1 56 0 setp.ge.s32 %r51,%r33,0; @ %r51 bra $L8; mov.u32 %r53,8388608; shr.s32 %r52,%r53,%r35; add.u32 %r33,%r33,%r52; $L8: .loc 1 57 0 not.b32 %r54,%r36; and.b32 %r55,%r54,%r33; mov.b32 %r37,%r55; bra $L1; $L2: .loc 1 61 0 setp.le.u32 %r56,%r34,2139095039; @ %r56 bra $L14; add.f32 %r37,%r38,%r38; bra $L1; $L17: mov.f32 %r37,%r38; bra $L1; $L10: mov.f32 %r37,0f00000000; bra $L1; $L18: mov.f32 %r37,%r38; .loc 1 65 0 bra $L1; $L12: .loc 1 54 0 mov.f32 %r37,%r38; bra $L1; $L14: mov.f32 %r37,%r38; $L1: .loc 1 66 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_fma.o/ 0 0 0 644 939 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmaf .visible .func (.param .f32 %value_out) fmaf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../newlib/libm/common/sf_fma.c" // BEGIN GLOBAL FUNCTION DEF: fmaf .visible .func (.param .f32 %value_out) fmaf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r27; .reg .f32 %r28; .reg .f32 %r29; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r34; mov.f32 %r27,%ar0; mov.f32 %r28,%ar1; mov.f32 %r29,%ar2; .loc 1 25 0 cvt.f64.f32 %r31,%r27; cvt.f64.f32 %r32,%r29; cvt.f64.f32 %r33,%r28; fma.rn.f64 %r34,%r31,%r33,%r32; cvt.rn.f32.f64 %value,%r34; .loc 1 26 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_fmax.o/0 0 0 644 1439 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmaxf .visible .func (.param .f32 %value_out) fmaxf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_fmax.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fmaxf .visible .func (.param .f32 %value_out) fmaxf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 17 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 19 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 22 0 setp.gt.f32 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f32 %r24,%r26; bra $L1; $L4: .loc 1 20 0 mov.f32 %r24,%r25; bra $L1; $L5: mov.f32 %r24,%r25; $L1: .loc 1 23 0 mov.f32 %value,%r24; st.param.f32 [%value_out],%value; ret; } lib_a-sf_fmin.o/0 0 0 644 1439 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fminf .visible .func (.param .f32 %value_out) fminf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_fmin.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fminf .visible .func (.param .f32 %value_out) fminf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 17 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 19 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 22 0 setp.lt.f32 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f32 %r24,%r26; bra $L1; $L4: .loc 1 20 0 mov.f32 %r24,%r25; bra $L1; $L5: mov.f32 %r24,%r25; $L1: .loc 1 23 0 mov.f32 %value,%r24; st.param.f32 [%value_out],%value; ret; } /962 0 0 0 644 1173 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r26; .reg .u32 %r27; .reg .f32 %r28; .reg .u32 %r29; .reg .pred %r30; .reg .u32 %r31; .reg .pred %r32; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; mov.f32 %r28,%ar0; .loc 1 16 0 mov.b32 %r29,%r28; and.b32 %r26,%r29,2147483647; setp.eq.u32 %r30,%r26,0; @ %r30 bra $L3; .loc 1 18 0 add.u32 %r31,%r26,-8388608; setp.le.u32 %r32,%r31,2130706431; @ %r32 bra $L4; .loc 1 21 0 add.u32 %r33,%r26,-1; setp.le.u32 %r34,%r33,8388606; @ %r34 bra $L5; .loc 1 24 0 set.u32.eq.u32 %r36,%r26,2139095040; neg.s32 %r27,%r36; bra $L1; $L3: .loc 1 17 0 mov.u32 %r27,2; bra $L1; $L4: .loc 1 20 0 mov.u32 %r27,4; bra $L1; $L5: .loc 1 23 0 mov.u32 %r27,3; $L1: .loc 1 28 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } /985 0 0 0 644 1883 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/sf_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u16 %r47; .reg .u16 %r48; .reg .u16 %r49; .reg .u32 %r50; .reg .u16 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r31,%r38; .loc 1 34 0 and.b32 %r32,%r31,2147483647; .loc 1 35 0 mov.u32 %r40,0; st.u32 [%r39],%r40; .loc 1 36 0 set.u32.gt.s32 %r42,%r32,2139095039; neg.s32 %r43,%r42; set.u32.eq.u32 %r45,%r32,0; neg.s32 %r46,%r45; cvt.u16.u32 %r48,%r43; cvt.u16.u32 %r49,%r46; or.b16 %r47,%r48,%r49; cvt.u32.u16 %r50,%r47; cvt.u16.u8 %r51,%r50; setp.ne.u16 %r52,%r51,0; @ %r52 bra $L4; .loc 1 37 0 setp.gt.s32 %r53,%r32,8388607; @ %r53 bra $L5; .loc 1 38 0 mul.f32 %r54,%r38,0f4c000000; .loc 1 39 0 mov.b32 %r31,%r54; .loc 1 40 0 and.b32 %r32,%r31,2147483647; mov.u32 %r36,-25; bra $L3; $L5: mov.u32 %r36,%r40; $L3: .loc 1 43 0 shr.s32 %r55,%r32,23; add.u32 %r56,%r55,-126; add.u32 %r57,%r56,%r36; st.u32 [%r39],%r57; .loc 1 44 0 and.b32 %r58,%r31,-2139095041; or.b32 %r59,%r58,1056964608; .loc 1 45 0 mov.b32 %r37,%r59; .loc 1 46 0 bra $L1; $L4: .loc 1 36 0 mov.f32 %r37,%r38; $L1: .loc 1 47 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /1003 0 0 0 644 1240 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ilogbf .visible .func (.param .u32 %value_out) ilogbf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_ilogb.c" // BEGIN GLOBAL FUNCTION DEF: ilogbf .visible .func (.param .u32 %value_out) ilogbf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r26; .reg .u32 %r27; .reg .u32 %r29; .reg .u32 %r30; .reg .f32 %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r35; .reg .pred %r36; .reg .u32 %r37; mov.f32 %r31,%ar0; .loc 1 28 0 mov.b32 %r26,%r31; .loc 1 29 0 and.b32 %r27,%r26,2147483647; .loc 1 30 0 setp.eq.u32 %r32,%r27,0; @ %r32 bra $L5; .loc 1 32 0 setp.gt.s32 %r33,%r27,8388607; @ %r33 bra $L3; .loc 1 33 0 shl.b32 %r29,%r27,8; mov.u32 %r30,-126; $L4: add.u32 %r30,%r30,-1; add.u32 %r29,%r29,%r29; setp.gt.s32 %r35,%r29,0; @ %r35 bra $L4; bra $L1; $L3: .loc 1 39 0 setp.gt.s32 %r36,%r27,2139095039; @ %r36 bra $L6; .loc 1 40 0 shr.s32 %r37,%r27,23; add.u32 %r30,%r37,-127; bra $L1; $L5: .loc 1 31 0 mov.u32 %r30,-2147483647; bra $L1; $L6: .loc 1 39 0 mov.u32 %r30,2147483647; $L1: .loc 1 41 0 mov.u32 %value,%r30; st.param.u32 [%value_out],%value; ret; } /1021 0 0 0 644 430 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: infinityf .visible .func (.param .f32 %value_out) infinityf; .file 1 "../../../../../newlib/libm/common/sf_infinity.c" // BEGIN GLOBAL FUNCTION DEF: infinityf .visible .func (.param .f32 %value_out) infinityf { .reg .f32 %value; .loc 1 13 0 mov.f32 %value,0f7f800000; .loc 1 14 0 st.param.f32 [%value_out],%value; ret; } /1042 0 0 0 644 691 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 21 0 mov.b32 %r23,%r27; .loc 1 22 0 and.b32 %r29,%r23,2147483647; .loc 1 23 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 24 0 st.param.u32 [%value_out],%value; ret; } /1060 0 0 0 644 700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isinff.c" // BEGIN GLOBAL FUNCTION DEF: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 13 0 mov.b32 %r23,%r27; .loc 1 14 0 and.b32 %r29,%r23,2147483647; .loc 1 15 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 16 0 st.param.u32 [%value_out],%value; ret; } /1079 0 0 0 644 691 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /1097 0 0 0 644 700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isnanf.c" // BEGIN GLOBAL FUNCTION DEF: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 23 0 mov.b32 %r23,%r27; .loc 1 24 0 and.b32 %r29,%r23,2147483647; .loc 1 25 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 26 0 st.param.u32 [%value_out],%value; ret; } /1116 0 0 0 644 2580 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/math/sf_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f32 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f32 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f32 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 26 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f32 %r37,%r32,0f00000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 27 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } mov.f32 %r32,%r50; .loc 1 28 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f32 %r54,%r32,0f00000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 30 0 mov.f32 %value,%r32; st.param.f32 [%value_out],%value; ret; } /1134 0 0 0 644 2439 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llrintf .visible .func (.param .u64 %value_out) llrintf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_llrint.c" // BEGIN VAR DEF: TWO23 .const .align 4 .u32 TWO23[2] = {1258291200,3405774848 }; // BEGIN GLOBAL FUNCTION DEF: llrintf .visible .func (.param .u64 %value_out) llrintf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .u32 %r40; .reg .u32 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .f32 %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; mov.f32 %r48,%ar0; .loc 1 53 0 mov.b32 %r45,%r48; .loc 1 59 0 shr.u32 %r49,%r45,23; and.b32 %r50,%r49,255; add.u32 %r40,%r50,-127; .loc 1 61 0 setp.gt.s32 %r51,%r40,62; @ %r51 bra $L2; .loc 1 63 0 setp.ge.s32 %r52,%r40,-1; @ %r52 bra $L3; $L7: .loc 1 64 0 mov.u64 %r47,0; bra $L1; $L3: .loc 1 56 0 shr.u32 %r22,%r45,31; .loc 1 65 0 setp.le.s32 %r53,%r40,22; @ %r53 bra $L5; .loc 1 66 0 and.b32 %r54,%r45,8388607; or.b32 %r55,%r54,8388608; cvt.u64.u32 %r56,%r55; add.u32 %r57,%r50,-150; shl.b64 %r47,%r56,%r57; bra $L6; $L5: .loc 1 69 0 cvta.const.u64 %r58,TWO23; cvt.s64.s32 %r59,%r22; shl.b64 %r60,%r59,2; add.u64 %r61,%r58,%r60; ld.f32 %r30,[%r61]; add.f32 %r31,%r30,%r48; st.f32 [%frame],%r31; .loc 1 70 0 ld.f32 %r32,[%frame]; sub.f32 %r62,%r32,%r30; .loc 1 71 0 mov.b32 %r46,%r62; .loc 1 74 0 and.b32 %r63,%r46,2147483647; setp.eq.u32 %r64,%r63,0; @ %r64 bra $L7; .loc 1 77 0 and.b32 %r43,%r46,8388607; .loc 1 78 0 or.b32 %r65,%r43,8388608; .loc 1 76 0 shr.u32 %r66,%r46,23; and.b32 %r67,%r66,255; .loc 1 79 0 mov.u32 %r70,150; sub.u32 %r69,%r70,%r67; shr.u32 %r71,%r65,%r69; cvt.u64.u32 %r47,%r71; bra $L6; $L2: .loc 1 84 0 cvt.rzi.s64.f32 %r47,%r48; bra $L1; $L6: .loc 1 86 0 setp.eq.u32 %r72,%r22,0; @ %r72 bra $L1; neg.s64 %r47,%r47; $L1: .loc 1 87 0 mov.u64 %value,%r47; st.param.u64 [%value_out],%value; ret; } /1153 0 0 0 644 1862 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llroundf .visible .func (.param .u64 %value_out) llroundf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_llround.c" // BEGIN GLOBAL FUNCTION DEF: llroundf .visible .func (.param .u64 %value_out) llroundf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u64 %r40; .reg .f32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r57; mov.f32 %r41,%ar0; .loc 1 23 0 mov.b32 %r36,%r41; .loc 1 24 0 shr.u32 %r42,%r36,23; and.b32 %r43,%r42,255; add.u32 %r35,%r43,-127; .loc 1 25 0 setp.lt.s32 %r44,%r36,0; selp.u32 %r34,-1,1,%r44; .loc 1 29 0 setp.gt.s32 %r45,%r35,62; @ %r45 bra $L3; .loc 1 31 0 setp.ge.s32 %r46,%r35,0; @ %r46 bra $L4; .loc 1 32 0 setp.ne.u32 %r47,%r35,-1; @ %r47 bra $L9; cvt.s64.s32 %r40,%r34; bra $L1; $L4: .loc 1 26 0 and.b32 %r37,%r36,8388607; .loc 1 27 0 or.b32 %r38,%r37,8388608; .loc 1 33 0 setp.le.s32 %r48,%r35,22; @ %r48 bra $L6; .loc 1 34 0 cvt.u64.u32 %r49,%r38; add.u32 %r50,%r43,-150; shl.b64 %r33,%r49,%r50; bra $L7; $L6: .loc 1 37 0 mov.u32 %r52,4194304; shr.s32 %r51,%r52,%r35; add.u32 %r53,%r51,%r38; .loc 1 38 0 mov.u32 %r55,23; sub.u32 %r54,%r55,%r35; shr.u32 %r56,%r53,%r54; cvt.u64.u32 %r33,%r56; bra $L7; $L3: .loc 1 42 0 cvt.rzi.s64.f32 %r40,%r41; bra $L1; $L7: .loc 1 44 0 cvt.s64.s32 %r57,%r34; mul.lo.u64 %r40,%r57,%r33; bra $L1; $L9: .loc 1 32 0 mov.u64 %r40,0; $L1: .loc 1 45 0 mov.u64 %value,%r40; st.param.u64 [%value_out],%value; ret; } /1173 0 0 0 644 5658 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log1pf .visible .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_log1p.c" // BEGIN GLOBAL FUNCTION DEF: log1pf .visible .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r36; .reg .f32 %r48; .reg .f32 %r54; .reg .f32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .f32 %r61; .reg .u32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .f32 %r84; .reg .pred %r85; .reg .f32 %r86; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r91; .reg .u32 %r92; .reg .u16 %r93; .reg .u16 %r94; .reg .u16 %r95; .reg .u32 %r96; .reg .u16 %r97; .reg .pred %r98; .reg .f32 %r99; .reg .u32 %r101; .reg .pred %r102; .reg .f32 %r103; .reg .pred %r104; .reg .u32 %r105; .reg .pred %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .u32 %r111; .reg .pred %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .pred %r118; .reg .pred %r119; .reg .pred %r120; .reg .f32 %r121; .reg .f32 %r123; .reg .pred %r124; .reg .f32 %r125; .reg .f32 %r126; .reg .f32 %r127; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .f32 %r135; .reg .f32 %r136; .reg .pred %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; mov.f32 %r79,%ar0; .loc 1 50 0 mov.b32 %r58,%r79; .loc 1 54 0 setp.le.s32 %r80,%r58,2139095039; @ %r80 bra $L2; add.f32 %r78,%r79,%r79; bra $L1; $L2: .loc 1 55 0 setp.gt.s32 %r81,%r58,1054086102; @ %r81 bra $L4; .loc 1 51 0 and.b32 %r62,%r58,2147483647; .loc 1 56 0 setp.le.s32 %r82,%r62,1065353215; @ %r82 bra $L5; .loc 1 57 0 setp.neu.f32 %r83,%r79,0fbf800000; @ %r83 bra $L6; mov.f32 %r84,0fcc000000; div.rn.f32 %r78,%r84,0f00000000; bra $L1; $L6: .loc 1 58 0 sub.f32 %r22,%r79,%r79; div.rn.f32 %r78,%r22,%r22; bra $L1; $L5: .loc 1 60 0 setp.gt.s32 %r85,%r62,822083583; @ %r85 bra $L7; .loc 1 61 0 add.f32 %r86,%r79,0f4c000000; set.u32.gt.f32 %r88,%r86,0f00000000; neg.s32 %r89,%r88; .loc 1 62 0 set.u32.le.s32 %r91,%r62,612368383; neg.s32 %r92,%r91; cvt.u16.u32 %r94,%r89; cvt.u16.u32 %r95,%r92; and.b16 %r93,%r94,%r95; cvt.u32.u16 %r96,%r93; cvt.u16.u8 %r97,%r96; setp.ne.u16 %r98,%r97,0; @ %r98 bra $L19; .loc 1 65 0 mul.f32 %r99,%r79,%r79; fma.rn.f32 %r78,%r99,0fbf000000,%r79; bra $L1; $L7: .loc 1 67 0 add.u32 %r101,%r58,1097468384; setp.le.u32 %r102,%r101,1097468384; @ %r102 bra $L8; .loc 1 94 0 mul.f32 %r103,%r79,0f3f000000; mul.f32 %r64,%r103,%r79; .loc 1 68 0 mov.u32 %r57,0; bra $L9; $L4: .loc 1 71 0 setp.gt.s32 %r104,%r58,1509949439; @ %r104 bra $L10; $L8: .loc 1 72 0 add.f32 %r63,%r79,0f3f800000; .loc 1 73 0 mov.b32 %r58,%r63; .loc 1 74 0 shr.s32 %r105,%r58,23; add.u32 %r57,%r105,-127; .loc 1 76 0 setp.le.s32 %r106,%r57,0; @ %r106 bra $L11; sub.f32 %r107,%r63,%r79; mov.f32 %r108,0f3f800000; sub.f32 %r61,%r108,%r107; bra $L12; $L11: mov.f32 %r110,0f3f800000; sub.f32 %r109,%r63,%r110; sub.f32 %r61,%r79,%r109; $L12: .loc 1 77 0 div.rn.f32 %r54,%r61,%r63; bra $L13; $L10: .loc 1 81 0 shr.s32 %r111,%r58,23; add.u32 %r57,%r111,-127; .loc 1 82 0 mov.f32 %r54,0f00000000; $L13: .loc 1 84 0 and.b32 %r59,%r58,8388607; .loc 1 85 0 setp.gt.s32 %r112,%r59,3474678; @ %r112 bra $L14; .loc 1 86 0 or.b32 %r113,%r59,1065353216; mov.b32 %r55,%r113; bra $L15; $L14: .loc 1 88 0 add.u32 %r57,%r57,1; .loc 1 89 0 or.b32 %r114,%r59,1056964608; mov.b32 %r55,%r114; .loc 1 90 0 mov.u32 %r115,8388608; sub.u32 %r32,%r115,%r59; shr.s32 %r59,%r32,2; $L15: .loc 1 92 0 mov.f32 %r116,0f3f800000; sub.f32 %r79,%r55,%r116; .loc 1 94 0 mul.f32 %r117,%r79,0f3f000000; mul.f32 %r64,%r117,%r79; .loc 1 95 0 setp.ne.u32 %r118,%r59,0; @ %r118 bra $L9; .loc 1 96 0 setp.neu.f32 %r119,%r79,0f00000000; @ %r119 bra $L16; setp.eq.u32 %r120,%r57,0; @ %r120 bra $L20; .loc 1 97 0 cvt.rn.f32.s32 %r34,%r57; fma.rn.f32 %r121,%r34,0f3717f7d1,%r54; fma.rn.f32 %r78,%r34,0f3f317180,%r121; bra $L1; $L16: .loc 1 98 0 fma.rn.f32 %r123,%r79,0fbf2aaaab,0f3f800000; mul.f32 %r67,%r123,%r64; .loc 1 99 0 setp.ne.u32 %r124,%r57,0; @ %r124 bra $L17; sub.f32 %r78,%r79,%r67; bra $L1; $L17: .loc 1 100 0 cvt.rn.f32.s32 %r36,%r57; fma.rn.f32 %r125,%r36,0f3717f7d1,%r54; sub.f32 %r126,%r67,%r125; sub.f32 %r127,%r126,%r79; neg.f32 %r128,%r127; fma.rn.f32 %r78,%r36,0f3f317180,%r128; bra $L1; $L9: .loc 1 102 0 add.f32 %r129,%r79,0f40000000; div.rn.f32 %r65,%r79,%r129; .loc 1 103 0 mul.f32 %r66,%r65,%r65; .loc 1 104 0 fma.rn.f32 %r130,%r66,0f3e178897,0f3e1cd04f; fma.rn.f32 %r131,%r130,%r66,0f3e3a3325; fma.rn.f32 %r132,%r131,%r66,0f3e638e29; fma.rn.f32 %r133,%r132,%r66,0f3e924925; fma.rn.f32 %r134,%r133,%r66,0f3ecccccd; fma.rn.f32 %r135,%r134,%r66,0f3f2aaaab; fma.rn.f32 %r136,%r135,%r66,%r64; mul.f32 %r77,%r136,%r65; .loc 1 105 0 setp.ne.u32 %r137,%r57,0; @ %r137 bra $L18; sub.f32 %r138,%r64,%r77; sub.f32 %r78,%r79,%r138; bra $L1; $L18: .loc 1 106 0 cvt.rn.f32.s32 %r48,%r57; fma.rn.f32 %r139,%r48,0f3717f7d1,%r54; add.f32 %r140,%r139,%r77; sub.f32 %r141,%r64,%r140; sub.f32 %r142,%r141,%r79; neg.f32 %r143,%r142; fma.rn.f32 %r78,%r48,0f3f317180,%r143; bra $L1; $L19: .loc 1 63 0 mov.f32 %r78,%r79; bra $L1; $L20: .loc 1 96 0 mov.f32 %r78,0f00000000; $L1: .loc 1 107 0 mov.f32 %value,%r78; st.param.f32 [%value_out],%value; ret; } lib_a-sf_log2.o/0 0 0 644 808 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log2f .visible .func (.param .f32 %value_out) log2f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_log2.c" // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log2f .visible .func (.param .f32 %value_out) log2f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r24,%ar0; .loc 1 33 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),logf,(%out_arg1); ld.param.f32 %r26,[%value_in]; } div.rn.f32 %value,%r26,0f3f317218; .loc 1 34 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_logb.o/0 0 0 644 1503 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: logbf .visible .func (.param .f32 %value_out) logbf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_logb.c" // BEGIN GLOBAL FUNCTION DEF: logbf .visible .func (.param .f32 %value_out) logbf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .pred %r34; .reg .f32 %r35; .reg .pred %r36; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .u32 %r41; .reg .u32 %r42; mov.f32 %r33,%ar0; .loc 1 33 0 mov.b32 %r27,%r33; .loc 1 34 0 and.b32 %r28,%r27,2147483647; .loc 1 35 0 setp.ne.u32 %r34,%r28,0; @ %r34 bra $L2; .loc 1 39 0 mov.f32 %r35,0fbf800000; div.rn.f32 %r32,%r35,0f00000000; bra $L1; $L2: .loc 1 41 0 setp.gt.s32 %r36,%r28,8388607; @ %r36 bra $L4; .loc 1 42 0 shl.b32 %r31,%r28,8; mov.u32 %r30,-126; $L5: add.u32 %r30,%r30,-1; add.u32 %r31,%r31,%r31; setp.gt.s32 %r38,%r31,0; @ %r38 bra $L5; .loc 1 43 0 cvt.rn.f32.s32 %r32,%r30; bra $L1; $L4: .loc 1 45 0 setp.eq.u32 %r39,%r28,2139095040; @ %r39 bra $L6; .loc 1 46 0 setp.gt.s32 %r40,%r28,2139095040; @ %r40 bra $L7; .loc 1 47 0 shr.s32 %r41,%r28,23; add.u32 %r42,%r41,-127; cvt.rn.f32.s32 %r32,%r42; bra $L1; $L6: .loc 1 45 0 mov.f32 %r32,0f7f800000; bra $L1; $L7: .loc 1 46 0 mov.f32 %r32,%r33; $L1: .loc 1 48 0 mov.f32 %value,%r32; st.param.f32 [%value_out],%value; ret; } /1191 0 0 0 644 2474 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lrintf .visible .func (.param .u64 %value_out) lrintf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_lrint.c" // BEGIN VAR DEF: TWO23 .const .align 4 .u32 TWO23[2] = {1258291200,3405774848 }; // BEGIN GLOBAL FUNCTION DEF: lrintf .visible .func (.param .u64 %value_out) lrintf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .u32 %r41; .reg .u32 %r44; .reg .u32 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .f32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .f32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .pred %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; mov.f32 %r49,%ar0; .loc 1 53 0 mov.b32 %r46,%r49; .loc 1 59 0 shr.u32 %r50,%r46,23; and.b32 %r51,%r50,255; add.u32 %r41,%r51,-127; .loc 1 61 0 setp.gt.s32 %r52,%r41,62; @ %r52 bra $L2; .loc 1 63 0 setp.ge.s32 %r53,%r41,-1; @ %r53 bra $L3; $L7: .loc 1 64 0 mov.u64 %r48,0; bra $L1; $L3: .loc 1 56 0 shr.u32 %r22,%r46,31; .loc 1 65 0 setp.le.s32 %r54,%r41,22; @ %r54 bra $L5; .loc 1 66 0 and.b32 %r55,%r46,8388607; or.b32 %r56,%r55,8388608; cvt.u64.u32 %r57,%r56; add.u32 %r58,%r51,-150; shl.b64 %r48,%r57,%r58; bra $L6; $L5: .loc 1 69 0 cvta.const.u64 %r59,TWO23; cvt.s64.s32 %r60,%r22; shl.b64 %r61,%r60,2; add.u64 %r62,%r59,%r61; ld.f32 %r30,[%r62]; add.f32 %r31,%r30,%r49; st.f32 [%frame],%r31; .loc 1 70 0 ld.f32 %r32,[%frame]; sub.f32 %r63,%r32,%r30; .loc 1 71 0 mov.b32 %r47,%r63; .loc 1 74 0 cvt.u64.u32 %r64,%r47; and.b64 %r65,%r64,-2147483649; setp.eq.u64 %r66,%r65,0; @ %r66 bra $L7; .loc 1 77 0 and.b32 %r44,%r47,8388607; .loc 1 78 0 or.b32 %r67,%r44,8388608; .loc 1 76 0 shr.u32 %r68,%r47,23; and.b32 %r69,%r68,255; .loc 1 79 0 mov.u32 %r72,150; sub.u32 %r71,%r72,%r69; shr.u32 %r73,%r67,%r71; cvt.u64.u32 %r48,%r73; bra $L6; $L2: .loc 1 84 0 cvt.rzi.s64.f32 %r48,%r49; bra $L1; $L6: .loc 1 86 0 setp.eq.u32 %r74,%r22,0; @ %r74 bra $L1; neg.s64 %r48,%r48; $L1: .loc 1 87 0 mov.u64 %value,%r48; st.param.u64 [%value_out],%value; ret; } /1209 0 0 0 644 1857 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lroundf .visible .func (.param .u64 %value_out) lroundf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_lround.c" // BEGIN GLOBAL FUNCTION DEF: lroundf .visible .func (.param .u64 %value_out) lroundf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u64 %r40; .reg .f32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r57; mov.f32 %r41,%ar0; .loc 1 26 0 mov.b32 %r36,%r41; .loc 1 27 0 shr.u32 %r42,%r36,23; and.b32 %r43,%r42,255; add.u32 %r35,%r43,-127; .loc 1 28 0 setp.lt.s32 %r44,%r36,0; selp.u32 %r34,-1,1,%r44; .loc 1 32 0 setp.gt.s32 %r45,%r35,62; @ %r45 bra $L3; .loc 1 34 0 setp.ge.s32 %r46,%r35,0; @ %r46 bra $L4; .loc 1 35 0 setp.ne.u32 %r47,%r35,-1; @ %r47 bra $L9; cvt.s64.s32 %r40,%r34; bra $L1; $L4: .loc 1 29 0 and.b32 %r37,%r36,8388607; .loc 1 30 0 or.b32 %r38,%r37,8388608; .loc 1 36 0 setp.le.s32 %r48,%r35,22; @ %r48 bra $L6; .loc 1 37 0 cvt.u64.u32 %r49,%r38; add.u32 %r50,%r43,-150; shl.b64 %r33,%r49,%r50; bra $L7; $L6: .loc 1 40 0 mov.u32 %r52,4194304; shr.s32 %r51,%r52,%r35; add.u32 %r53,%r51,%r38; .loc 1 41 0 mov.u32 %r55,23; sub.u32 %r54,%r55,%r35; shr.u32 %r56,%r53,%r54; cvt.u64.u32 %r33,%r56; bra $L7; $L3: .loc 1 45 0 cvt.rzi.s64.f32 %r40,%r41; bra $L1; $L7: .loc 1 47 0 cvt.s64.s32 %r57,%r34; mul.lo.u64 %r40,%r57,%r33; bra $L1; $L9: .loc 1 35 0 mov.u64 %r40,0; $L1: .loc 1 48 0 mov.u64 %value,%r40; st.param.u64 [%value_out],%value; ret; } lib_a-sf_modf.o/0 0 0 644 1773 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_modf.c" // BEGIN GLOBAL FUNCTION DEF: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r31; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .f32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r35,%r38; .loc 1 34 0 shr.s32 %r40,%r35,23; and.b32 %r41,%r40,255; add.u32 %r34,%r41,-127; .loc 1 35 0 setp.gt.s32 %r42,%r34,22; @ %r42 bra $L2; .loc 1 36 0 setp.ge.s32 %r43,%r34,0; @ %r43 bra $L3; .loc 1 37 0 and.b32 %r44,%r35,-2147483648; mov.b32 %r45,%r44; st.f32 [%r39],%r45; .loc 1 38 0 mov.f32 %r37,%r38; bra $L1; $L3: .loc 1 40 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r34; .loc 1 41 0 and.b32 %r47,%r35,%r36; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L5; .loc 1 43 0 st.f32 [%r39],%r38; .loc 1 45 0 and.b32 %r49,%r35,-2147483648; mov.b32 %r37,%r49; .loc 1 46 0 bra $L1; $L5: .loc 1 48 0 not.b32 %r50,%r36; and.b32 %r51,%r50,%r35; mov.b32 %r31,%r51; st.f32 [%r39],%r31; .loc 1 49 0 sub.f32 %r37,%r38,%r31; bra $L1; $L2: .loc 1 54 0 st.f32 [%r39],%r38; .loc 1 56 0 and.b32 %r52,%r35,-2147483648; mov.b32 %r37,%r52; $L1: .loc 1 59 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_nan.o/ 0 0 0 644 494 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_nan.c" // BEGIN GLOBAL FUNCTION DEF: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 17 0 mov.f32 %value,0f7fc00000; .loc 1 18 0 st.param.f32 [%value_out],%value; ret; } /1228 0 0 0 644 822 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nearbyintf .visible .func (.param .f32 %value_out) nearbyintf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_nearbyint.c" // BEGIN GLOBAL FUNCTION DECL: rintf .extern .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nearbyintf .visible .func (.param .f32 %value_out) nearbyintf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r25; mov.f32 %r23,%ar0; .loc 1 23 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r23; call (%value_in),rintf,(%out_arg1); ld.param.f32 %r25,[%value_in]; } .loc 1 24 0 mov.f32 %value,%r25; st.param.f32 [%value_out],%value; ret; } /1250 0 0 0 644 2807 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nextafterf .visible .func (.param .f32 %value_out) nextafterf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_nextafter.c" // BEGIN GLOBAL FUNCTION DEF: nextafterf .visible .func (.param .f32 %value_out) nextafterf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r33; .reg .u32 %r37; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .u32 %r42; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; .reg .u16 %r49; .reg .u16 %r50; .reg .u16 %r51; .reg .u32 %r52; .reg .u16 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .pred %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .u32 %r67; .reg .u16 %r69; .reg .u16 %r70; .reg .u16 %r71; .reg .u32 %r72; .reg .u16 %r73; .reg .pred %r74; .reg .u32 %r75; .reg .pred %r76; mov.f32 %r40,%ar0; mov.f32 %r41,%ar1; .loc 1 27 0 mov.b32 %r31,%r40; .loc 1 28 0 mov.b32 %r37,%r41; .loc 1 29 0 and.b32 %r33,%r31,2147483647; .loc 1 30 0 and.b32 %r42,%r37,2147483647; .loc 1 33 0 set.u32.gt.s32 %r44,%r42,2139095040; neg.s32 %r45,%r44; .loc 1 32 0 set.u32.gt.s32 %r47,%r33,2139095040; neg.s32 %r48,%r47; cvt.u16.u32 %r50,%r45; cvt.u16.u32 %r51,%r48; or.b16 %r49,%r50,%r51; cvt.u32.u16 %r52,%r49; cvt.u16.u8 %r53,%r52; setp.eq.u16 %r54,%r53,0; @ %r54 bra $L2; .loc 1 34 0 add.f32 %r39,%r40,%r41; bra $L1; $L2: .loc 1 35 0 setp.eq.f32 %r55,%r40,%r41; @ %r55 bra $L10; .loc 1 36 0 setp.ne.u32 %r56,%r33,0; @ %r56 bra $L4; .loc 1 37 0 and.b32 %r57,%r37,-2147483648; or.b32 %r58,%r57,1; mov.b32 %r39,%r58; .loc 1 38 0 mul.f32 %r38,%r39,%r39; .loc 1 39 0 setp.neu.f32 %r59,%r39,%r38; selp.f32 %r39,%r39,%r38,%r59; bra $L1; $L4: .loc 1 41 0 setp.lt.s32 %r60,%r31,0; @ %r60 bra $L5; .loc 1 42 0 setp.le.s32 %r61,%r31,%r37; @ %r61 bra $L6; .loc 1 43 0 add.u32 %r30,%r31,-1; bra $L7; $L6: .loc 1 45 0 add.u32 %r30,%r31,1; bra $L7; $L5: .loc 1 48 0 not.b32 %r63,%r37; shr.u32 %r64,%r63,31; set.u32.gt.s32 %r66,%r31,%r37; neg.s32 %r67,%r66; cvt.u16.u32 %r70,%r64; cvt.u16.u32 %r71,%r67; or.b16 %r69,%r70,%r71; cvt.u32.u16 %r72,%r69; cvt.u16.u8 %r73,%r72; setp.eq.u16 %r74,%r73,0; @ %r74 bra $L8; .loc 1 49 0 add.u32 %r30,%r31,-1; bra $L7; $L8: .loc 1 51 0 add.u32 %r30,%r31,1; $L7: .loc 1 54 0 and.b32 %r75,%r30,2139095040; .loc 1 55 0 setp.ne.u32 %r76,%r75,2139095040; @ %r76 bra $L9; add.f32 %r39,%r40,%r40; bra $L1; $L9: mov.b32 %r39,%r30; bra $L1; $L10: .loc 1 35 0 mov.f32 %r39,%r40; $L1: .loc 1 65 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } /1272 0 0 0 644 925 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: pow10f .visible .func (.param .f32 %value_out) pow10f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_pow10.c" // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: pow10f .visible .func (.param .f32 %value_out) pow10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r23,%ar0; .loc 1 32 0 mov.f32 %r24,0f41200000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r23; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 33 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } /1290 0 0 0 644 7548 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remquof .visible .func (.param .f32 %value_out) remquof (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/common/sf_remquo.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN VAR DEF: Zero .const .align 4 .u32 Zero[2] = {0,2147483648 }; // BEGIN GLOBAL FUNCTION DEF: remquof .visible .func (.param .f32 %value_out) remquof (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u64 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r34; .reg .f32 %r37; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r47; .reg .f32 %r50; .reg .f32 %r52; .reg .u32 %r54; .reg .f32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r81; .reg .u32 %r84; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .u64 %r89; .reg .u32 %r91; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u16 %r96; .reg .u16 %r97; .reg .u16 %r98; .reg .u32 %r100; .reg .u32 %r101; .reg .u16 %r103; .reg .u16 %r105; .reg .u32 %r106; .reg .u16 %r107; .reg .pred %r108; .reg .u32 %r109; .reg .pred %r110; .reg .pred %r111; .reg .u32 %r112; .reg .u64 %r113; .reg .u32 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .pred %r118; .reg .pred %r119; .reg .pred %r121; .reg .u32 %r122; .reg .pred %r123; .reg .pred %r124; .reg .pred %r126; .reg .u32 %r127; .reg .pred %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r132; .reg .u32 %r133; .reg .pred %r134; .reg .pred %r135; .reg .pred %r139; .reg .pred %r140; .reg .pred %r141; .reg .pred %r142; .reg .pred %r143; .reg .u64 %r144; .reg .u32 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u64 %r148; .reg .pred %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .f32 %r157; .reg .pred %r158; .reg .pred %r159; .reg .pred %r160; .reg .u32 %r161; .reg .pred %r162; .reg .pred %r163; .reg .pred %r164; .reg .u32 %r165; .reg .pred %r166; .reg .u32 %r167; .reg .pred %r168; .reg .pred %r170; mov.f32 %r87,%ar0; mov.f32 %r88,%ar1; mov.u64 %r89,%ar2; .loc 1 42 0 mov.b32 %r63,%r87; .loc 1 43 0 mov.b32 %r64,%r88; .loc 1 46 0 and.b32 %r58,%r63,2147483647; .loc 1 47 0 and.b32 %r66,%r64,2147483647; .loc 1 50 0 set.u32.eq.u32 %r91,%r66,0; neg.s32 %r92,%r91; set.u32.gt.s32 %r94,%r66,2139095040; neg.s32 %r95,%r94; cvt.u16.u32 %r97,%r92; cvt.u16.u32 %r98,%r95; or.b16 %r96,%r97,%r98; set.u32.gt.s32 %r100,%r58,2139095039; neg.s32 %r101,%r100; cvt.u16.u32 %r105,%r101; or.b16 %r103,%r96,%r105; cvt.u32.u16 %r106,%r103; cvt.u16.u8 %r107,%r106; setp.eq.u16 %r108,%r107,0; @ %r108 bra $L2; .loc 1 51 0 mov.u32 %r109,0; st.u32 [%r89],%r109; .loc 1 52 0 mul.f32 %r37,%r87,%r88; div.rn.f32 %r86,%r37,%r37; bra $L1; $L2: .loc 1 44 0 xor.b32 %r34,%r63,%r64; .loc 1 45 0 and.b32 %r65,%r63,-2147483648; .loc 1 54 0 setp.lt.s32 %r110,%r58,%r66; @ %r110 bra $L34; .loc 1 57 0 setp.ne.u32 %r111,%r58,%r66; @ %r111 bra $L5; .loc 1 58 0 mov.u32 %r112,1; st.u32 [%r89],%r112; .loc 1 59 0 cvta.const.u64 %r113,Zero; shr.u32 %r114,%r65,31; cvt.u64.u32 %r115,%r114; shl.b64 %r116,%r115,2; add.u64 %r117,%r113,%r116; ld.f32 %r86,[%r117]; bra $L1; $L5: .loc 1 63 0 setp.gt.s32 %r118,%r58,8388607; @ %r118 bra $L6; .loc 1 64 0 shl.b32 %r69,%r58,8; setp.eq.u32 %r119,%r69,0; @ %r119 bra $L35; mov.u32 %r68,-126; $L8: add.u32 %r68,%r68,-1; add.u32 %r69,%r69,%r69; setp.gt.s32 %r121,%r69,0; @ %r121 bra $L8; bra $L7; $L6: .loc 1 65 0 shr.s32 %r122,%r58,23; add.u32 %r68,%r122,-127; bra $L7; $L35: .loc 1 64 0 mov.u32 %r68,-126; $L7: .loc 1 68 0 setp.gt.s32 %r123,%r66,8388607; @ %r123 bra $L9; .loc 1 69 0 shl.b32 %r72,%r66,8; setp.eq.u32 %r124,%r72,0; @ %r124 bra $L36; mov.u32 %r71,-126; $L11: add.u32 %r71,%r71,-1; add.u32 %r72,%r72,%r72; setp.gt.s32 %r126,%r72,0; @ %r126 bra $L11; bra $L10; $L9: .loc 1 70 0 shr.s32 %r127,%r66,23; add.u32 %r71,%r127,-127; bra $L10; $L36: .loc 1 69 0 mov.u32 %r71,-126; $L10: .loc 1 73 0 setp.lt.s32 %r128,%r68,-126; @ %r128 bra $L12; .loc 1 74 0 and.b32 %r42,%r63,8388607; or.b32 %r57,%r42,8388608; bra $L13; $L12: .loc 1 76 0 mov.u32 %r130,-126; sub.u32 %r129,%r130,%r68; .loc 1 77 0 shl.b32 %r57,%r58,%r129; $L13: .loc 1 79 0 setp.lt.s32 %r170,%r71,-126; @ %r170 bra $L14; .loc 1 80 0 and.b32 %r43,%r64,8388607; or.b32 %r59,%r43,8388608; bra $L15; $L14: .loc 1 82 0 mov.u32 %r133,-126; sub.u32 %r132,%r133,%r71; .loc 1 83 0 shl.b32 %r59,%r66,%r132; $L15: .loc 1 87 0 sub.u32 %r75,%r68,%r71; .loc 1 89 0 add.u32 %r77,%r75,-1; setp.eq.u32 %r134,%r75,0; @ %r134 bra $L37; .loc 1 88 0 mov.u32 %r60,0; $L19: .loc 1 90 0 sub.u32 %r81,%r57,%r59; .loc 1 91 0 setp.ge.s32 %r135,%r81,0; @ %r135 bra $L17; add.u32 %r57,%r57,%r57; bra $L18; $L17: .loc 1 92 0 add.u32 %r57,%r81,%r81; add.u32 %r60,%r60,1; $L18: .loc 1 93 0 add.u32 %r60,%r60,%r60; .loc 1 89 0 add.u32 %r77,%r77,-1; setp.ne.u32 %r139,%r77,-1; @ %r139 bra $L19; bra $L16; $L37: .loc 1 88 0 mov.u32 %r60,%r75; $L16: .loc 1 95 0 sub.u32 %r78,%r57,%r59; .loc 1 96 0 setp.lt.s32 %r140,%r78,0; @ %r140 bra $L20; add.u32 %r60,%r60,1; mov.u32 %r57,%r78; $L20: .loc 1 99 0 setp.eq.u32 %r141,%r57,0; @ %r141 bra $L21; .loc 1 103 0 setp.le.s32 %r142,%r57,8388607; @ %r142 bra $L22; bra $L23; $L21: .loc 1 100 0 setp.ge.s32 %r143,%r34,0; @ %r143 bra $L24; neg.s32 %r61,%r60; bra $L25; $L24: mov.u32 %r61,%r60; $L25: st.u32 [%r89],%r61; .loc 1 101 0 cvta.const.u64 %r144,Zero; shr.u32 %r145,%r65,31; cvt.u64.u32 %r146,%r145; shl.b64 %r147,%r146,2; add.u64 %r148,%r144,%r147; ld.f32 %r86,[%r148]; bra $L1; $L22: .loc 1 104 0 add.u32 %r57,%r57,%r57; .loc 1 105 0 add.u32 %r71,%r71,-1; .loc 1 103 0 setp.le.s32 %r150,%r57,8388607; @ %r150 bra $L22; setp.lt.s32 %r170,%r71,-126; $L23: .loc 1 107 0 @ %r170 bra $L26; .loc 1 108 0 add.u32 %r47,%r57,-8388608; add.u32 %r152,%r71,127; shl.b32 %r153,%r152,23; or.b32 %r58,%r153,%r47; bra $L4; $L26: .loc 1 110 0 mov.u32 %r155,-126; sub.u32 %r154,%r155,%r71; .loc 1 111 0 shr.s32 %r58,%r57,%r154; bra $L4; $L34: .loc 1 55 0 mov.u32 %r60,0; $L4: .loc 1 114 0 mov.b32 %r56,%r58; .loc 1 115 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r88; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r157,[%value_in]; } .loc 1 116 0 setp.lt.f32 %r158,%r157,0f01000000; @ ! %r158 bra $L50; .loc 1 117 0 add.f32 %r50,%r56,%r56; setp.gt.f32 %r159,%r50,%r157; @ %r159 bra $L29; setp.neu.f32 %r160,%r50,%r157; @ %r160 bra $L30; and.b32 %r161,%r60,1; setp.eq.u32 %r162,%r161,0; @ %r162 bra $L30; $L29: .loc 1 118 0 add.u32 %r60,%r60,1; .loc 1 119 0 sub.f32 %r56,%r56,%r157; bra $L30; $L50: .loc 1 121 0 mul.f32 %r52,%r157,0f3f000000; setp.lt.f32 %r163,%r52,%r56; @ %r163 bra $L31; setp.neu.f32 %r164,%r52,%r56; @ %r164 bra $L30; and.b32 %r165,%r60,1; setp.eq.u32 %r166,%r165,0; @ %r166 bra $L30; $L31: .loc 1 122 0 add.u32 %r60,%r60,1; .loc 1 123 0 sub.f32 %r56,%r56,%r157; $L30: .loc 1 126 0 mov.b32 %r167,%r56; xor.b32 %r54,%r65,%r167; mov.b32 %r86,%r54; .loc 1 127 0 and.b32 %r84,%r60,2147483647; .loc 1 128 0 setp.ge.s32 %r168,%r34,0; @ %r168 bra $L32; neg.s32 %r62,%r84; bra $L33; $L32: mov.u32 %r62,%r84; $L33: st.u32 [%r89],%r62; $L1: .loc 1 130 0 mov.f32 %value,%r86; st.param.f32 [%value_out],%value; ret; } lib_a-sf_rint.o/0 0 0 644 3145 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rintf .visible .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_rint.c" // BEGIN VAR DEF: TWO23 .const .align 4 .u32 TWO23[2] = {1258291200,3405774848 }; // BEGIN GLOBAL FUNCTION DEF: rintf .visible .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .f32 %r33; .reg .f32 %r34; .reg .f32 %r35; .reg .u32 %r38; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .f32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .pred %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .pred %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .f32 %r97; mov.f32 %r63,%ar0; .loc 1 39 0 mov.b32 %r22,%r63; .loc 1 41 0 and.b32 %r52,%r22,2147483647; .loc 1 42 0 shr.u32 %r64,%r52,23; add.u32 %r53,%r64,-127; .loc 1 43 0 setp.gt.s32 %r65,%r53,22; @ %r65 bra $L2; .loc 1 44 0 setp.eq.u32 %r66,%r52,0; @ %r66 bra $L3; .loc 1 39 0 mov.u32 %r50,%r22; .loc 1 40 0 shr.u32 %r51,%r22,31; .loc 1 46 0 setp.ge.s32 %r67,%r53,0; @ %r67 bra $L4; .loc 1 47 0 and.b32 %r57,%r22,8388607; .loc 1 51 0 cvta.const.u64 %r68,TWO23; cvt.s64.s32 %r69,%r51; shl.b64 %r70,%r69,2; add.u64 %r71,%r68,%r70; ld.f32 %r33,[%r71]; .loc 1 49 0 neg.s32 %r72,%r57; shr.u32 %r74,%r72,9; and.b32 %r75,%r74,4194304; .loc 1 48 0 and.b32 %r76,%r22,-1048576; .loc 1 49 0 or.b32 %r77,%r75,%r76; .loc 1 51 0 mov.b32 %r78,%r77; add.f32 %r34,%r33,%r78; st.f32 [%frame],%r34; .loc 1 52 0 ld.f32 %r35,[%frame]; sub.f32 %r79,%r35,%r33; .loc 1 54 0 mov.b32 %r81,%r79; and.b32 %r80,%r81,2147483647; shl.b32 %r82,%r51,31; or.b32 %r38,%r80,%r82; mov.b32 %r63,%r38; .loc 1 55 0 bra $L3; $L4: .loc 1 57 0 mov.u32 %r83,8388607; shr.s32 %r54,%r83,%r53; .loc 1 58 0 and.b32 %r84,%r50,%r54; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L3; .loc 1 59 0 shr.u32 %r55,%r54,1; .loc 1 60 0 and.b32 %r86,%r50,%r55; setp.eq.u32 %r87,%r86,0; @ %r87 bra $L5; not.b32 %r88,%r55; and.b32 %r89,%r88,%r50; mov.u32 %r91,2097152; shr.s32 %r90,%r91,%r53; or.b32 %r50,%r89,%r90; bra $L5; $L2: .loc 1 63 0 setp.le.u32 %r92,%r52,2139095039; @ %r92 bra $L3; add.f32 %r63,%r63,%r63; bra $L3; $L5: .loc 1 68 0 cvta.const.u64 %r93,TWO23; cvt.s64.s32 %r94,%r51; shl.b64 %r95,%r94,2; add.u64 %r96,%r93,%r95; ld.f32 %r47,[%r96]; mov.b32 %r97,%r50; add.f32 %r48,%r47,%r97; st.f32 [%frame],%r48; .loc 1 69 0 ld.f32 %r49,[%frame]; sub.f32 %r63,%r49,%r47; $L3: .loc 1 70 0 mov.f32 %value,%r63; st.param.f32 [%value_out],%value; ret; } /1309 0 0 0 644 1702 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: roundf .visible .func (.param .f32 %value_out) roundf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_round.c" // BEGIN GLOBAL FUNCTION DEF: roundf .visible .func (.param .f32 %value_out) roundf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .pred %r40; .reg .pred %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; mov.f32 %r36,%ar0; .loc 1 25 0 mov.b32 %r32,%r36; .loc 1 28 0 shr.u32 %r37,%r32,23; and.b32 %r38,%r37,255; add.u32 %r31,%r38,-127; .loc 1 30 0 setp.gt.s32 %r39,%r31,22; @ %r39 bra $L2; .loc 1 32 0 setp.ge.s32 %r40,%r31,0; @ %r40 bra $L3; .loc 1 34 0 and.b32 %r30,%r32,-2147483648; .loc 1 35 0 setp.ne.u32 %r41,%r31,-1; @ %r41 bra $L4; .loc 1 37 0 or.b32 %r30,%r30,1065353216; bra $L4; $L3: .loc 1 41 0 mov.u32 %r42,8388607; shr.s32 %r33,%r42,%r31; .loc 1 42 0 and.b32 %r43,%r32,%r33; setp.eq.u32 %r44,%r43,0; @ %r44 bra $L6; .loc 1 46 0 mov.u32 %r46,4194304; shr.s32 %r45,%r46,%r31; add.u32 %r34,%r45,%r32; .loc 1 47 0 not.b32 %r47,%r33; and.b32 %r30,%r47,%r34; bra $L4; $L2: .loc 1 52 0 setp.ne.u32 %r48,%r31,128; @ %r48 bra $L7; .loc 1 54 0 add.f32 %r35,%r36,%r36; bra $L1; $L4: .loc 1 58 0 mov.b32 %r35,%r30; .loc 1 59 0 bra $L1; $L6: .loc 1 44 0 mov.f32 %r35,%r36; bra $L1; $L7: mov.f32 %r35,%r36; $L1: .loc 1 60 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } /1327 0 0 0 644 3639 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalblnf .visible .func (.param .f32 %value_out) scalblnf (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_scalbln.c" // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalblnf .visible .func (.param .f32 %value_out) scalblnf (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r28; .reg .u32 %r46; .reg .u32 %r47; .reg .f32 %r52; .reg .f32 %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .pred %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u32 %r62; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r67; .reg .u32 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u16 %r71; .reg .u32 %r72; .reg .u16 %r73; .reg .pred %r74; .reg .f32 %r75; .reg .f32 %r77; .reg .pred %r78; .reg .f32 %r79; .reg .f32 %r81; .reg .pred %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .f32 %r87; .reg .f32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .f32 %r94; mov.f32 %r53,%ar0; mov.u64 %r54,%ar1; .loc 1 36 0 mov.b32 %r46,%r53; .loc 1 37 0 shr.s32 %r55,%r46,23; and.b32 %r47,%r55,255; .loc 1 38 0 setp.ne.u32 %r56,%r47,0; @ %r56 bra $L2; .loc 1 39 0 and.b32 %r57,%r46,2147483647; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L9; .loc 1 40 0 mul.f32 %r53,%r53,0f4c000000; .loc 1 41 0 mov.b32 %r46,%r53; .loc 1 42 0 shr.s32 %r59,%r46,23; and.b32 %r60,%r59,255; add.u32 %r47,%r60,-25; bra $L4; $L2: .loc 1 44 0 setp.ne.u32 %r61,%r47,255; @ %r61 bra $L4; add.f32 %r52,%r53,%r53; bra $L1; $L4: .loc 1 45 0 cvt.u32.u64 %r62,%r54; add.u32 %r28,%r47,%r62; .loc 1 46 0 set.u32.gt.s64 %r64,%r54,50000; neg.s32 %r65,%r64; set.u32.gt.s32 %r67,%r28,254; neg.s32 %r68,%r67; cvt.u16.u32 %r70,%r65; cvt.u16.u32 %r71,%r68; or.b16 %r69,%r70,%r71; cvt.u32.u16 %r72,%r69; cvt.u16.u8 %r73,%r72; setp.eq.u16 %r74,%r73,0; @ %r74 bra $L5; .loc 1 47 0 mov.f32 %r75,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r75; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r77,[%value_in]; } mul.f32 %r52,%r77,0f7149f2ca; bra $L1; $L5: .loc 1 48 0 setp.ge.s64 %r78,%r54,-50000; @ %r78 bra $L6; .loc 1 49 0 mov.f32 %r79,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r79; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r81,[%value_in]; } mul.f32 %r52,%r81,0f0da24260; bra $L1; $L6: .loc 1 50 0 setp.le.s32 %r82,%r28,0; @ %r82 bra $L7; .loc 1 51 0 and.b32 %r83,%r46,-2139095041; shl.b32 %r84,%r28,23; or.b32 %r85,%r83,%r84; mov.b32 %r52,%r85; bra $L1; $L7: .loc 1 52 0 setp.ge.s32 %r86,%r28,-24; @ %r86 bra $L8; .loc 1 53 0 mov.f32 %r87,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r87; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r89,[%value_in]; } mul.f32 %r52,%r89,0f0da24260; bra $L1; $L8: .loc 1 54 0 add.u32 %r90,%r28,25; .loc 1 55 0 shl.b32 %r91,%r90,23; and.b32 %r92,%r46,-2139095041; or.b32 %r93,%r91,%r92; .loc 1 56 0 mov.b32 %r94,%r93; mul.f32 %r52,%r94,0f33000000; bra $L1; $L9: .loc 1 39 0 mov.f32 %r52,%r53; $L1: .loc 1 57 0 mov.f32 %value,%r52; st.param.f32 [%value_out],%value; ret; } /1347 0 0 0 644 3411 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .f32 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .f32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .pred %r64; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .f32 %r75; mov.f32 %r47,%ar0; mov.u32 %r48,%ar1; .loc 1 46 0 mov.b32 %r22,%r47; .loc 1 47 0 and.b32 %r42,%r22,2147483647; .loc 1 49 0 setp.eq.u32 %r49,%r42,0; @ %r49 bra $L11; .loc 1 51 0 setp.le.u32 %r50,%r42,2139095039; @ %r50 bra $L3; .loc 1 52 0 add.f32 %r46,%r47,%r47; bra $L1; $L3: .loc 1 53 0 setp.gt.u32 %r51,%r42,8388607; @ %r51 bra $L4; .loc 1 54 0 mul.f32 %r47,%r47,0f4c000000; .loc 1 57 0 setp.lt.s32 %r52,%r48,-50000; @ %r52 bra $L5; .loc 1 55 0 mov.b32 %r41,%r47; .loc 1 56 0 shr.s32 %r53,%r41,23; and.b32 %r54,%r53,255; add.u32 %r40,%r54,-25; bra $L6; $L5: .loc 1 57 0 mul.f32 %r46,%r47,0f0da24260; bra $L1; $L4: .loc 1 46 0 mov.u32 %r41,%r22; .loc 1 48 0 shr.u32 %r40,%r42,23; $L6: .loc 1 59 0 add.u32 %r43,%r40,%r48; .loc 1 60 0 setp.le.s32 %r55,%r43,254; @ %r55 bra $L7; mov.f32 %r56,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r56; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r58,[%value_in]; } mul.f32 %r46,%r58,0f7149f2ca; bra $L1; $L7: .loc 1 61 0 setp.le.s32 %r59,%r43,0; @ %r59 bra $L8; .loc 1 62 0 and.b32 %r60,%r41,-2139095041; shl.b32 %r61,%r43,23; or.b32 %r62,%r60,%r61; mov.b32 %r46,%r62; bra $L1; $L8: .loc 1 63 0 setp.ge.s32 %r63,%r43,-22; @ %r63 bra $L9; .loc 1 64 0 setp.le.s32 %r64,%r48,50000; @ %r64 bra $L10; .loc 1 65 0 mov.f32 %r65,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r65; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r67,[%value_in]; } mul.f32 %r46,%r67,0f7149f2ca; bra $L1; $L10: .loc 1 66 0 mov.f32 %r68,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r70,[%value_in]; } mul.f32 %r46,%r70,0f0da24260; bra $L1; $L9: .loc 1 68 0 add.u32 %r71,%r43,25; .loc 1 69 0 shl.b32 %r72,%r71,23; and.b32 %r73,%r41,-2139095041; or.b32 %r74,%r72,%r73; .loc 1 70 0 mov.b32 %r75,%r74; mul.f32 %r46,%r75,0f33000000; bra $L1; $L11: .loc 1 50 0 mov.f32 %r46,%r47; $L1: .loc 1 71 0 mov.f32 %value,%r46; st.param.f32 [%value_out],%value; ret; } /1366 0 0 0 644 1292 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: significandf .visible .func (.param .f32 %value_out) significandf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_signif.c" // BEGIN GLOBAL FUNCTION DECL: ilogbf .extern .func (.param .u32 %value_out) ilogbf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalbf .extern .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: significandf .visible .func (.param .f32 %value_out) significandf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r26; .reg .u32 %r28; .reg .u32 %r31; .reg .f32 %r32; .reg .f32 %r33; mov.f32 %r26,%ar0; .loc 1 25 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),ilogbf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } neg.s32 %r31,%r28; cvt.rn.f32.s32 %r32,%r31; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),__ieee754_scalbf,(%out_arg1,%out_arg2); ld.param.f32 %r33,[%value_in]; } .loc 1 26 0 mov.f32 %value,%r33; st.param.f32 [%value_out],%value; ret; } lib_a-sf_sin.o/ 0 0 0 644 3876 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sinf .visible .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_sin.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .extern .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .extern .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .extern .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: sinf .visible .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .pred %r39; .reg .f32 %r41; .reg .u32 %r42; .reg .f32 %r43; .reg .pred %r44; .reg .u32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .f32 %r52; .reg .u32 %r54; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .u32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r68; .reg .f32 %r69; mov.f32 %r38,%ar0; .loc 1 28 0 mov.b32 %r34,%r38; .loc 1 31 0 and.b32 %r35,%r34,2147483647; .loc 1 32 0 setp.gt.s32 %r39,%r35,1061752792; @ %r39 bra $L2; mov.u32 %r42,0; mov.f32 %r41,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r42; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r43,[%value_in]; } mov.f32 %r37,%r43; bra $L1; $L2: .loc 1 35 0 setp.le.s32 %r44,%r35,2139095039; @ %r44 bra $L4; sub.f32 %r37,%r38,%r38; bra $L1; $L4: .loc 1 39 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2f,(%out_arg1,%out_arg2); ld.param.u32 %r47,[%value_in]; } .loc 1 40 0 and.b32 %r48,%r47,3; setp.eq.u32 %r49,%r48,1; @ %r49 bra $L6; setp.eq.u32 %r50,%r48,2; @ %r50 bra $L7; setp.eq.u32 %r51,%r48,0; @ ! %r51 bra $L9; .loc 1 41 0 ld.f32 %r55,[%frame+4]; mov.u32 %r54,1; ld.f32 %r52,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r52; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r55; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r54; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r56,[%value_in]; } mov.f32 %r37,%r56; bra $L1; $L6: .loc 1 42 0 ld.f32 %r59,[%frame+4]; ld.f32 %r57,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r57; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r59; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r60,[%value_in]; } mov.f32 %r37,%r60; bra $L1; $L7: .loc 1 43 0 ld.f32 %r64,[%frame+4]; mov.u32 %r63,1; ld.f32 %r61,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r63; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r65,[%value_in]; } neg.f32 %r37,%r65; bra $L1; $L9: .loc 1 45 0 ld.f32 %r68,[%frame+4]; ld.f32 %r66,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r66; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r68; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r69,[%value_in]; } neg.f32 %r37,%r69; $L1: .loc 1 48 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_tan.o/ 0 0 0 644 2453 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanf .visible .func (.param .f32 %value_out) tanf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_tan.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_tanf .extern .func (.param .f32 %value_out) __kernel_tanf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .extern .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: tanf .visible .func (.param .f32 %value_out) tanf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r28; .reg .u32 %r29; .reg .f32 %r31; .reg .f32 %r32; .reg .pred %r33; .reg .f32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .pred %r38; .reg .u32 %r41; .reg .f32 %r42; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .f32 %r49; .reg .f32 %r50; mov.f32 %r32,%ar0; .loc 1 28 0 mov.b32 %r28,%r32; .loc 1 31 0 and.b32 %r29,%r28,2147483647; .loc 1 32 0 setp.gt.s32 %r33,%r29,1061752794; @ %r33 bra $L2; mov.u32 %r36,1; mov.f32 %r35,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r35; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r36; call (%value_in),__kernel_tanf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r37,[%value_in]; } mov.f32 %r31,%r37; bra $L1; $L2: .loc 1 35 0 setp.le.s32 %r38,%r29,2139095039; @ %r38 bra $L4; sub.f32 %r31,%r32,%r32; bra $L1; $L4: .loc 1 39 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2f,(%out_arg1,%out_arg2); ld.param.u32 %r41,[%value_in]; } .loc 1 40 0 add.u32 %r45,%r41,%r41; and.b32 %r46,%r45,2; mov.u32 %r48,1; sub.u32 %r47,%r48,%r46; ld.f32 %r49,[%frame+4]; ld.f32 %r42,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r49; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r47; call (%value_in),__kernel_tanf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r50,[%value_in]; } mov.f32 %r31,%r50; $L1: .loc 1 43 0 mov.f32 %value,%r31; st.param.f32 [%value_out],%value; ret; } lib_a-sf_tanh.o/0 0 0 644 2765 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanhf .visible .func (.param .f32 %value_out) tanhf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/sf_tanh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1f .extern .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanhf .visible .func (.param .f32 %value_out) tanhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r31; .reg .u32 %r32; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .pred %r39; .reg .f32 %r40; .reg .pred %r41; .reg .pred %r43; .reg .pred %r44; .reg .f32 %r45; .reg .pred %r46; .reg .f32 %r48; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .pred %r63; mov.f32 %r38,%ar0; .loc 1 34 0 mov.b32 %r31,%r38; .loc 1 35 0 and.b32 %r32,%r31,2147483647; .loc 1 38 0 setp.le.s32 %r39,%r32,2139095039; @ %r39 bra $L2; mov.f32 %r40,0f3f800000; div.rn.f32 %r36,%r40,%r38; .loc 1 39 0 setp.lt.s32 %r41,%r31,0; @ %r41 bra $L3; add.f32 %r37,%r36,0f3f800000; bra $L1; $L3: .loc 1 40 0 sub.f32 %r37,%r36,%r40; bra $L1; $L2: .loc 1 44 0 setp.gt.s32 %r43,%r32,1102053375; @ %r43 bra $L8; .loc 1 45 0 setp.gt.s32 %r44,%r32,603979775; @ %r44 bra $L6; .loc 1 46 0 add.f32 %r45,%r38,0f3f800000; mul.f32 %r37,%r45,%r38; bra $L1; $L6: .loc 1 47 0 setp.le.s32 %r46,%r32,1065353215; @ %r46 bra $L7; .loc 1 48 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r48,[%value_in]; } add.f32 %r50,%r48,%r48; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r51,[%value_in]; } .loc 1 49 0 add.f32 %r52,%r51,0f40000000; mov.f32 %r54,0f40000000; div.rn.f32 %r53,%r54,%r52; mov.f32 %r55,0f3f800000; sub.f32 %r37,%r55,%r53; bra $L5; $L7: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r57,[%value_in]; } mul.f32 %r59,%r57,0fc0000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r59; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r60,[%value_in]; } .loc 1 52 0 neg.f32 %r61,%r60; add.f32 %r62,%r60,0f40000000; div.rn.f32 %r37,%r61,%r62; bra $L5; $L8: .loc 1 56 0 mov.f32 %r37,0f3f800000; $L5: .loc 1 58 0 setp.ge.s32 %r63,%r31,0; @ %r63 bra $L1; neg.f32 %r37,%r37; $L1: .loc 1 59 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /1385 0 0 0 644 1180 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: truncf .visible .func (.param .f32 %value_out) truncf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_trunc.c" // BEGIN GLOBAL FUNCTION DEF: truncf .visible .func (.param .f32 %value_out) truncf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r29; .reg .f32 %r31; .reg .f32 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .pred %r35; .reg .pred %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; mov.f32 %r32,%ar0; .loc 1 23 0 mov.b32 %r27,%r32; .loc 1 29 0 shr.s32 %r33,%r27,23; and.b32 %r34,%r33,255; add.u32 %r29,%r34,-127; .loc 1 31 0 setp.gt.s32 %r35,%r29,22; @ %r35 bra $L4; .loc 1 33 0 setp.ge.s32 %r36,%r29,0; @ %r36 bra $L3; .loc 1 26 0 and.b32 %r37,%r27,-2147483648; .loc 1 36 0 mov.b32 %r31,%r37; bra $L1; $L3: .loc 1 40 0 mov.u32 %r39,8388607; shr.s32 %r38,%r39,%r29; not.b32 %r40,%r38; and.b32 %r41,%r40,%r27; mov.b32 %r31,%r41; bra $L1; $L4: mov.f32 %r31,%r32; $L1: .loc 1 52 0 mov.f32 %value,%r31; st.param.f32 [%value_out],%value; ret; } lib_a-sinhl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sinhl .visible .func (.param .f64 %value_out) sinhl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/sinhl.c" // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sinhl .visible .func (.param .f64 %value_out) sinhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-sinl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sinl .visible .func (.param .f64 %value_out) sinl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/sinl.c" // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sinl .visible .func (.param .f64 %value_out) sinl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),sin,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-sqrtl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sqrtl .visible .func (.param .f64 %value_out) sqrtl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/sqrtl.c" // BEGIN GLOBAL FUNCTION DECL: sqrt .extern .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sqrtl .visible .func (.param .f64 %value_out) sqrtl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-tanhl.o/ 0 0 0 644 792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanhl .visible .func (.param .f64 %value_out) tanhl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/tanhl.c" // BEGIN GLOBAL FUNCTION DECL: tanh .extern .func (.param .f64 %value_out) tanh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanhl .visible .func (.param .f64 %value_out) tanhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),tanh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-tanl.o/ 0 0 0 644 784 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanl .visible .func (.param .f64 %value_out) tanl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/tanl.c" // BEGIN GLOBAL FUNCTION DECL: tan .extern .func (.param .f64 %value_out) tan (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanl .visible .func (.param .f64 %value_out) tanl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),tan,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-tgammal.o/0 0 0 644 808 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tgammal .visible .func (.param .f64 %value_out) tgammal (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/tgammal.c" // BEGIN GLOBAL FUNCTION DECL: tgamma .extern .func (.param .f64 %value_out) tgamma (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tgammal .visible .func (.param .f64 %value_out) tgammal (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),tgamma,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-truncl.o/ 0 0 0 644 800 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: truncl .visible .func (.param .f64 %value_out) truncl (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/truncl.c" // BEGIN GLOBAL FUNCTION DECL: trunc .extern .func (.param .f64 %value_out) trunc (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: truncl .visible .func (.param .f64 %value_out) truncl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),trunc,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-w_acos.o/ 0 0 0 644 3861 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acos .visible .func (.param .f64 %value_out) acos (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_acos.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acos .extern .func (.param .f64 %value_out) __ieee754_acos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {97,99,111,115,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: acos .visible .func (.param .f64 %value_out) acos (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .u64 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; mov.f64 %r34,%ar0; .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__ieee754_acos,(%out_arg1); ld.param.f64 %r36,[%value_in]; } mov.f64 %r33,%r36; .loc 1 97 0 ld.global.u32 %r37,[__fdlib_version]; setp.eq.u32 %r38,%r37,-1; @ %r38 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.eq.u32 %r41,%r40,0; @ %r41 bra $L1; .loc 1 98 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r43,[%value_in]; } setp.gt.f64 %r44,%r43,0d3ff0000000000000; @ ! %r44 bra $L1; .loc 1 100 0 mov.u32 %r45,1; st.u32 [%frame],%r45; .loc 1 101 0 cvta.const.u64 %r46,$LC0; st.u64 [%frame+8],%r46; .loc 1 102 0 mov.u32 %r47,0; st.u32 [%frame+40],%r47; .loc 1 103 0 st.f64 [%frame+24],%r34; st.f64 [%frame+16],%r34; .loc 1 104 0 cvta.const.u64 %r48,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r48; call (%value_in),nan,(%out_arg1); ld.param.f64 %r49,[%value_in]; } st.f64 [%frame+32],%r49; .loc 1 105 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,33; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 107 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,33; st.u32 [%r57],%r58; $L5: .loc 1 110 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 112 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 116 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } lib_a-w_acosh.o/0 0 0 644 3352 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acosh .visible .func (.param .f64 %value_out) acosh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_acosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosh .extern .func (.param .f64 %value_out) __ieee754_acosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,99,111,115,104,0 }; // BEGIN GLOBAL FUNCTION DEF: acosh .visible .func (.param .f64 %value_out) acosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .u32 %r42; .reg .u64 %r43; .reg .u32 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u64 %r58; mov.f64 %r33,%ar0; .loc 1 100 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_acosh,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 101 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 102 0 setp.lt.f64 %r41,%r33,0d3ff0000000000000; @ ! %r41 bra $L1; .loc 1 104 0 mov.u32 %r42,1; st.u32 [%frame],%r42; .loc 1 105 0 cvta.const.u64 %r43,$LC0; st.u64 [%frame+8],%r43; .loc 1 106 0 mov.u32 %r44,0; st.u32 [%frame+40],%r44; .loc 1 107 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 108 0 mov.f64 %r46,0d0000000000000000; div.rn.f64 %r45,%r46,0d0000000000000000; st.f64 [%frame+32],%r45; .loc 1 109 0 ld.global.u32 %r47,[__fdlib_version]; setp.ne.u32 %r48,%r47,2; @ %r48 bra $L4; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r49,[%value_in]; } mov.u32 %r50,33; st.u32 [%r49],%r50; bra $L5; $L4: .loc 1 111 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r52,[%value_in]; } setp.ne.u32 %r53,%r52,0; @ %r53 bra $L5; .loc 1 112 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,33; st.u32 [%r54],%r55; $L5: .loc 1 114 0 ld.u32 %r56,[%frame+40]; setp.eq.u32 %r57,%r56,0; @ %r57 bra $L6; .loc 1 115 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r58],%r31; $L6: .loc 1 116 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 120 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } lib_a-w_asin.o/ 0 0 0 644 3864 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: asin .visible .func (.param .f64 %value_out) asin (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_asin.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_asin .extern .func (.param .f64 %value_out) __ieee754_asin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {97,115,105,110,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: asin .visible .func (.param .f64 %value_out) asin (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .u64 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; mov.f64 %r34,%ar0; .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__ieee754_asin,(%out_arg1); ld.param.f64 %r36,[%value_in]; } mov.f64 %r33,%r36; .loc 1 100 0 ld.global.u32 %r37,[__fdlib_version]; setp.eq.u32 %r38,%r37,-1; @ %r38 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.eq.u32 %r41,%r40,0; @ %r41 bra $L1; .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r43,[%value_in]; } setp.gt.f64 %r44,%r43,0d3ff0000000000000; @ ! %r44 bra $L1; .loc 1 103 0 mov.u32 %r45,1; st.u32 [%frame],%r45; .loc 1 104 0 cvta.const.u64 %r46,$LC0; st.u64 [%frame+8],%r46; .loc 1 105 0 mov.u32 %r47,0; st.u32 [%frame+40],%r47; .loc 1 106 0 st.f64 [%frame+24],%r34; st.f64 [%frame+16],%r34; .loc 1 107 0 cvta.const.u64 %r48,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r48; call (%value_in),nan,(%out_arg1); ld.param.f64 %r49,[%value_in]; } st.f64 [%frame+32],%r49; .loc 1 108 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,33; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 110 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,33; st.u32 [%r57],%r58; $L5: .loc 1 113 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 114 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 115 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 119 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } lib_a-w_atan2.o/0 0 0 644 1032 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan2 .visible .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_atan2.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2 .extern .func (.param .f64 %value_out) __ieee754_atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atan2 .visible .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),__ieee754_atan2,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 88 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-w_atanh.o/0 0 0 644 4770 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: atanh .visible .func (.param .f64 %value_out) atanh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_atanh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanh .extern .func (.param .f64 %value_out) __ieee754_atanh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,116,97,110,104,0 }; // BEGIN GLOBAL FUNCTION DEF: atanh .visible .func (.param .f64 %value_out) atanh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .f64 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .f64 %r47; .reg .pred %r48; .reg .pred %r49; .reg .u32 %r50; .reg .u64 %r51; .reg .u32 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .f64 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; mov.f64 %r38,%ar0; .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),__ieee754_atanh,(%out_arg1); ld.param.f64 %r40,[%value_in]; } mov.f64 %r37,%r40; .loc 1 100 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r47,[%value_in]; } .loc 1 102 0 setp.ge.f64 %r48,%r47,0d3ff0000000000000; @ ! %r48 bra $L1; ld.global.u32 %r36,[__fdlib_version]; .loc 1 103 0 setp.gt.f64 %r49,%r47,0d3ff0000000000000; @ ! %r49 bra $L23; .loc 1 105 0 mov.u32 %r50,1; st.u32 [%frame],%r50; .loc 1 106 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 107 0 mov.u32 %r52,0; st.u32 [%frame+40],%r52; .loc 1 108 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 109 0 mov.f64 %r54,0d0000000000000000; div.rn.f64 %r53,%r54,0d0000000000000000; st.f64 [%frame+32],%r53; .loc 1 110 0 setp.ne.u32 %r55,%r36,2; @ %r55 bra $L6; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,33; st.u32 [%r56],%r57; bra $L7; $L6: .loc 1 112 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.eq.u32 %r60,%r59,0; @ ! %r60 bra $L7; .loc 1 113 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } mov.u32 %r62,33; st.u32 [%r61],%r62; bra $L7; $L23: .loc 1 117 0 mov.u32 %r63,2; st.u32 [%frame],%r63; .loc 1 118 0 cvta.const.u64 %r64,$LC0; st.u64 [%frame+8],%r64; .loc 1 119 0 mov.u32 %r65,0; st.u32 [%frame+40],%r65; .loc 1 120 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 121 0 div.rn.f64 %r66,%r38,0d0000000000000000; st.f64 [%frame+32],%r66; .loc 1 122 0 setp.ne.u32 %r67,%r36,2; @ %r67 bra $L9; .loc 1 123 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L7; $L9: .loc 1 124 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r71,[%value_in]; } setp.ne.u32 %r72,%r71,0; @ %r72 bra $L7; .loc 1 125 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } mov.u32 %r74,33; st.u32 [%r73],%r74; $L7: .loc 1 128 0 ld.u32 %r75,[%frame+40]; setp.eq.u32 %r76,%r75,0; @ %r76 bra $L11; .loc 1 129 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r77],%r34; $L11: .loc 1 130 0 ld.f64 %r37,[%frame+32]; $L1: .loc 1 134 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } lib_a-w_cosh.o/ 0 0 0 644 3714 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: cosh .visible .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_cosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_cosh .extern .func (.param .f64 %value_out) __ieee754_cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {99,111,115,104,0 }; // BEGIN GLOBAL FUNCTION DEF: cosh .visible .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .f64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r52; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; mov.f64 %r33,%ar0; .loc 1 85 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_cosh,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 86 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r42,[%value_in]; } setp.gt.f64 %r43,%r42,0d408633ce8fb9f87d; @ ! %r43 bra $L1; .loc 1 95 0 mov.u32 %r44,3; st.u32 [%frame],%r44; .loc 1 96 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 97 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 98 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 99 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r47,%r25,0; @ %r47 bra $L4; .loc 1 100 0 mov.f64 %r48,0d47efffffe0000000; st.f64 [%frame+32],%r48; bra $L5; $L4: .loc 1 102 0 mov.f64 %r49,0d7ff0000000000000; st.f64 [%frame+32],%r49; .loc 1 103 0 setp.ne.u32 %r50,%r25,2; @ %r50 bra $L5; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r51,[%value_in]; } mov.u32 %r52,34; st.u32 [%r51],%r52; bra $L6; $L5: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r54,[%value_in]; } setp.ne.u32 %r55,%r54,0; @ %r55 bra $L6; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,34; st.u32 [%r56],%r57; $L6: .loc 1 108 0 ld.u32 %r58,[%frame+40]; setp.eq.u32 %r59,%r58,0; @ %r59 bra $L7; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r60],%r31; $L7: .loc 1 110 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 114 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } lib_a-w_drem.o/ 0 0 0 644 1009 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: drem .visible .func (.param .f64 %value_out) drem (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_drem.c" // BEGIN GLOBAL FUNCTION DECL: remainder .extern .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: drem .visible .func (.param .f64 %value_out) drem (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 14 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),remainder,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 15 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-w_exp.o/ 0 0 0 644 4955 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: exp .visible .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_exp.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {101,120,112,0 }; // BEGIN GLOBAL FUNCTION DEF: exp .visible .func (.param .f64 %value_out) exp (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r30; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .pred %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .f64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r39,%ar0; .loc 1 88 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r41,[%value_in]; } mov.f64 %r38,%r41; .loc 1 89 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L1; .loc 1 90 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),finite,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L1; .loc 1 91 0 setp.gt.f64 %r47,%r39,0d40862e42fefa39ef; @ ! %r47 bra $L27; .loc 1 99 0 mov.u32 %r48,3; st.u32 [%frame],%r48; .loc 1 100 0 cvta.const.u64 %r49,$LC0; st.u64 [%frame+8],%r49; .loc 1 101 0 mov.u32 %r50,0; st.u32 [%frame+40],%r50; .loc 1 102 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 103 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r51,%r24,0; @ %r51 bra $L5; .loc 1 104 0 mov.f64 %r52,0d47efffffe0000000; st.f64 [%frame+32],%r52; bra $L6; $L5: .loc 1 106 0 mov.f64 %r53,0d7ff0000000000000; st.f64 [%frame+32],%r53; .loc 1 107 0 setp.ne.u32 %r54,%r24,2; @ %r54 bra $L6; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; bra $L7; $L6: .loc 1 109 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L7; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,34; st.u32 [%r60],%r61; $L7: .loc 1 112 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L8; .loc 1 113 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r30,[%frame+40]; st.u32 [%r64],%r30; $L8: .loc 1 114 0 ld.f64 %r38,[%frame+32]; bra $L1; $L27: .loc 1 115 0 setp.lt.f64 %r65,%r39,0dc0874910d52d3051; @ ! %r65 bra $L1; .loc 1 117 0 mov.u32 %r66,4; st.u32 [%frame],%r66; .loc 1 118 0 cvta.const.u64 %r67,$LC0; st.u64 [%frame+8],%r67; .loc 1 119 0 mov.u32 %r68,0; st.u32 [%frame+40],%r68; .loc 1 120 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 121 0 mov.f64 %r69,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 122 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r71,%r70,2; @ %r71 bra $L10; .loc 1 123 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L11; $L10: .loc 1 124 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L11; .loc 1 125 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L11: .loc 1 127 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L12; .loc 1 128 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r81],%r37; $L12: .loc 1 129 0 ld.f64 %r38,[%frame+32]; $L1: .loc 1 134 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } lib_a-w_exp2.o/ 0 0 0 644 918 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp2 .visible .func (.param .f64 %value_out) exp2 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_exp2.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp2 .visible .func (.param .f64 %value_out) exp2 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r23,%ar0; .loc 1 67 0 mov.f64 %r24,0d4000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r23; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 68 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } lib_a-w_fmod.o/ 0 0 0 644 4192 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: fmod .visible .func (.param .f64 %value_out) fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_fmod.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmod .extern .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {102,109,111,100,0 }; // BEGIN GLOBAL FUNCTION DEF: fmod .visible .func (.param .f64 %value_out) fmod (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r25; .reg .u32 %r32; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u16 %r55; .reg .u16 %r56; .reg .u16 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; mov.f64 %r37,%ar0; mov.f64 %r38,%ar1; .loc 1 81 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r38; call (%value_in),__ieee754_fmod,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } mov.f64 %r36,%r41; .loc 1 82 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r48,[%value_in]; } set.u32.ne.u32 %r50,%r48,0; neg.s32 %r51,%r50; .loc 1 83 0 set.u32.eq.f64 %r53,%r38,0d0000000000000000; neg.s32 %r54,%r53; cvt.u16.u32 %r56,%r51; cvt.u16.u32 %r57,%r54; and.b16 %r55,%r56,%r57; cvt.u32.u16 %r58,%r55; cvt.u16.u8 %r59,%r58; setp.eq.u16 %r60,%r59,0; @ %r60 bra $L1; .loc 1 85 0 mov.u32 %r61,1; st.u32 [%frame],%r61; .loc 1 86 0 cvta.const.u64 %r62,$LC0; st.u64 [%frame+8],%r62; .loc 1 87 0 st.f64 [%frame+16],%r37; .loc 1 88 0 st.f64 [%frame+24],%r38; .loc 1 89 0 mov.u32 %r63,0; st.u32 [%frame+40],%r63; .loc 1 90 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r64,%r25,0; @ %r64 bra $L3; .loc 1 91 0 st.f64 [%frame+32],%r37; bra $L4; $L3: .loc 1 93 0 mov.f64 %r66,0d0000000000000000; div.rn.f64 %r65,%r66,0d0000000000000000; st.f64 [%frame+32],%r65; .loc 1 94 0 setp.ne.u32 %r67,%r25,2; @ %r67 bra $L4; .loc 1 95 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L5; $L4: .loc 1 96 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r71,[%value_in]; } setp.ne.u32 %r72,%r71,0; @ %r72 bra $L5; .loc 1 97 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } mov.u32 %r74,33; st.u32 [%r73],%r74; $L5: .loc 1 99 0 ld.u32 %r75,[%frame+40]; setp.eq.u32 %r76,%r75,0; @ %r76 bra $L6; .loc 1 100 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r77],%r32; $L6: .loc 1 101 0 ld.f64 %r36,[%frame+32]; $L1: .loc 1 105 0 mov.f64 %value,%r36; st.param.f64 [%value_out],%value; ret; } lib_a-w_gamma.o/0 0 0 644 5090 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gamma .visible .func (.param .f64 %value_out) gamma (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .extern .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: gamma .visible .func (.param .f64 %value_out) gamma (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .f64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r78; .reg .pred %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .u64 %r84; mov.f64 %r40,%ar0; .loc 1 185 0 ld.global.u64 %r44,[_impure_ptr]; add.u64 %r43,%r44,224; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; call (%value_in),__ieee754_gamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r45,[%value_in]; } mov.f64 %r39,%r45; .loc 1 186 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L1; .loc 1 187 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r45; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.ne.u32 %r50,%r49,0; @ %r50 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } setp.eq.u32 %r53,%r52,0; @ %r53 bra $L1; .loc 1 194 0 cvta.const.u64 %r54,$LC0; st.u64 [%frame+8],%r54; .loc 1 195 0 st.u32 [%frame+40],%r49; .loc 1 196 0 st.f64 [%frame+24],%r40; st.f64 [%frame+16],%r40; .loc 1 197 0 ld.global.u32 %r56,[__fdlib_version]; setp.ne.u32 %r57,%r56,0; @ %r57 bra $L3; .loc 1 198 0 mov.f64 %r58,0d47efffffe0000000; st.f64 [%frame+32],%r58; bra $L4; $L3: .loc 1 200 0 mov.f64 %r59,0d7ff0000000000000; st.f64 [%frame+32],%r59; $L4: .loc 1 201 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),floor,(%out_arg1); ld.param.f64 %r61,[%value_in]; } setp.neu.f64 %r62,%r61,%r40; @ %r62 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f64 %r63,%r40,0d0000000000000000; @ ! %r63 bra $L6; .loc 1 203 0 mov.u32 %r64,2; st.u32 [%frame],%r64; .loc 1 204 0 setp.ne.u32 %r65,%r38,2; @ %r65 bra $L8; .loc 1 205 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } mov.u32 %r67,33; st.u32 [%r66],%r67; bra $L9; $L8: .loc 1 206 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r69,[%value_in]; } setp.eq.u32 %r70,%r69,0; @ ! %r70 bra $L9; .loc 1 207 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } mov.u32 %r72,33; st.u32 [%r71],%r72; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 211 0 mov.u32 %r73,3; st.u32 [%frame],%r73; .loc 1 212 0 setp.ne.u32 %r74,%r38,2; @ %r74 bra $L11; .loc 1 213 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,34; st.u32 [%r75],%r76; bra $L9; $L11: .loc 1 214 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r78,[%value_in]; } setp.ne.u32 %r79,%r78,0; @ %r79 bra $L9; .loc 1 215 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r80,[%value_in]; } mov.u32 %r81,34; st.u32 [%r80],%r81; $L9: .loc 1 218 0 ld.u32 %r82,[%frame+40]; setp.eq.u32 %r83,%r82,0; @ %r83 bra $L13; .loc 1 219 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r84,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r84],%r37; $L13: .loc 1 220 0 ld.f64 %r39,[%frame+32]; $L1: .loc 1 224 0 mov.f64 %value,%r39; st.param.f64 [%value_out],%value; ret; } lib_a-w_hypot.o/0 0 0 644 3990 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: hypot .visible .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_hypot.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypot .extern .func (.param .f64 %value_out) __ieee754_hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {104,121,112,111,116,0 }; // BEGIN GLOBAL FUNCTION DEF: hypot .visible .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r26; .reg .u32 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r50; .reg .u64 %r51; .reg .pred %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; mov.f64 %r34,%ar0; mov.f64 %r35,%ar1; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; call (%value_in),__ieee754_hypot,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } mov.f64 %r33,%r38; .loc 1 78 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; .loc 1 79 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),finite,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.ne.u32 %r43,%r42,0; @ %r43 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),finite,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),finite,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,0; @ %r49 bra $L1; .loc 1 87 0 mov.u32 %r50,3; st.u32 [%frame],%r50; .loc 1 88 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 89 0 st.u32 [%frame+40],%r42; .loc 1 90 0 st.f64 [%frame+16],%r34; .loc 1 91 0 st.f64 [%frame+24],%r35; .loc 1 92 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r53,%r26,0; @ %r53 bra $L3; .loc 1 93 0 mov.f64 %r54,0d47efffffe0000000; st.f64 [%frame+32],%r54; bra $L4; $L3: .loc 1 95 0 mov.f64 %r55,0d7ff0000000000000; st.f64 [%frame+32],%r55; .loc 1 96 0 setp.ne.u32 %r56,%r26,2; @ %r56 bra $L4; .loc 1 97 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; bra $L5; $L4: .loc 1 98 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r60,[%value_in]; } setp.ne.u32 %r61,%r60,0; @ %r61 bra $L5; .loc 1 99 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } mov.u32 %r63,34; st.u32 [%r62],%r63; $L5: .loc 1 101 0 ld.u32 %r64,[%frame+40]; setp.eq.u32 %r65,%r64,0; @ %r65 bra $L6; .loc 1 102 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r66],%r32; $L6: .loc 1 103 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 107 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } lib_a-w_j0.o/ 0 0 0 644 7960 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j0 .visible .func (.param .f64 %value_out) j0 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_j0.c" // BEGIN GLOBAL FUNCTION DECL: y0 .visible .func (.param .f64 %value_out) y0 (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0 .extern .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0 .extern .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {106,48,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[3] = {121,48,0 }; // BEGIN GLOBAL FUNCTION DEF: j0 .visible .func (.param .f64 %value_out) j0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .f64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .f64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; mov.f64 %r33,%ar0; .loc 1 141 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 142 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 143 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r42,[%value_in]; } setp.gt.f64 %r43,%r42,0d434921fb54442d18; @ ! %r43 bra $L1; .loc 1 145 0 mov.u32 %r44,5; st.u32 [%frame],%r44; .loc 1 146 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 147 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 148 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 149 0 mov.f64 %r47,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 150 0 ld.global.u32 %r48,[__fdlib_version]; setp.ne.u32 %r49,%r48,2; @ %r49 bra $L4; .loc 1 151 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r50,[%value_in]; } mov.u32 %r51,34; st.u32 [%r50],%r51; bra $L5; $L4: .loc 1 152 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.ne.u32 %r54,%r53,0; @ %r54 bra $L5; .loc 1 153 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; $L5: .loc 1 155 0 ld.u32 %r57,[%frame+40]; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L6; .loc 1 156 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r59],%r31; $L6: .loc 1 157 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 161 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y0 .visible .func (.param .f64 %value_out) y0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r30; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .pred %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .f64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r39,%ar0; .loc 1 175 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__ieee754_y0,(%out_arg1); ld.param.f64 %r41,[%value_in]; } mov.f64 %r38,%r41; .loc 1 176 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L17; .loc 1 177 0 setp.le.f64 %r47,%r39,0d0000000000000000; @ ! %r47 bra $L43; .loc 1 185 0 mov.u32 %r48,1; st.u32 [%frame],%r48; .loc 1 186 0 cvta.const.u64 %r49,$LC1; st.u64 [%frame+8],%r49; .loc 1 187 0 mov.u32 %r50,0; st.u32 [%frame+40],%r50; .loc 1 188 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 189 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r51,%r24,0; @ %r51 bra $L21; .loc 1 190 0 mov.f64 %r52,0dc7efffffe0000000; st.f64 [%frame+32],%r52; bra $L22; $L21: .loc 1 192 0 mov.f64 %r53,0dfff0000000000000; st.f64 [%frame+32],%r53; .loc 1 193 0 setp.ne.u32 %r54,%r24,2; @ %r54 bra $L22; .loc 1 194 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,33; st.u32 [%r55],%r56; bra $L23; $L22: .loc 1 195 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L23; .loc 1 196 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,33; st.u32 [%r60],%r61; $L23: .loc 1 198 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L24; .loc 1 199 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r30,[%frame+40]; st.u32 [%r64],%r30; $L24: .loc 1 200 0 ld.f64 %r38,[%frame+32]; bra $L17; $L43: .loc 1 202 0 setp.gt.f64 %r65,%r39,0d434921fb54442d18; @ ! %r65 bra $L17; .loc 1 204 0 mov.u32 %r66,5; st.u32 [%frame],%r66; .loc 1 205 0 cvta.const.u64 %r67,$LC1; st.u64 [%frame+8],%r67; .loc 1 206 0 mov.u32 %r68,0; st.u32 [%frame+40],%r68; .loc 1 207 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 208 0 mov.f64 %r69,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 209 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r71,%r70,2; @ %r71 bra $L26; .loc 1 210 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L27; $L26: .loc 1 211 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L27; .loc 1 212 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L27: .loc 1 214 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L28; .loc 1 215 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r81],%r37; $L28: .loc 1 216 0 ld.f64 %r38,[%frame+32]; $L17: .loc 1 220 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } lib_a-w_j1.o/ 0 0 0 644 7924 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j1 .visible .func (.param .f64 %value_out) j1 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_j1.c" // BEGIN GLOBAL FUNCTION DECL: y1 .visible .func (.param .f64 %value_out) y1 (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1 .extern .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1 .extern .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {106,49,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[3] = {121,49,0 }; // BEGIN GLOBAL FUNCTION DEF: j1 .visible .func (.param .f64 %value_out) j1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .f64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .f64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; mov.f64 %r33,%ar0; .loc 1 35 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 36 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 37 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r42,[%value_in]; } setp.gt.f64 %r43,%r42,0d434921fb54442d18; @ ! %r43 bra $L1; .loc 1 39 0 mov.u32 %r44,5; st.u32 [%frame],%r44; .loc 1 40 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 41 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 42 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 43 0 mov.f64 %r47,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 44 0 ld.global.u32 %r48,[__fdlib_version]; setp.ne.u32 %r49,%r48,2; @ %r49 bra $L4; .loc 1 45 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r50,[%value_in]; } mov.u32 %r51,34; st.u32 [%r50],%r51; bra $L5; $L4: .loc 1 46 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.ne.u32 %r54,%r53,0; @ %r54 bra $L5; .loc 1 47 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; $L5: .loc 1 49 0 ld.u32 %r57,[%frame+40]; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L6; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r59],%r31; $L6: .loc 1 51 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 55 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y1 .visible .func (.param .f64 %value_out) y1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r30; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .pred %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .f64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r39,%ar0; .loc 1 69 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__ieee754_y1,(%out_arg1); ld.param.f64 %r41,[%value_in]; } mov.f64 %r38,%r41; .loc 1 70 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L17; .loc 1 71 0 setp.le.f64 %r47,%r39,0d0000000000000000; @ ! %r47 bra $L43; .loc 1 79 0 mov.u32 %r48,1; st.u32 [%frame],%r48; .loc 1 80 0 cvta.const.u64 %r49,$LC1; st.u64 [%frame+8],%r49; .loc 1 81 0 mov.u32 %r50,0; st.u32 [%frame+40],%r50; .loc 1 82 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 83 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r51,%r24,0; @ %r51 bra $L21; .loc 1 84 0 mov.f64 %r52,0dc7efffffe0000000; st.f64 [%frame+32],%r52; bra $L22; $L21: .loc 1 86 0 mov.f64 %r53,0dfff0000000000000; st.f64 [%frame+32],%r53; .loc 1 87 0 setp.ne.u32 %r54,%r24,2; @ %r54 bra $L22; .loc 1 88 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,33; st.u32 [%r55],%r56; bra $L23; $L22: .loc 1 89 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L23; .loc 1 90 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,33; st.u32 [%r60],%r61; $L23: .loc 1 92 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L24; .loc 1 93 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r30,[%frame+40]; st.u32 [%r64],%r30; $L24: .loc 1 94 0 ld.f64 %r38,[%frame+32]; bra $L17; $L43: .loc 1 96 0 setp.gt.f64 %r65,%r39,0d434921fb54442d18; @ ! %r65 bra $L17; .loc 1 98 0 mov.u32 %r66,5; st.u32 [%frame],%r66; .loc 1 99 0 cvta.const.u64 %r67,$LC1; st.u64 [%frame+8],%r67; .loc 1 100 0 mov.u32 %r68,0; st.u32 [%frame+40],%r68; .loc 1 101 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 102 0 mov.f64 %r69,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 103 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r71,%r70,2; @ %r71 bra $L26; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L27; $L26: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L27; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L27: .loc 1 108 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L28; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r81],%r37; $L28: .loc 1 110 0 ld.f64 %r38,[%frame+32]; $L17: .loc 1 114 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } lib_a-w_jn.o/ 0 0 0 644 8521 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: jn .visible .func (.param .f64 %value_out) jn (.param .u32 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_jn.c" // BEGIN GLOBAL FUNCTION DECL: yn .visible .func (.param .f64 %value_out) yn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_jn .extern .func (.param .f64 %value_out) __ieee754_jn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_yn .extern .func (.param .f64 %value_out) __ieee754_yn (.param .u32 %in_ar0, .param .f64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {106,110,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[3] = {121,110,0 }; // BEGIN GLOBAL FUNCTION DEF: jn .visible .func (.param .f64 %value_out) jn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r32; .reg .f64 %r33; .reg .u32 %r34; .reg .f64 %r35; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .f64 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u32 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; mov.u32 %r34,%ar0; mov.f64 %r35,%ar1; .loc 1 57 0 { .param .f64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r34; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; call (%value_in),__ieee754_jn,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } mov.f64 %r33,%r38; .loc 1 58 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 59 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r45,[%value_in]; } setp.gt.f64 %r46,%r45,0d434921fb54442d18; @ ! %r46 bra $L1; .loc 1 61 0 mov.u32 %r47,5; st.u32 [%frame],%r47; .loc 1 62 0 cvta.const.u64 %r48,$LC0; st.u64 [%frame+8],%r48; .loc 1 63 0 mov.u32 %r49,0; st.u32 [%frame+40],%r49; .loc 1 64 0 cvt.rn.f64.s32 %r50,%r34; st.f64 [%frame+16],%r50; .loc 1 65 0 st.f64 [%frame+24],%r35; .loc 1 66 0 mov.f64 %r51,0d0000000000000000; st.f64 [%frame+32],%r51; .loc 1 67 0 ld.global.u32 %r52,[__fdlib_version]; setp.ne.u32 %r53,%r52,2; @ %r53 bra $L4; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,34; st.u32 [%r54],%r55; bra $L5; $L4: .loc 1 69 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L5; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; $L5: .loc 1 72 0 ld.u32 %r61,[%frame+40]; setp.eq.u32 %r62,%r61,0; @ %r62 bra $L6; .loc 1 73 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r63],%r32; $L6: .loc 1 74 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 78 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: yn .visible .func (.param .f64 %value_out) yn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r25; .reg .u32 %r31; .reg .u32 %r39; .reg .f64 %r40; .reg .u32 %r41; .reg .f64 %r42; .reg .f64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .f64 %r55; .reg .pred %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .u64 %r87; mov.u32 %r41,%ar0; mov.f64 %r42,%ar1; .loc 1 92 0 { .param .f64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r41; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r42; call (%value_in),__ieee754_yn,(%out_arg1,%out_arg2); ld.param.f64 %r45,[%value_in]; } mov.f64 %r40,%r45; .loc 1 93 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L17; .loc 1 94 0 setp.le.f64 %r51,%r42,0d0000000000000000; @ ! %r51 bra $L43; .loc 1 102 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 103 0 cvta.const.u64 %r53,$LC1; st.u64 [%frame+8],%r53; .loc 1 104 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 105 0 cvt.rn.f64.s32 %r55,%r41; st.f64 [%frame+16],%r55; .loc 1 106 0 st.f64 [%frame+24],%r42; .loc 1 107 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r56,%r25,0; @ %r56 bra $L21; .loc 1 108 0 mov.f64 %r57,0dc7efffffe0000000; st.f64 [%frame+32],%r57; bra $L22; $L21: .loc 1 110 0 mov.f64 %r58,0dfff0000000000000; st.f64 [%frame+32],%r58; .loc 1 111 0 setp.ne.u32 %r59,%r25,2; @ %r59 bra $L22; .loc 1 112 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,33; st.u32 [%r60],%r61; bra $L23; $L22: .loc 1 113 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r63,[%value_in]; } setp.ne.u32 %r64,%r63,0; @ %r64 bra $L23; .loc 1 114 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; $L23: .loc 1 116 0 ld.u32 %r67,[%frame+40]; setp.eq.u32 %r68,%r67,0; @ %r68 bra $L24; .loc 1 117 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r69,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r69],%r31; $L24: .loc 1 118 0 ld.f64 %r40,[%frame+32]; bra $L17; $L43: .loc 1 120 0 setp.gt.f64 %r70,%r42,0d434921fb54442d18; @ ! %r70 bra $L17; .loc 1 122 0 mov.u32 %r71,5; st.u32 [%frame],%r71; .loc 1 123 0 cvta.const.u64 %r72,$LC1; st.u64 [%frame+8],%r72; .loc 1 124 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 125 0 cvt.rn.f64.s32 %r74,%r41; st.f64 [%frame+16],%r74; .loc 1 126 0 st.f64 [%frame+24],%r42; .loc 1 127 0 mov.f64 %r75,0d0000000000000000; st.f64 [%frame+32],%r75; .loc 1 128 0 ld.global.u32 %r76,[__fdlib_version]; setp.ne.u32 %r77,%r76,2; @ %r77 bra $L26; .loc 1 129 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r78,[%value_in]; } mov.u32 %r79,34; st.u32 [%r78],%r79; bra $L27; $L26: .loc 1 130 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r81,[%value_in]; } setp.ne.u32 %r82,%r81,0; @ %r82 bra $L27; .loc 1 131 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } mov.u32 %r84,34; st.u32 [%r83],%r84; $L27: .loc 1 133 0 ld.u32 %r85,[%frame+40]; setp.eq.u32 %r86,%r85,0; @ %r86 bra $L28; .loc 1 134 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r87,[%value_in]; } ld.u32 %r39,[%frame+40]; st.u32 [%r87],%r39; $L28: .loc 1 135 0 ld.f64 %r40,[%frame+32]; $L17: .loc 1 139 0 mov.f64 %value,%r40; st.param.f64 [%value_out],%value; ret; } /1403 0 0 0 644 5090 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgamma .visible .func (.param .f64 %value_out) lgamma (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .extern .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {108,103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: lgamma .visible .func (.param .f64 %value_out) lgamma (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .f64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r78; .reg .pred %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .u64 %r84; mov.f64 %r40,%ar0; .loc 1 39 0 ld.global.u64 %r44,[_impure_ptr]; add.u64 %r43,%r44,224; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; call (%value_in),__ieee754_lgamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r45,[%value_in]; } mov.f64 %r39,%r45; .loc 1 40 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L1; .loc 1 41 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r45; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.ne.u32 %r50,%r49,0; @ %r50 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } setp.eq.u32 %r53,%r52,0; @ %r53 bra $L1; .loc 1 48 0 cvta.const.u64 %r54,$LC0; st.u64 [%frame+8],%r54; .loc 1 49 0 st.u32 [%frame+40],%r49; .loc 1 50 0 st.f64 [%frame+16],%r40; .loc 1 51 0 st.f64 [%frame+24],%r40; .loc 1 52 0 ld.global.u32 %r56,[__fdlib_version]; setp.ne.u32 %r57,%r56,0; @ %r57 bra $L3; .loc 1 53 0 mov.f64 %r58,0d47efffffe0000000; st.f64 [%frame+32],%r58; bra $L4; $L3: .loc 1 55 0 mov.f64 %r59,0d7ff0000000000000; st.f64 [%frame+32],%r59; $L4: .loc 1 56 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),floor,(%out_arg1); ld.param.f64 %r61,[%value_in]; } setp.neu.f64 %r62,%r61,%r40; @ %r62 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f64 %r63,%r40,0d0000000000000000; @ ! %r63 bra $L6; .loc 1 58 0 mov.u32 %r64,2; st.u32 [%frame],%r64; .loc 1 59 0 setp.ne.u32 %r65,%r38,2; @ %r65 bra $L8; .loc 1 60 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } mov.u32 %r67,33; st.u32 [%r66],%r67; bra $L9; $L8: .loc 1 61 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r69,[%value_in]; } setp.eq.u32 %r70,%r69,0; @ ! %r70 bra $L9; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } mov.u32 %r72,33; st.u32 [%r71],%r72; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 67 0 mov.u32 %r73,3; st.u32 [%frame],%r73; .loc 1 68 0 setp.ne.u32 %r74,%r38,2; @ %r74 bra $L11; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,34; st.u32 [%r75],%r76; bra $L9; $L11: .loc 1 70 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r78,[%value_in]; } setp.ne.u32 %r79,%r78,0; @ %r79 bra $L9; .loc 1 71 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r80,[%value_in]; } mov.u32 %r81,34; st.u32 [%r80],%r81; $L9: .loc 1 74 0 ld.u32 %r82,[%frame+40]; setp.eq.u32 %r83,%r82,0; @ %r83 bra $L13; .loc 1 75 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r84,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r84],%r37; $L13: .loc 1 76 0 ld.f64 %r39,[%frame+32]; $L1: .loc 1 80 0 mov.f64 %value,%r39; st.param.f64 [%value_out],%value; ret; } lib_a-w_log.o/ 0 0 0 644 4925 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: log .visible .func (.param .f64 %value_out) log (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_log.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {108,111,103,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: log .visible .func (.param .f64 %value_out) log (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u64 %r70; .reg .f64 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r76; .reg .u32 %r77; mov.f64 %r36,%ar0; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r38,[%value_in]; } mov.f64 %r35,%r38; .loc 1 77 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; setp.gt.f64 %r44,%r36,0d0000000000000000; @ %r44 bra $L1; .loc 1 84 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 85 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 86 0 st.f64 [%frame+16],%r36; .loc 1 87 0 st.f64 [%frame+24],%r36; .loc 1 88 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r47,%r24,0; @ %r47 bra $L3; .loc 1 89 0 mov.f64 %r48,0dc7efffffe0000000; st.f64 [%frame+32],%r48; .loc 1 92 0 setp.eq.f64 %r49,%r36,0d0000000000000000; @ %r49 bra $L4; bra $L21; $L3: .loc 1 91 0 mov.f64 %r50,0dfff0000000000000; st.f64 [%frame+32],%r50; .loc 1 92 0 setp.neu.f64 %r51,%r36,0d0000000000000000; @ %r51 bra $L6; .loc 1 94 0 mov.u32 %r52,2; st.u32 [%frame],%r52; .loc 1 95 0 setp.ne.u32 %r53,%r24,2; @ %r53 bra $L7; .loc 1 96 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,34; st.u32 [%r54],%r55; bra $L8; $L7: .loc 1 97 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L8; .loc 1 98 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; bra $L8; $L6: .loc 1 102 0 mov.u32 %r61,1; st.u32 [%frame],%r61; .loc 1 103 0 setp.ne.u32 %r62,%r24,2; @ %r62 bra $L9; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L10; $L9: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.ne.u32 %r67,%r66,0; @ %r67 bra $L10; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; $L10: .loc 1 108 0 cvta.const.u64 %r70,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; call (%value_in),nan,(%out_arg1); ld.param.f64 %r71,[%value_in]; } st.f64 [%frame+32],%r71; $L8: .loc 1 110 0 ld.u32 %r72,[%frame+40]; setp.eq.u32 %r73,%r72,0; @ %r73 bra $L11; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r74],%r34; $L11: .loc 1 112 0 ld.f64 %r35,[%frame+32]; bra $L1; $L4: .loc 1 94 0 mov.u32 %r76,2; st.u32 [%frame],%r76; bra $L7; $L21: .loc 1 102 0 mov.u32 %r77,1; st.u32 [%frame],%r77; bra $L9; $L1: .loc 1 114 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-w_log10.o/0 0 0 644 4964 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: log10 .visible .func (.param .f64 %value_out) log10 (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_log10.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10 .extern .func (.param .f64 %value_out) __ieee754_log10 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {108,111,103,49,48,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: log10 .visible .func (.param .f64 %value_out) log10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u64 %r70; .reg .f64 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r76; .reg .u32 %r77; mov.f64 %r36,%ar0; .loc 1 73 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__ieee754_log10,(%out_arg1); ld.param.f64 %r38,[%value_in]; } mov.f64 %r35,%r38; .loc 1 74 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 75 0 setp.le.f64 %r44,%r36,0d0000000000000000; @ ! %r44 bra $L1; .loc 1 82 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 83 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 84 0 st.f64 [%frame+16],%r36; .loc 1 85 0 st.f64 [%frame+24],%r36; .loc 1 86 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r47,%r24,0; @ %r47 bra $L4; .loc 1 87 0 mov.f64 %r48,0dc7efffffe0000000; st.f64 [%frame+32],%r48; .loc 1 90 0 setp.eq.f64 %r49,%r36,0d0000000000000000; @ %r49 bra $L5; bra $L23; $L4: .loc 1 89 0 mov.f64 %r50,0dfff0000000000000; st.f64 [%frame+32],%r50; .loc 1 90 0 setp.neu.f64 %r51,%r36,0d0000000000000000; @ %r51 bra $L7; .loc 1 92 0 mov.u32 %r52,2; st.u32 [%frame],%r52; .loc 1 93 0 setp.ne.u32 %r53,%r24,2; @ %r53 bra $L8; .loc 1 94 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,34; st.u32 [%r54],%r55; bra $L9; $L8: .loc 1 95 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L9; .loc 1 96 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; bra $L9; $L7: .loc 1 100 0 mov.u32 %r61,1; st.u32 [%frame],%r61; .loc 1 101 0 setp.ne.u32 %r62,%r24,2; @ %r62 bra $L10; .loc 1 102 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L11; $L10: .loc 1 103 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.ne.u32 %r67,%r66,0; @ %r67 bra $L11; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; $L11: .loc 1 106 0 cvta.const.u64 %r70,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; call (%value_in),nan,(%out_arg1); ld.param.f64 %r71,[%value_in]; } st.f64 [%frame+32],%r71; $L9: .loc 1 108 0 ld.u32 %r72,[%frame+40]; setp.eq.u32 %r73,%r72,0; @ %r73 bra $L12; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r74],%r34; $L12: .loc 1 110 0 ld.f64 %r35,[%frame+32]; bra $L1; $L5: .loc 1 92 0 mov.u32 %r76,2; st.u32 [%frame],%r76; bra $L8; $L23: .loc 1 100 0 mov.u32 %r77,1; st.u32 [%frame],%r77; bra $L10; $L1: .loc 1 114 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-w_pow.o/ 0 0 0 644 15142 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: pow .visible .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_pow.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_pow .extern .func (.param .f64 %value_out) __ieee754_pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {112,111,119,0 }; // BEGIN GLOBAL FUNCTION DEF: pow .visible .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r32; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r46; .reg .u32 %r51; .reg .u32 %r58; .reg .u32 %r68; .reg .u32 %r77; .reg .u32 %r78; .reg .f64 %r79; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r82; .reg .f64 %r85; .reg .u32 %r86; .reg .pred %r87; .reg .u32 %r89; .reg .pred %r90; .reg .u32 %r92; .reg .pred %r93; .reg .pred %r94; .reg .u32 %r95; .reg .u64 %r96; .reg .f64 %r98; .reg .u32 %r100; .reg .u32 %r101; .reg .u32 %r103; .reg .u32 %r104; .reg .u16 %r105; .reg .u16 %r106; .reg .u16 %r107; .reg .u32 %r108; .reg .u16 %r109; .reg .pred %r110; .reg .u32 %r112; .reg .pred %r113; .reg .u64 %r114; .reg .u32 %r115; .reg .u32 %r116; .reg .pred %r117; .reg .u64 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u32 %r121; .reg .u64 %r122; .reg .u32 %r123; .reg .f64 %r124; .reg .u32 %r125; .reg .pred %r126; .reg .u32 %r128; .reg .pred %r129; .reg .u64 %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .pred %r133; .reg .u64 %r134; .reg .u32 %r136; .reg .pred %r137; .reg .pred %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .pred %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .pred %r145; .reg .u64 %r146; .reg .u32 %r147; .reg .u32 %r149; .reg .pred %r150; .reg .u64 %r151; .reg .u32 %r152; .reg .u32 %r153; .reg .pred %r154; .reg .u64 %r155; .reg .u32 %r157; .reg .pred %r158; .reg .u32 %r160; .reg .pred %r161; .reg .u32 %r163; .reg .pred %r164; .reg .u32 %r166; .reg .pred %r167; .reg .u32 %r168; .reg .u64 %r169; .reg .pred %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .f64 %r174; .reg .pred %r175; .reg .u64 %r176; .reg .u32 %r177; .reg .u32 %r179; .reg .pred %r180; .reg .u64 %r181; .reg .u32 %r182; .reg .u32 %r183; .reg .pred %r184; .reg .u64 %r185; .reg .u32 %r186; .reg .u64 %r187; .reg .pred %r190; .reg .f64 %r191; .reg .pred %r192; .reg .f64 %r194; .reg .pred %r195; .reg .f64 %r196; .reg .f64 %r197; .reg .pred %r198; .reg .f64 %r200; .reg .pred %r201; .reg .f64 %r202; .reg .pred %r204; .reg .u64 %r205; .reg .u32 %r206; .reg .u32 %r208; .reg .pred %r209; .reg .u64 %r210; .reg .u32 %r211; .reg .u32 %r212; .reg .pred %r213; .reg .u64 %r214; .reg .pred %r215; .reg .u32 %r217; .reg .pred %r218; .reg .u32 %r220; .reg .pred %r221; .reg .u32 %r222; .reg .u64 %r223; .reg .u32 %r224; .reg .f64 %r225; .reg .u32 %r226; .reg .pred %r227; .reg .u64 %r228; .reg .u32 %r229; .reg .u32 %r231; .reg .pred %r232; .reg .u64 %r233; .reg .u32 %r234; .reg .u32 %r235; .reg .pred %r236; .reg .u64 %r237; .reg .u32 %r239; mov.f64 %r81,%ar0; mov.f64 %r82,%ar1; .loc 1 85 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r82; call (%value_in),__ieee754_pow,(%out_arg1,%out_arg2); ld.param.f64 %r85,[%value_in]; } mov.f64 %r80,%r85; .loc 1 86 0 ld.global.u32 %r86,[__fdlib_version]; setp.eq.u32 %r87,%r86,-1; @ %r87 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r89,[%value_in]; } setp.eq.u32 %r90,%r89,0; @ %r90 bra $L1; .loc 1 87 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r92,[%value_in]; } setp.ne.u32 %r93,%r92,0; @ %r93 bra $L3; .loc 1 88 0 setp.neu.f64 %r94,%r82,0d0000000000000000; @ %r94 bra $L1; .loc 1 91 0 mov.u32 %r95,1; st.u32 [%frame],%r95; .loc 1 92 0 cvta.const.u64 %r96,$LC0; st.u64 [%frame+8],%r96; .loc 1 93 0 st.u32 [%frame+40],%r92; .loc 1 94 0 st.f64 [%frame+16],%r81; .loc 1 95 0 st.f64 [%frame+24],%r82; .loc 1 96 0 mov.f64 %r98,0d3ff0000000000000; st.f64 [%frame+32],%r98; .loc 1 97 0 ld.global.u32 %r78,[__fdlib_version]; set.u32.eq.u32 %r100,%r78,-1; neg.s32 %r101,%r100; set.u32.eq.u32 %r103,%r78,2; neg.s32 %r104,%r103; cvt.u16.u32 %r106,%r101; cvt.u16.u32 %r107,%r104; or.b16 %r105,%r106,%r107; cvt.u32.u16 %r108,%r105; cvt.u16.u8 %r109,%r108; setp.ne.u16 %r110,%r109,0; @ %r110 bra $L35; .loc 1 99 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r112,[%value_in]; } setp.ne.u32 %r113,%r112,0; @ %r113 bra $L5; .loc 1 100 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r114,[%value_in]; } mov.u32 %r115,33; st.u32 [%r114],%r115; $L5: .loc 1 102 0 ld.u32 %r116,[%frame+40]; setp.ne.u32 %r117,%r116,0; @ %r117 bra $L6; ld.f64 %r80,[%frame+32]; bra $L1; $L6: .loc 1 103 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r118,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r118],%r32; ld.f64 %r80,[%frame+32]; bra $L1; $L35: mov.f64 %r80,%r98; .loc 1 104 0 bra $L1; $L3: .loc 1 108 0 setp.neu.f64 %r119,%r81,0d0000000000000000; @ %r119 bra $L7; .loc 1 109 0 setp.neu.f64 %r120,%r82,0d0000000000000000; @ %r120 bra $L8; .loc 1 112 0 mov.u32 %r121,1; st.u32 [%frame],%r121; .loc 1 113 0 cvta.const.u64 %r122,$LC0; st.u64 [%frame+8],%r122; .loc 1 114 0 mov.u32 %r123,0; st.u32 [%frame+40],%r123; .loc 1 115 0 st.f64 [%frame+16],%r81; .loc 1 116 0 st.f64 [%frame+24],%r82; .loc 1 117 0 mov.f64 %r124,0d0000000000000000; st.f64 [%frame+32],%r124; .loc 1 118 0 ld.global.u32 %r125,[__fdlib_version]; setp.ne.u32 %r126,%r125,0; @ %r126 bra $L36; .loc 1 119 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r128,[%value_in]; } setp.ne.u32 %r129,%r128,0; @ %r129 bra $L10; .loc 1 120 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r130,[%value_in]; } mov.u32 %r131,33; st.u32 [%r130],%r131; $L10: .loc 1 122 0 ld.u32 %r132,[%frame+40]; setp.ne.u32 %r133,%r132,0; @ %r133 bra $L11; ld.f64 %r80,[%frame+32]; bra $L1; $L11: .loc 1 123 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r134,[%value_in]; } ld.u32 %r38,[%frame+40]; st.u32 [%r134],%r38; ld.f64 %r80,[%frame+32]; bra $L1; $L36: mov.f64 %r80,0d3ff0000000000000; .loc 1 124 0 bra $L1; $L8: .loc 1 126 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),finite,(%out_arg1); ld.param.u32 %r136,[%value_in]; } setp.eq.u32 %r137,%r136,0; @ %r137 bra $L1; setp.lt.f64 %r138,%r82,0d0000000000000000; @ ! %r138 bra $L1; .loc 1 128 0 mov.u32 %r139,1; st.u32 [%frame],%r139; .loc 1 129 0 cvta.const.u64 %r140,$LC0; st.u64 [%frame+8],%r140; .loc 1 130 0 mov.u32 %r141,0; st.u32 [%frame+40],%r141; .loc 1 131 0 st.f64 [%frame+16],%r81; .loc 1 132 0 st.f64 [%frame+24],%r82; .loc 1 133 0 ld.global.u32 %r40,[__fdlib_version]; setp.ne.u32 %r142,%r40,0; @ %r142 bra $L13; .loc 1 134 0 mov.f64 %r143,0d0000000000000000; st.f64 [%frame+32],%r143; bra $L14; $L13: .loc 1 136 0 mov.f64 %r144,0dfff0000000000000; st.f64 [%frame+32],%r144; .loc 1 137 0 setp.ne.u32 %r145,%r40,2; @ %r145 bra $L14; .loc 1 138 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r146,[%value_in]; } mov.u32 %r147,33; st.u32 [%r146],%r147; bra $L15; $L14: .loc 1 139 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r149,[%value_in]; } setp.ne.u32 %r150,%r149,0; @ %r150 bra $L15; .loc 1 140 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r151,[%value_in]; } mov.u32 %r152,33; st.u32 [%r151],%r152; $L15: .loc 1 142 0 ld.u32 %r153,[%frame+40]; setp.eq.u32 %r154,%r153,0; @ %r154 bra $L16; .loc 1 143 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r155,[%value_in]; } ld.u32 %r46,[%frame+40]; st.u32 [%r155],%r46; $L16: .loc 1 144 0 ld.f64 %r80,[%frame+32]; bra $L1; $L7: .loc 1 148 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r85; call (%value_in),finite,(%out_arg1); ld.param.u32 %r157,[%value_in]; } setp.ne.u32 %r158,%r157,0; @ %r158 bra $L17; .loc 1 149 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),finite,(%out_arg1); ld.param.u32 %r160,[%value_in]; } setp.eq.u32 %r161,%r160,0; @ %r161 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),finite,(%out_arg1); ld.param.u32 %r163,[%value_in]; } setp.eq.u32 %r164,%r163,0; @ %r164 bra $L17; .loc 1 150 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r85; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r166,[%value_in]; } setp.ne.u32 %r167,%r166,0; @ %r167 bra $L18; .loc 1 152 0 mov.u32 %r168,1; st.u32 [%frame],%r168; .loc 1 153 0 cvta.const.u64 %r169,$LC0; st.u64 [%frame+8],%r169; .loc 1 154 0 st.u32 [%frame+40],%r166; .loc 1 155 0 st.f64 [%frame+16],%r81; .loc 1 156 0 st.f64 [%frame+24],%r82; .loc 1 157 0 ld.global.u32 %r51,[__fdlib_version]; setp.ne.u32 %r171,%r51,0; @ %r171 bra $L19; .loc 1 158 0 mov.f64 %r172,0d0000000000000000; st.f64 [%frame+32],%r172; bra $L20; $L19: .loc 1 160 0 mov.f64 %r174,0d0000000000000000; div.rn.f64 %r173,%r174,0d0000000000000000; st.f64 [%frame+32],%r173; .loc 1 161 0 setp.ne.u32 %r175,%r51,2; @ %r175 bra $L20; .loc 1 162 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r176,[%value_in]; } mov.u32 %r177,33; st.u32 [%r176],%r177; bra $L21; $L20: .loc 1 163 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r179,[%value_in]; } setp.ne.u32 %r180,%r179,0; @ %r180 bra $L21; .loc 1 164 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r181,[%value_in]; } mov.u32 %r182,33; st.u32 [%r181],%r182; $L21: .loc 1 166 0 ld.u32 %r183,[%frame+40]; setp.eq.u32 %r184,%r183,0; @ %r184 bra $L22; .loc 1 167 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r185,[%value_in]; } ld.u32 %r58,[%frame+40]; st.u32 [%r185],%r58; $L22: .loc 1 168 0 ld.f64 %r80,[%frame+32]; bra $L1; $L18: .loc 1 171 0 mov.u32 %r186,3; st.u32 [%frame],%r186; .loc 1 172 0 cvta.const.u64 %r187,$LC0; st.u64 [%frame+8],%r187; .loc 1 173 0 st.u32 [%frame+40],%r157; .loc 1 174 0 st.f64 [%frame+16],%r81; .loc 1 175 0 st.f64 [%frame+24],%r82; mul.f64 %r79,%r82,0d3fe0000000000000; .loc 1 176 0 ld.global.u32 %r239,[__fdlib_version]; setp.ne.u32 %r190,%r239,0; @ %r190 bra $L23; .loc 1 177 0 mov.f64 %r191,0d47efffffe0000000; st.f64 [%frame+32],%r191; .loc 1 179 0 setp.lt.f64 %r192,%r81,0d0000000000000000; @ ! %r192 bra $L24; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r79; call (%value_in),rint,(%out_arg1); ld.param.f64 %r194,[%value_in]; } setp.neu.f64 %r195,%r194,%r79; @ %r195 bra $L26; ld.global.u32 %r239,[__fdlib_version]; bra $L27; $L26: mov.f64 %r196,0dc7efffffe0000000; st.f64 [%frame+32],%r196; ld.global.u32 %r239,[__fdlib_version]; bra $L27; $L23: .loc 1 181 0 mov.f64 %r197,0d7ff0000000000000; st.f64 [%frame+32],%r197; .loc 1 183 0 setp.lt.f64 %r198,%r81,0d0000000000000000; @ ! %r198 bra $L27; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r79; call (%value_in),rint,(%out_arg1); ld.param.f64 %r200,[%value_in]; } setp.eq.f64 %r201,%r200,%r79; @ ! %r201 bra $L74; ld.global.u32 %r239,[__fdlib_version]; bra $L27; $L74: mov.f64 %r202,0dfff0000000000000; st.f64 [%frame+32],%r202; ld.global.u32 %r239,[__fdlib_version]; $L27: .loc 1 185 0 setp.ne.u32 %r204,%r239,2; @ %r204 bra $L24; .loc 1 186 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r205,[%value_in]; } mov.u32 %r206,34; st.u32 [%r205],%r206; bra $L30; $L24: .loc 1 187 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r208,[%value_in]; } setp.ne.u32 %r209,%r208,0; @ %r209 bra $L30; .loc 1 188 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r210,[%value_in]; } mov.u32 %r211,34; st.u32 [%r210],%r211; $L30: .loc 1 190 0 ld.u32 %r212,[%frame+40]; setp.eq.u32 %r213,%r212,0; @ %r213 bra $L31; .loc 1 191 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r214,[%value_in]; } ld.u32 %r68,[%frame+40]; st.u32 [%r214],%r68; $L31: .loc 1 192 0 ld.f64 %r80,[%frame+32]; bra $L1; $L17: .loc 1 196 0 setp.neu.f64 %r215,%r85,0d0000000000000000; @ %r215 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),finite,(%out_arg1); ld.param.u32 %r217,[%value_in]; } setp.eq.u32 %r218,%r217,0; @ %r218 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),finite,(%out_arg1); ld.param.u32 %r220,[%value_in]; } setp.eq.u32 %r221,%r220,0; @ %r221 bra $L1; .loc 1 198 0 mov.u32 %r222,4; st.u32 [%frame],%r222; .loc 1 199 0 cvta.const.u64 %r223,$LC0; st.u64 [%frame+8],%r223; .loc 1 200 0 mov.u32 %r224,0; st.u32 [%frame+40],%r224; .loc 1 201 0 st.f64 [%frame+16],%r81; .loc 1 202 0 st.f64 [%frame+24],%r82; .loc 1 203 0 mov.f64 %r225,0d0000000000000000; st.f64 [%frame+32],%r225; .loc 1 204 0 ld.global.u32 %r226,[__fdlib_version]; setp.ne.u32 %r227,%r226,2; @ %r227 bra $L32; .loc 1 205 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r228,[%value_in]; } mov.u32 %r229,34; st.u32 [%r228],%r229; bra $L33; $L32: .loc 1 206 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r231,[%value_in]; } setp.ne.u32 %r232,%r231,0; @ %r232 bra $L33; .loc 1 207 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r233,[%value_in]; } mov.u32 %r234,34; st.u32 [%r233],%r234; $L33: .loc 1 209 0 ld.u32 %r235,[%frame+40]; setp.eq.u32 %r236,%r235,0; @ %r236 bra $L34; .loc 1 210 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r237,[%value_in]; } ld.u32 %r77,[%frame+40]; st.u32 [%r237],%r77; $L34: .loc 1 211 0 ld.f64 %r80,[%frame+32]; $L1: .loc 1 215 0 mov.f64 %value,%r80; st.param.f64 [%value_out],%value; ret; } /1421 0 0 0 644 3922 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: remainder .visible .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_remainder.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainder .extern .func (.param .f64 %value_out) __ieee754_remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[10] = {114,101,109,97,105,110,100,101,114,0 }; // BEGIN GLOBAL FUNCTION DEF: remainder .visible .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r31; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r49; .reg .u32 %r50; .reg .u16 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .u32 %r54; .reg .u16 %r55; .reg .pred %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; mov.f64 %r36,%ar0; mov.f64 %r37,%ar1; .loc 1 68 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r37; call (%value_in),__ieee754_remainder,(%out_arg1,%out_arg2); ld.param.f64 %r40,[%value_in]; } mov.f64 %r35,%r40; .loc 1 69 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r44,[%value_in]; } .loc 1 70 0 set.u32.eq.f64 %r46,%r37,0d0000000000000000; neg.s32 %r47,%r46; .loc 1 69 0 set.u32.ne.u32 %r49,%r44,0; neg.s32 %r50,%r49; .loc 1 70 0 cvt.u16.u32 %r52,%r47; cvt.u16.u32 %r53,%r50; and.b16 %r51,%r52,%r53; cvt.u32.u16 %r54,%r51; cvt.u16.u8 %r55,%r54; setp.eq.u16 %r56,%r55,0; @ %r56 bra $L1; .loc 1 72 0 mov.u32 %r57,1; st.u32 [%frame],%r57; .loc 1 73 0 cvta.const.u64 %r58,$LC0; st.u64 [%frame+8],%r58; .loc 1 74 0 mov.u32 %r59,0; st.u32 [%frame+40],%r59; .loc 1 75 0 st.f64 [%frame+16],%r36; .loc 1 76 0 st.f64 [%frame+24],%r37; .loc 1 77 0 mov.f64 %r61,0d0000000000000000; div.rn.f64 %r60,%r61,0d0000000000000000; st.f64 [%frame+32],%r60; .loc 1 78 0 ld.global.u32 %r62,[__fdlib_version]; setp.ne.u32 %r63,%r62,2; @ %r63 bra $L3; .loc 1 79 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,33; st.u32 [%r64],%r65; bra $L4; $L3: .loc 1 80 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r67,[%value_in]; } setp.ne.u32 %r68,%r67,0; @ %r68 bra $L4; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r69,[%value_in]; } mov.u32 %r70,33; st.u32 [%r69],%r70; $L4: .loc 1 83 0 ld.u32 %r71,[%frame+40]; setp.eq.u32 %r72,%r71,0; @ %r72 bra $L5; .loc 1 84 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r73],%r31; $L5: .loc 1 85 0 ld.f64 %r35,[%frame+32]; $L1: .loc 1 89 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-w_scalb.o/0 0 0 644 6702 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: scalb .visible .func (.param .f64 %value_out) scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/math/w_scalb.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalb .extern .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {115,99,97,108,98,0 }; // BEGIN GLOBAL FUNCTION DEF: scalb .visible .func (.param .f64 %value_out) scalb (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r32; .reg .u32 %r43; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r52; .reg .u32 %r53; .reg .pred %r54; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .pred %r67; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r84; .reg .u32 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .u32 %r89; .reg .u16 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u32 %r94; .reg .f64 %r95; .reg .f64 %r97; .reg .u32 %r98; .reg .pred %r99; .reg .u64 %r100; .reg .u32 %r101; .reg .u32 %r103; .reg .pred %r104; .reg .u64 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .u32 %r111; .reg .pred %r112; .reg .u64 %r113; .reg .u32 %r114; mov.f64 %r48,%ar0; mov.f64 %r49,%ar1; .loc 1 51 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r48; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r49; call (%value_in),__ieee754_scalb,(%out_arg1,%out_arg2); ld.param.f64 %r52,[%value_in]; } mov.f64 %r47,%r52; .loc 1 52 0 ld.global.u32 %r53,[__fdlib_version]; setp.eq.u32 %r54,%r53,-1; @ %r54 bra $L1; .loc 1 53 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),finite,(%out_arg1); ld.param.u32 %r56,[%value_in]; } setp.ne.u32 %r57,%r56,0; @ %r57 bra $L3; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.eq.u32 %r60,%r59,0; @ %r60 bra $L3; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r48; call (%value_in),finite,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.eq.u32 %r63,%r62,0; @ %r63 bra $L3; .loc 1 55 0 mov.u32 %r64,3; st.u32 [%frame],%r64; .loc 1 56 0 cvta.const.u64 %r65,$LC0; st.u64 [%frame+8],%r65; .loc 1 57 0 st.u32 [%frame+40],%r56; .loc 1 58 0 st.f64 [%frame+16],%r48; .loc 1 59 0 st.f64 [%frame+24],%r49; .loc 1 60 0 setp.gt.f64 %r67,%r48,0d0000000000000000; selp.f64 %r46,0d7ff0000000000000,0dfff0000000000000,%r67; st.f64 [%frame+32],%r46; .loc 1 61 0 ld.global.u32 %r68,[__fdlib_version]; setp.ne.u32 %r69,%r68,2; @ %r69 bra $L5; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,34; st.u32 [%r70],%r71; bra $L6; $L5: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r73,[%value_in]; } setp.ne.u32 %r74,%r73,0; @ %r74 bra $L6; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,34; st.u32 [%r75],%r76; $L6: .loc 1 66 0 ld.u32 %r77,[%frame+40]; setp.eq.u32 %r78,%r77,0; @ %r78 bra $L7; .loc 1 67 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r79],%r32; $L7: .loc 1 68 0 ld.f64 %r47,[%frame+32]; bra $L1; $L3: .loc 1 70 0 set.u32.eq.f64 %r81,%r52,0d0000000000000000; neg.s32 %r82,%r81; set.u32.neu.f64 %r84,%r48,%r52; neg.s32 %r85,%r84; cvt.u16.u32 %r87,%r82; cvt.u16.u32 %r88,%r85; and.b16 %r86,%r87,%r88; cvt.u32.u16 %r89,%r86; cvt.u16.u8 %r90,%r89; setp.eq.u16 %r91,%r90,0; @ %r91 bra $L8; .loc 1 72 0 mov.u32 %r92,4; st.u32 [%frame],%r92; .loc 1 73 0 cvta.const.u64 %r93,$LC0; st.u64 [%frame+8],%r93; .loc 1 74 0 mov.u32 %r94,0; st.u32 [%frame+40],%r94; .loc 1 75 0 st.f64 [%frame+16],%r48; .loc 1 76 0 st.f64 [%frame+24],%r49; .loc 1 77 0 mov.f64 %r95,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r95; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r48; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r97,[%value_in]; } st.f64 [%frame+32],%r97; .loc 1 78 0 ld.global.u32 %r98,[__fdlib_version]; setp.ne.u32 %r99,%r98,2; @ %r99 bra $L9; .loc 1 79 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r100,[%value_in]; } mov.u32 %r101,34; st.u32 [%r100],%r101; bra $L10; $L9: .loc 1 80 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r103,[%value_in]; } setp.ne.u32 %r104,%r103,0; @ %r104 bra $L10; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r105,[%value_in]; } mov.u32 %r106,34; st.u32 [%r105],%r106; $L10: .loc 1 83 0 ld.u32 %r107,[%frame+40]; setp.eq.u32 %r108,%r107,0; @ %r108 bra $L11; .loc 1 84 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r109,[%value_in]; } ld.u32 %r43,[%frame+40]; st.u32 [%r109],%r43; $L11: .loc 1 85 0 ld.f64 %r47,[%frame+32]; bra $L1; $L8: .loc 1 88 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),finite,(%out_arg1); ld.param.u32 %r111,[%value_in]; } setp.ne.u32 %r112,%r111,0; @ %r112 bra $L1; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r113,[%value_in]; } mov.u32 %r114,34; st.u32 [%r113],%r114; $L1: .loc 1 92 0 mov.f64 %value,%r47; st.param.f64 [%value_out],%value; ret; } /1442 0 0 0 644 1230 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sincos .visible .func sincos (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/math/w_sincos.c" // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sincos .visible .func sincos (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .f64 %r28; .reg .f64 %r30; mov.f64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 18 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),sin,(%out_arg1); ld.param.f64 %r28,[%value_in]; } st.f64 [%r25],%r28; .loc 1 19 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),cos,(%out_arg1); ld.param.f64 %r30,[%value_in]; } st.f64 [%r26],%r30; .loc 1 20 0 ret; } lib_a-w_sinh.o/ 0 0 0 644 3714 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sinh .visible .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_sinh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinh .extern .func (.param .f64 %value_out) __ieee754_sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {115,105,110,104,0 }; // BEGIN GLOBAL FUNCTION DEF: sinh .visible .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; mov.f64 %r35,%ar0; .loc 1 89 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),__ieee754_sinh,(%out_arg1); ld.param.f64 %r37,[%value_in]; } mov.f64 %r34,%r37; .loc 1 90 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; .loc 1 91 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),finite,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.ne.u32 %r42,%r41,0; @ %r42 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),finite,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 99 0 mov.u32 %r46,3; st.u32 [%frame],%r46; .loc 1 100 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 101 0 st.u32 [%frame+40],%r41; .loc 1 102 0 st.f64 [%frame+24],%r35; st.f64 [%frame+16],%r35; .loc 1 103 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r49,%r25,0; @ %r49 bra $L3; .loc 1 104 0 setp.gt.f64 %r50,%r35,0d0000000000000000; selp.f64 %r32,0d47efffffe0000000,0dc7efffffe0000000,%r50; st.f64 [%frame+32],%r32; bra $L5; $L3: .loc 1 106 0 setp.gt.f64 %r51,%r35,0d0000000000000000; selp.f64 %r33,0d7ff0000000000000,0dfff0000000000000,%r51; st.f64 [%frame+32],%r33; .loc 1 107 0 setp.ne.u32 %r52,%r25,2; @ %r52 bra $L5; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r53,[%value_in]; } mov.u32 %r54,34; st.u32 [%r53],%r54; bra $L7; $L5: .loc 1 109 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r56,[%value_in]; } setp.ne.u32 %r57,%r56,0; @ %r57 bra $L7; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } mov.u32 %r59,34; st.u32 [%r58],%r59; $L7: .loc 1 112 0 ld.u32 %r60,[%frame+40]; setp.eq.u32 %r61,%r60,0; @ %r61 bra $L8; .loc 1 113 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r62],%r31; $L8: .loc 1 114 0 ld.f64 %r34,[%frame+32]; $L1: .loc 1 118 0 mov.f64 %value,%r34; st.param.f64 [%value_out],%value; ret; } lib_a-w_sqrt.o/ 0 0 0 644 3496 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sqrt .visible .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_sqrt.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {115,113,114,116,0 }; // BEGIN GLOBAL FUNCTION DEF: sqrt .visible .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .u32 %r42; .reg .u64 %r43; .reg .u32 %r44; .reg .pred %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .pred %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; mov.f64 %r33,%ar0; .loc 1 69 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 70 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 71 0 setp.lt.f64 %r41,%r33,0d0000000000000000; @ ! %r41 bra $L1; .loc 1 72 0 mov.u32 %r42,1; st.u32 [%frame],%r42; .loc 1 73 0 cvta.const.u64 %r43,$LC0; st.u64 [%frame+8],%r43; .loc 1 74 0 mov.u32 %r44,0; st.u32 [%frame+40],%r44; .loc 1 75 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 76 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r45,%r24,0; @ %r45 bra $L4; .loc 1 77 0 mov.f64 %r46,0d0000000000000000; st.f64 [%frame+32],%r46; bra $L5; $L4: .loc 1 79 0 mov.f64 %r48,0d0000000000000000; div.rn.f64 %r47,%r48,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 80 0 setp.ne.u32 %r49,%r24,2; @ %r49 bra $L5; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r50,[%value_in]; } mov.u32 %r51,33; st.u32 [%r50],%r51; bra $L6; $L5: .loc 1 82 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.ne.u32 %r54,%r53,0; @ %r54 bra $L6; .loc 1 83 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,33; st.u32 [%r55],%r56; $L6: .loc 1 85 0 ld.u32 %r57,[%frame+40]; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L7; .loc 1 86 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r59],%r31; $L7: .loc 1 87 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 91 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } /1460 0 0 0 644 3303 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tgamma .visible .func (.param .f64 %value_out) tgamma (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/math/w_tgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .extern .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_standard .extern .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: tgamma .visible .func (.param .f64 %value_out) tgamma (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r27; .reg .f64 %r28; .reg .f64 %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .pred %r35; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r52; .reg .f64 %r53; mov.f64 %r28,%ar0; .loc 1 31 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_gamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r31,[%value_in]; } mov.f64 %r27,%r31; .loc 1 32 0 ld.u32 %r32,[%frame]; setp.ge.s32 %r33,%r32,0; @ %r33 bra $L2; neg.f64 %r27,%r27; $L2: .loc 1 36 0 ld.global.u32 %r34,[__fdlib_version]; setp.eq.u32 %r35,%r34,-1; @ %r35 bra $L1; .loc 1 38 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r27; call (%value_in),finite,(%out_arg1); ld.param.u32 %r37,[%value_in]; } setp.ne.u32 %r38,%r37,0; @ %r38 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; call (%value_in),finite,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.eq.u32 %r41,%r40,0; @ %r41 bra $L1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; call (%value_in),floor,(%out_arg1); ld.param.f64 %r43,[%value_in]; } setp.neu.f64 %r44,%r43,%r28; @ %r44 bra $L4; setp.le.f64 %r45,%r28,0d0000000000000000; @ ! %r45 bra $L4; .loc 1 40 0 mov.u32 %r48,41; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r28; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r48; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r49,[%value_in]; } mov.f64 %r27,%r49; bra $L1; $L4: .loc 1 42 0 mov.u32 %r52,40; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r28; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r52; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r53,[%value_in]; } mov.f64 %r27,%r53; $L1: .loc 1 46 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-wf_acos.o/0 0 0 644 3936 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acosf .visible .func (.param .f32 %value_out) acosf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_acos.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosf .extern .func (.param .f32 %value_out) __ieee754_acosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,99,111,115,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: acosf .visible .func (.param .f32 %value_out) acosf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r33; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .f32 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .f64 %r64; mov.f32 %r36,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__ieee754_acosf,(%out_arg1); ld.param.f32 %r38,[%value_in]; } mov.f32 %r35,%r38; .loc 1 36 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 37 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } setp.gt.f32 %r46,%r45,0f3f800000; @ ! %r46 bra $L1; .loc 1 39 0 mov.u32 %r47,1; st.u32 [%frame],%r47; .loc 1 40 0 cvta.const.u64 %r48,$LC0; st.u64 [%frame+8],%r48; .loc 1 41 0 mov.u32 %r49,0; st.u32 [%frame+40],%r49; .loc 1 42 0 cvt.f64.f32 %r25,%r36; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 43 0 cvta.const.u64 %r50,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r50; call (%value_in),nan,(%out_arg1); ld.param.f64 %r51,[%value_in]; } st.f64 [%frame+32],%r51; .loc 1 44 0 ld.global.u32 %r52,[__fdlib_version]; setp.ne.u32 %r53,%r52,2; @ %r53 bra $L4; .loc 1 45 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,33; st.u32 [%r54],%r55; bra $L5; $L4: .loc 1 46 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L5; .loc 1 47 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; $L5: .loc 1 49 0 ld.u32 %r61,[%frame+40]; setp.eq.u32 %r62,%r61,0; @ %r62 bra $L6; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r63],%r33; $L6: .loc 1 51 0 ld.f64 %r64,[%frame+32]; cvt.rn.f32.f64 %r35,%r64; $L1: .loc 1 55 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } /1478 0 0 0 644 3421 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acoshf .visible .func (.param .f32 %value_out) acoshf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_acosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acoshf .extern .func (.param .f32 %value_out) __ieee754_acoshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {97,99,111,115,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: acoshf .visible .func (.param .f32 %value_out) acoshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .u32 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r52; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .f64 %r61; mov.f32 %r35,%ar0; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_acoshf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 37 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 38 0 setp.lt.f32 %r43,%r35,0f3f800000; @ ! %r43 bra $L1; .loc 1 40 0 mov.u32 %r44,1; st.u32 [%frame],%r44; .loc 1 41 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 42 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 43 0 cvt.f64.f32 %r24,%r35; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 44 0 mov.f64 %r48,0d0000000000000000; div.rn.f64 %r47,%r48,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 45 0 ld.global.u32 %r49,[__fdlib_version]; setp.ne.u32 %r50,%r49,2; @ %r50 bra $L4; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r51,[%value_in]; } mov.u32 %r52,33; st.u32 [%r51],%r52; bra $L5; $L4: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r54,[%value_in]; } setp.ne.u32 %r55,%r54,0; @ %r55 bra $L5; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,33; st.u32 [%r56],%r57; $L5: .loc 1 50 0 ld.u32 %r58,[%frame+40]; setp.eq.u32 %r59,%r58,0; @ %r59 bra $L6; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r60],%r32; $L6: .loc 1 52 0 ld.f64 %r61,[%frame+32]; cvt.rn.f32.f64 %r34,%r61; $L1: .loc 1 56 0 mov.f32 %value,%r34; st.param.f32 [%value_out],%value; ret; } lib_a-wf_asin.o/0 0 0 644 3937 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: asinf .visible .func (.param .f32 %value_out) asinf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_asin.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_asinf .extern .func (.param .f32 %value_out) __ieee754_asinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,115,105,110,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: asinf .visible .func (.param .f32 %value_out) asinf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r33; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .f32 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .f64 %r64; mov.f32 %r36,%ar0; .loc 1 37 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__ieee754_asinf,(%out_arg1); ld.param.f32 %r38,[%value_in]; } mov.f32 %r35,%r38; .loc 1 38 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 39 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } setp.gt.f32 %r46,%r45,0f3f800000; @ ! %r46 bra $L1; .loc 1 41 0 mov.u32 %r47,1; st.u32 [%frame],%r47; .loc 1 42 0 cvta.const.u64 %r48,$LC0; st.u64 [%frame+8],%r48; .loc 1 43 0 mov.u32 %r49,0; st.u32 [%frame+40],%r49; .loc 1 44 0 cvt.f64.f32 %r25,%r36; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 45 0 cvta.const.u64 %r50,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r50; call (%value_in),nan,(%out_arg1); ld.param.f64 %r51,[%value_in]; } st.f64 [%frame+32],%r51; .loc 1 46 0 ld.global.u32 %r52,[__fdlib_version]; setp.ne.u32 %r53,%r52,2; @ %r53 bra $L4; .loc 1 47 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,33; st.u32 [%r54],%r55; bra $L5; $L4: .loc 1 48 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L5; .loc 1 49 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; $L5: .loc 1 51 0 ld.u32 %r61,[%frame+40]; setp.eq.u32 %r62,%r61,0; @ %r62 bra $L6; .loc 1 52 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r63],%r33; $L6: .loc 1 53 0 ld.f64 %r64,[%frame+32]; cvt.rn.f32.f64 %r35,%r64; $L1: .loc 1 57 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } /1496 0 0 0 644 1040 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan2f .visible .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_atan2.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2f .extern .func (.param .f32 %value_out) __ieee754_atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atan2f .visible .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r27; mov.f32 %r23,%ar0; mov.f32 %r24,%ar1; .loc 1 31 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r23; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; call (%value_in),__ieee754_atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r27,[%value_in]; } .loc 1 32 0 mov.f32 %value,%r27; st.param.f32 [%value_out],%value; ret; } /1514 0 0 0 644 4824 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: atanhf .visible .func (.param .f32 %value_out) atanhf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_atanh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanhf .extern .func (.param .f32 %value_out) __ieee754_atanhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {97,116,97,110,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: atanhf .visible .func (.param .f32 %value_out) atanhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .f64 %r37; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .pred %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .f64 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .f64 %r80; mov.f32 %r40,%ar0; .loc 1 34 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__ieee754_atanhf,(%out_arg1); ld.param.f32 %r42,[%value_in]; } mov.f32 %r39,%r42; .loc 1 35 0 ld.global.u32 %r43,[__fdlib_version]; setp.eq.u32 %r44,%r43,-1; @ %r44 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.eq.u32 %r47,%r46,0; @ %r47 bra $L1; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } .loc 1 37 0 setp.ge.f32 %r50,%r49,0f3f800000; @ ! %r50 bra $L1; cvt.f64.f32 %r37,%r40; ld.global.u32 %r38,[__fdlib_version]; .loc 1 38 0 setp.gt.f32 %r51,%r49,0f3f800000; @ ! %r51 bra $L23; .loc 1 40 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 41 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 42 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 43 0 st.f64 [%frame+24],%r37; st.f64 [%frame+16],%r37; .loc 1 44 0 mov.f64 %r56,0d0000000000000000; div.rn.f64 %r55,%r56,0d0000000000000000; st.f64 [%frame+32],%r55; .loc 1 45 0 setp.ne.u32 %r57,%r38,2; @ %r57 bra $L6; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } mov.u32 %r59,33; st.u32 [%r58],%r59; bra $L7; $L6: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r61,[%value_in]; } setp.eq.u32 %r62,%r61,0; @ ! %r62 bra $L7; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L7; $L23: .loc 1 52 0 mov.u32 %r65,2; st.u32 [%frame],%r65; .loc 1 53 0 cvta.const.u64 %r66,$LC0; st.u64 [%frame+8],%r66; .loc 1 54 0 mov.u32 %r67,0; st.u32 [%frame+40],%r67; .loc 1 55 0 st.f64 [%frame+24],%r37; st.f64 [%frame+16],%r37; .loc 1 56 0 div.rn.f64 %r68,%r37,0d0000000000000000; st.f64 [%frame+32],%r68; .loc 1 57 0 setp.ne.u32 %r69,%r38,2; @ %r69 bra $L9; .loc 1 58 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; bra $L7; $L9: .loc 1 59 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r73,[%value_in]; } setp.ne.u32 %r74,%r73,0; @ %r74 bra $L7; .loc 1 60 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,33; st.u32 [%r75],%r76; $L7: .loc 1 63 0 ld.u32 %r77,[%frame+40]; setp.eq.u32 %r78,%r77,0; @ %r78 bra $L11; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r79],%r34; $L11: .loc 1 65 0 ld.f64 %r80,[%frame+32]; cvt.rn.f32.f64 %r39,%r80; $L1: .loc 1 69 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } lib_a-wf_cosh.o/0 0 0 644 3792 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: coshf .visible .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_cosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_coshf .extern .func (.param .f32 %value_out) __ieee754_coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {99,111,115,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: coshf .visible .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r26; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .f64 %r63; mov.f32 %r35,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_coshf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 36 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 37 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.gt.f32 %r45,%r44,0f42b2d4fc; @ ! %r45 bra $L1; .loc 1 45 0 mov.u32 %r46,3; st.u32 [%frame],%r46; .loc 1 46 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 47 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 48 0 cvt.f64.f32 %r25,%r35; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 49 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r49,%r26,0; @ %r49 bra $L4; .loc 1 50 0 mov.f64 %r50,0d47efffffe0000000; st.f64 [%frame+32],%r50; bra $L5; $L4: .loc 1 52 0 mov.f64 %r51,0d7ff0000000000000; st.f64 [%frame+32],%r51; .loc 1 53 0 setp.ne.u32 %r52,%r26,2; @ %r52 bra $L5; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r53,[%value_in]; } mov.u32 %r54,34; st.u32 [%r53],%r54; bra $L6; $L5: .loc 1 55 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r56,[%value_in]; } setp.ne.u32 %r57,%r56,0; @ %r57 bra $L6; .loc 1 56 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } mov.u32 %r59,34; st.u32 [%r58],%r59; $L6: .loc 1 58 0 ld.u32 %r60,[%frame+40]; setp.eq.u32 %r61,%r60,0; @ %r61 bra $L7; .loc 1 59 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r62],%r32; $L7: .loc 1 60 0 ld.f64 %r63,[%frame+32]; cvt.rn.f32.f64 %r34,%r63; $L1: .loc 1 64 0 mov.f32 %value,%r34; st.param.f32 [%value_out],%value; ret; } lib_a-wf_drem.o/0 0 0 644 1017 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: dremf .visible .func (.param .f32 %value_out) dremf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_drem.c" // BEGIN GLOBAL FUNCTION DECL: remainderf .extern .func (.param .f32 %value_out) remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: dremf .visible .func (.param .f32 %value_out) dremf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r27; mov.f32 %r23,%ar0; mov.f32 %r24,%ar1; .loc 1 18 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r23; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; call (%value_in),remainderf,(%out_arg1,%out_arg2); ld.param.f32 %r27,[%value_in]; } .loc 1 19 0 mov.f32 %value,%r27; st.param.f32 [%value_out],%value; ret; } lib_a-wf_exp.o/ 0 0 0 644 5089 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: expf .visible .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_exp.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {101,120,112,102,0 }; // BEGIN GLOBAL FUNCTION DEF: expf .visible .func (.param .f32 %value_out) expf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r33; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .f64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r43,%ar0; .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } mov.f32 %r42,%r45; .loc 1 44 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L1; .loc 1 45 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L1; .loc 1 46 0 setp.gt.f32 %r51,%r43,0f42b17180; @ ! %r51 bra $L27; .loc 1 54 0 mov.u32 %r52,3; st.u32 [%frame],%r52; .loc 1 55 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 56 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 57 0 cvt.f64.f32 %r24,%r43; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 58 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r55,%r25,0; @ %r55 bra $L5; .loc 1 59 0 mov.f64 %r56,0d47efffffe0000000; st.f64 [%frame+32],%r56; bra $L6; $L5: .loc 1 61 0 mov.f64 %r57,0d7ff0000000000000; st.f64 [%frame+32],%r57; .loc 1 62 0 setp.ne.u32 %r58,%r25,2; @ %r58 bra $L6; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; bra $L7; $L6: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L7; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,34; st.u32 [%r64],%r65; $L7: .loc 1 67 0 ld.u32 %r66,[%frame+40]; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L8; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r68],%r31; $L8: .loc 1 69 0 ld.f64 %r69,[%frame+32]; cvt.rn.f32.f64 %r42,%r69; bra $L1; $L27: .loc 1 70 0 setp.lt.f32 %r70,%r43,0fc2cff1b5; @ ! %r70 bra $L1; .loc 1 72 0 mov.u32 %r71,4; st.u32 [%frame],%r71; .loc 1 73 0 cvta.const.u64 %r72,$LC0; st.u64 [%frame+8],%r72; .loc 1 74 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 75 0 cvt.f64.f32 %r33,%r43; st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 76 0 mov.f64 %r74,0d0000000000000000; st.f64 [%frame+32],%r74; .loc 1 77 0 ld.global.u32 %r75,[__fdlib_version]; setp.ne.u32 %r76,%r75,2; @ %r76 bra $L10; .loc 1 78 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L11; $L10: .loc 1 79 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L11; .loc 1 80 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L11: .loc 1 82 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L12; .loc 1 83 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r40,[%frame+40]; st.u32 [%r86],%r40; $L12: .loc 1 84 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r42,%r87; $L1: .loc 1 89 0 mov.f32 %value,%r42; st.param.f32 [%value_out],%value; ret; } lib_a-wf_exp2.o/0 0 0 644 918 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp2f .visible .func (.param .f32 %value_out) exp2f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_exp2.c" // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp2f .visible .func (.param .f32 %value_out) exp2f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r23,%ar0; .loc 1 31 0 mov.f32 %r24,0f40000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r23; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 32 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } lib_a-wf_fmod.o/0 0 0 644 4313 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: fmodf .visible .func (.param .f32 %value_out) fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_fmod.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmodf .extern .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {102,109,111,100,102,0 }; // BEGIN GLOBAL FUNCTION DEF: fmodf .visible .func (.param .f32 %value_out) fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r27; .reg .u32 %r34; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u16 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u32 %r61; .reg .u16 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .f64 %r67; .reg .pred %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; .reg .f64 %r82; mov.f32 %r40,%ar0; mov.f32 %r41,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),__ieee754_fmodf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } mov.f32 %r39,%r44; .loc 1 36 0 ld.global.u32 %r45,[__fdlib_version]; setp.eq.u32 %r46,%r45,-1; @ %r46 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r51,[%value_in]; } set.u32.ne.u32 %r53,%r51,0; neg.s32 %r54,%r53; .loc 1 37 0 set.u32.eq.f32 %r56,%r41,0f00000000; neg.s32 %r57,%r56; cvt.u16.u32 %r59,%r54; cvt.u16.u32 %r60,%r57; and.b16 %r58,%r59,%r60; cvt.u32.u16 %r61,%r58; cvt.u16.u8 %r62,%r61; setp.eq.u16 %r63,%r62,0; @ %r63 bra $L1; .loc 1 39 0 mov.u32 %r64,1; st.u32 [%frame],%r64; .loc 1 40 0 cvta.const.u64 %r65,$LC0; st.u64 [%frame+8],%r65; .loc 1 41 0 mov.u32 %r66,0; st.u32 [%frame+40],%r66; .loc 1 42 0 cvt.f64.f32 %r25,%r40; st.f64 [%frame+16],%r25; .loc 1 43 0 cvt.f64.f32 %r67,%r41; st.f64 [%frame+24],%r67; .loc 1 44 0 ld.global.u32 %r27,[__fdlib_version]; setp.ne.u32 %r68,%r27,0; @ %r68 bra $L3; .loc 1 45 0 st.f64 [%frame+32],%r25; bra $L4; $L3: .loc 1 47 0 mov.f64 %r70,0d0000000000000000; div.rn.f64 %r69,%r70,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 48 0 setp.ne.u32 %r71,%r27,2; @ %r71 bra $L4; .loc 1 49 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,33; st.u32 [%r72],%r73; bra $L5; $L4: .loc 1 50 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L5; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,33; st.u32 [%r77],%r78; $L5: .loc 1 53 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L6; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r81],%r34; $L6: .loc 1 55 0 ld.f64 %r82,[%frame+32]; cvt.rn.f32.f64 %r39,%r82; $L1: .loc 1 59 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } /1532 0 0 0 644 5590 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gammaf .visible .func (.param .f32 %value_out) gammaf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .extern .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: gammaf .visible .func (.param .f32 %value_out) gammaf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r36; .reg .u32 %r38; .reg .f64 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .u64 %r44; .reg .u64 %r45; .reg .f32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r50; .reg .pred %r51; .reg .u32 %r53; .reg .pred %r54; .reg .f32 %r56; .reg .pred %r57; .reg .pred %r58; .reg .u32 %r59; .reg .u64 %r60; .reg .pred %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .pred %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .pred %r88; .reg .u64 %r89; .reg .f64 %r90; mov.f32 %r41,%ar0; .loc 1 33 0 ld.global.u64 %r45,[_impure_ptr]; add.u64 %r44,%r45,224; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r44; call (%value_in),__ieee754_gammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } mov.f32 %r40,%r46; .loc 1 34 0 ld.global.u32 %r47,[__fdlib_version]; setp.eq.u32 %r48,%r47,-1; @ %r48 bra $L1; .loc 1 35 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r50,[%value_in]; } setp.ne.u32 %r51,%r50,0; @ %r51 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.eq.u32 %r54,%r53,0; @ %r54 bra $L1; .loc 1 42 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r56,[%value_in]; } setp.neu.f32 %r57,%r56,%r41; @ %r57 bra $L3; cvt.f64.f32 %r39,%r41; ld.global.u32 %r38,[__fdlib_version]; setp.le.f32 %r58,%r41,0f00000000; @ ! %r58 bra $L4; .loc 1 44 0 mov.u32 %r59,2; st.u32 [%frame],%r59; .loc 1 45 0 cvta.const.u64 %r60,$LC0; st.u64 [%frame+8],%r60; .loc 1 46 0 st.u32 [%frame+40],%r50; .loc 1 47 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 48 0 setp.ne.u32 %r62,%r38,0; @ %r62 bra $L6; .loc 1 49 0 mov.f64 %r63,0d47efffffe0000000; st.f64 [%frame+32],%r63; bra $L7; $L6: .loc 1 51 0 mov.f64 %r64,0d7ff0000000000000; st.f64 [%frame+32],%r64; .loc 1 52 0 setp.ne.u32 %r65,%r38,2; @ %r65 bra $L7; .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } mov.u32 %r67,33; st.u32 [%r66],%r67; bra $L8; $L7: .loc 1 54 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r69,[%value_in]; } setp.eq.u32 %r70,%r69,0; @ ! %r70 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } mov.u32 %r72,33; st.u32 [%r71],%r72; bra $L8; $L3: cvt.f64.f32 %r39,%r41; ld.global.u32 %r38,[__fdlib_version]; $L4: .loc 1 59 0 mov.u32 %r73,3; st.u32 [%frame],%r73; .loc 1 60 0 cvta.const.u64 %r74,$LC0; st.u64 [%frame+8],%r74; .loc 1 61 0 mov.u32 %r75,0; st.u32 [%frame+40],%r75; .loc 1 62 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 63 0 setp.ne.u32 %r76,%r38,0; @ %r76 bra $L10; .loc 1 64 0 mov.f64 %r77,0d47efffffe0000000; st.f64 [%frame+32],%r77; bra $L11; $L10: .loc 1 66 0 mov.f64 %r78,0d7ff0000000000000; st.f64 [%frame+32],%r78; .loc 1 67 0 setp.ne.u32 %r79,%r38,2; @ %r79 bra $L11; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r80,[%value_in]; } mov.u32 %r81,34; st.u32 [%r80],%r81; bra $L8; $L11: .loc 1 69 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r83,[%value_in]; } setp.ne.u32 %r84,%r83,0; @ %r84 bra $L8; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r85,[%value_in]; } mov.u32 %r86,34; st.u32 [%r85],%r86; $L8: .loc 1 73 0 ld.u32 %r87,[%frame+40]; setp.eq.u32 %r88,%r87,0; @ %r88 bra $L13; .loc 1 74 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r89,[%value_in]; } ld.u32 %r36,[%frame+40]; st.u32 [%r89],%r36; $L13: .loc 1 75 0 ld.f64 %r90,[%frame+32]; cvt.rn.f32.f64 %r40,%r90; $L1: .loc 1 79 0 mov.f32 %value,%r40; st.param.f32 [%value_out],%value; ret; } /1550 0 0 0 644 4123 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: hypotf .visible .func (.param .f32 %value_out) hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_hypot.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypotf .extern .func (.param .f32 %value_out) __ieee754_hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {104,121,112,111,116,102,0 }; // BEGIN GLOBAL FUNCTION DEF: hypotf .visible .func (.param .f32 %value_out) hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r28; .reg .u32 %r34; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r65; .reg .pred %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .f64 %r72; mov.f32 %r37,%ar0; mov.f32 %r38,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r38; call (%value_in),__ieee754_hypotf,(%out_arg1,%out_arg2); ld.param.f32 %r41,[%value_in]; } mov.f32 %r36,%r41; .loc 1 36 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.ne.u32 %r46,%r45,0; @ %r46 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.eq.u32 %r52,%r51,0; @ %r52 bra $L1; .loc 1 45 0 mov.u32 %r53,3; st.u32 [%frame],%r53; .loc 1 46 0 cvta.const.u64 %r54,$LC0; st.u64 [%frame+8],%r54; .loc 1 47 0 st.u32 [%frame+40],%r45; .loc 1 48 0 cvt.f64.f32 %r56,%r37; st.f64 [%frame+16],%r56; .loc 1 49 0 cvt.f64.f32 %r57,%r38; st.f64 [%frame+24],%r57; .loc 1 50 0 ld.global.u32 %r28,[__fdlib_version]; setp.ne.u32 %r58,%r28,0; @ %r58 bra $L3; .loc 1 51 0 mov.f64 %r59,0d47efffffe0000000; st.f64 [%frame+32],%r59; bra $L4; $L3: .loc 1 53 0 mov.f64 %r60,0d7ff0000000000000; st.f64 [%frame+32],%r60; .loc 1 54 0 setp.ne.u32 %r61,%r28,2; @ %r61 bra $L4; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } mov.u32 %r63,34; st.u32 [%r62],%r63; bra $L5; $L4: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r65,[%value_in]; } setp.ne.u32 %r66,%r65,0; @ %r66 bra $L5; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r67,[%value_in]; } mov.u32 %r68,34; st.u32 [%r67],%r68; $L5: .loc 1 59 0 ld.u32 %r69,[%frame+40]; setp.eq.u32 %r70,%r69,0; @ %r70 bra $L6; .loc 1 60 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r71],%r34; $L6: .loc 1 61 0 ld.f64 %r72,[%frame+32]; cvt.rn.f32.f64 %r36,%r72; $L1: .loc 1 65 0 mov.f32 %value,%r36; st.param.f32 [%value_out],%value; ret; } lib_a-wf_j0.o/ 0 0 0 644 8168 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j0f .visible .func (.param .f32 %value_out) j0f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_j0.c" // BEGIN GLOBAL FUNCTION DECL: y0f .visible .func (.param .f32 %value_out) y0f (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0f .extern .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0f .extern .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {106,48,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {121,48,102,0 }; // BEGIN GLOBAL FUNCTION DEF: j0f .visible .func (.param .f32 %value_out) j0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .f64 %r62; mov.f32 %r35,%ar0; .loc 1 34 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 35 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.gt.f32 %r45,%r44,0f5a490fdb; @ ! %r45 bra $L1; .loc 1 38 0 mov.u32 %r46,5; st.u32 [%frame],%r46; .loc 1 39 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 40 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 41 0 cvt.f64.f32 %r25,%r35; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 42 0 mov.f64 %r49,0d0000000000000000; st.f64 [%frame+32],%r49; .loc 1 43 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 44 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,34; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 45 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; $L5: .loc 1 48 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 49 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 50 0 ld.f64 %r62,[%frame+32]; cvt.rn.f32.f64 %r34,%r62; $L1: .loc 1 54 0 mov.f32 %value,%r34; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y0f .visible .func (.param .f32 %value_out) y0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r33; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .f64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r43,%ar0; .loc 1 68 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__ieee754_y0f,(%out_arg1); ld.param.f32 %r45,[%value_in]; } mov.f32 %r42,%r45; .loc 1 69 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L17; .loc 1 70 0 setp.le.f32 %r51,%r43,0f00000000; @ ! %r51 bra $L43; .loc 1 78 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 79 0 cvta.const.u64 %r53,$LC1; st.u64 [%frame+8],%r53; .loc 1 80 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 81 0 cvt.f64.f32 %r24,%r43; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 82 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r55,%r25,0; @ %r55 bra $L21; .loc 1 83 0 mov.f64 %r56,0dc7efffffe0000000; st.f64 [%frame+32],%r56; bra $L22; $L21: .loc 1 85 0 mov.f64 %r57,0dfff0000000000000; st.f64 [%frame+32],%r57; .loc 1 86 0 setp.ne.u32 %r58,%r25,2; @ %r58 bra $L22; .loc 1 87 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; bra $L23; $L22: .loc 1 88 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L23; .loc 1 89 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,33; st.u32 [%r64],%r65; $L23: .loc 1 91 0 ld.u32 %r66,[%frame+40]; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L24; .loc 1 92 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r68],%r31; $L24: .loc 1 93 0 ld.f64 %r69,[%frame+32]; cvt.rn.f32.f64 %r42,%r69; bra $L17; $L43: .loc 1 95 0 setp.gt.f32 %r70,%r43,0f5a490fdb; @ ! %r70 bra $L17; .loc 1 97 0 mov.u32 %r71,5; st.u32 [%frame],%r71; .loc 1 98 0 cvta.const.u64 %r72,$LC1; st.u64 [%frame+8],%r72; .loc 1 99 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 100 0 cvt.f64.f32 %r33,%r43; st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 101 0 mov.f64 %r74,0d0000000000000000; st.f64 [%frame+32],%r74; .loc 1 102 0 ld.global.u32 %r75,[__fdlib_version]; setp.ne.u32 %r76,%r75,2; @ %r76 bra $L26; .loc 1 103 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L27; $L26: .loc 1 104 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L27; .loc 1 105 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L27: .loc 1 107 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L28; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r40,[%frame+40]; st.u32 [%r86],%r40; $L28: .loc 1 109 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r42,%r87; $L17: .loc 1 113 0 mov.f32 %value,%r42; st.param.f32 [%value_out],%value; ret; } lib_a-wf_j1.o/ 0 0 0 644 8170 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j1f .visible .func (.param .f32 %value_out) j1f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_j1.c" // BEGIN GLOBAL FUNCTION DECL: y1f .visible .func (.param .f32 %value_out) y1f (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1f .extern .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1f .extern .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {106,49,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {121,49,102,0 }; // BEGIN GLOBAL FUNCTION DEF: j1f .visible .func (.param .f32 %value_out) j1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .f64 %r62; mov.f32 %r35,%ar0; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 37 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 38 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.gt.f32 %r45,%r44,0f5a490fdb; @ ! %r45 bra $L1; .loc 1 40 0 mov.u32 %r46,5; st.u32 [%frame],%r46; .loc 1 41 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 42 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 43 0 cvt.f64.f32 %r25,%r35; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 44 0 mov.f64 %r49,0d0000000000000000; st.f64 [%frame+32],%r49; .loc 1 45 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,34; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; $L5: .loc 1 50 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 52 0 ld.f64 %r62,[%frame+32]; cvt.rn.f32.f64 %r34,%r62; $L1: .loc 1 56 0 mov.f32 %value,%r34; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y1f .visible .func (.param .f32 %value_out) y1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r33; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .f64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r43,%ar0; .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__ieee754_y1f,(%out_arg1); ld.param.f32 %r45,[%value_in]; } mov.f32 %r42,%r45; .loc 1 71 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L17; .loc 1 72 0 setp.le.f32 %r51,%r43,0f00000000; @ ! %r51 bra $L43; .loc 1 80 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 81 0 cvta.const.u64 %r53,$LC1; st.u64 [%frame+8],%r53; .loc 1 82 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 83 0 cvt.f64.f32 %r24,%r43; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 84 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r55,%r25,0; @ %r55 bra $L21; .loc 1 85 0 mov.f64 %r56,0dc7efffffe0000000; st.f64 [%frame+32],%r56; bra $L22; $L21: .loc 1 87 0 mov.f64 %r57,0dfff0000000000000; st.f64 [%frame+32],%r57; .loc 1 88 0 setp.ne.u32 %r58,%r25,2; @ %r58 bra $L22; .loc 1 89 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; bra $L23; $L22: .loc 1 90 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L23; .loc 1 91 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,33; st.u32 [%r64],%r65; $L23: .loc 1 93 0 ld.u32 %r66,[%frame+40]; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L24; .loc 1 94 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r68],%r31; $L24: .loc 1 95 0 ld.f64 %r69,[%frame+32]; cvt.rn.f32.f64 %r42,%r69; bra $L17; $L43: .loc 1 97 0 setp.gt.f32 %r70,%r43,0f5a490fdb; @ ! %r70 bra $L17; .loc 1 99 0 mov.u32 %r71,5; st.u32 [%frame],%r71; .loc 1 100 0 cvta.const.u64 %r72,$LC1; st.u64 [%frame+8],%r72; .loc 1 101 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 102 0 cvt.f64.f32 %r33,%r43; st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 103 0 mov.f64 %r74,0d0000000000000000; st.f64 [%frame+32],%r74; .loc 1 104 0 ld.global.u32 %r75,[__fdlib_version]; setp.ne.u32 %r76,%r75,2; @ %r76 bra $L26; .loc 1 105 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L27; $L26: .loc 1 106 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L27; .loc 1 107 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L27: .loc 1 109 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L28; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r40,[%frame+40]; st.u32 [%r86],%r40; $L28: .loc 1 111 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r42,%r87; $L17: .loc 1 115 0 mov.f32 %value,%r42; st.param.f32 [%value_out],%value; ret; } lib_a-wf_jn.o/ 0 0 0 644 8747 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: jnf .visible .func (.param .f32 %value_out) jnf (.param .u32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_jn.c" // BEGIN GLOBAL FUNCTION DECL: ynf .visible .func (.param .f32 %value_out) ynf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_jnf .extern .func (.param .f32 %value_out) __ieee754_jnf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_ynf .extern .func (.param .f32 %value_out) __ieee754_ynf (.param .u32 %in_ar0, .param .f32 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {106,110,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {121,110,102,0 }; // BEGIN GLOBAL FUNCTION DEF: jnf .visible .func (.param .f32 %value_out) jnf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r33; .reg .f32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .f32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .f64 %r67; mov.u32 %r36,%ar0; mov.f32 %r37,%ar1; .loc 1 32 0 { .param .f32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r36; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r37; call (%value_in),__ieee754_jnf,(%out_arg1,%out_arg2); ld.param.f32 %r40,[%value_in]; } mov.f32 %r35,%r40; .loc 1 33 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 34 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } setp.gt.f32 %r48,%r47,0f5a490fdb; @ ! %r48 bra $L1; .loc 1 36 0 mov.u32 %r49,5; st.u32 [%frame],%r49; .loc 1 37 0 cvta.const.u64 %r50,$LC0; st.u64 [%frame+8],%r50; .loc 1 38 0 mov.u32 %r51,0; st.u32 [%frame+40],%r51; .loc 1 39 0 cvt.rn.f64.s32 %r52,%r36; st.f64 [%frame+16],%r52; .loc 1 40 0 cvt.f64.f32 %r53,%r37; st.f64 [%frame+24],%r53; .loc 1 41 0 mov.f64 %r54,0d0000000000000000; st.f64 [%frame+32],%r54; .loc 1 42 0 ld.global.u32 %r55,[__fdlib_version]; setp.ne.u32 %r56,%r55,2; @ %r56 bra $L4; .loc 1 43 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; bra $L5; $L4: .loc 1 44 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r60,[%value_in]; } setp.ne.u32 %r61,%r60,0; @ %r61 bra $L5; .loc 1 45 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } mov.u32 %r63,34; st.u32 [%r62],%r63; $L5: .loc 1 47 0 ld.u32 %r64,[%frame+40]; setp.eq.u32 %r65,%r64,0; @ %r65 bra $L6; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r66],%r33; $L6: .loc 1 49 0 ld.f64 %r67,[%frame+32]; cvt.rn.f32.f64 %r35,%r67; $L1: .loc 1 53 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ynf .visible .func (.param .f32 %value_out) ynf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r26; .reg .u32 %r32; .reg .u32 %r42; .reg .f32 %r44; .reg .u32 %r45; .reg .f32 %r46; .reg .f32 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .u32 %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .pred %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .f64 %r75; .reg .pred %r76; .reg .u32 %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u32 %r88; .reg .pred %r89; .reg .u64 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .pred %r93; .reg .u64 %r94; .reg .f64 %r95; mov.u32 %r45,%ar0; mov.f32 %r46,%ar1; .loc 1 67 0 { .param .f32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r45; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r46; call (%value_in),__ieee754_ynf,(%out_arg1,%out_arg2); ld.param.f32 %r49,[%value_in]; } mov.f32 %r44,%r49; .loc 1 68 0 ld.global.u32 %r50,[__fdlib_version]; setp.eq.u32 %r51,%r50,-1; @ %r51 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.eq.u32 %r54,%r53,0; @ %r54 bra $L17; .loc 1 69 0 setp.le.f32 %r55,%r46,0f00000000; @ ! %r55 bra $L43; .loc 1 77 0 mov.u32 %r56,1; st.u32 [%frame],%r56; .loc 1 78 0 cvta.const.u64 %r57,$LC1; st.u64 [%frame+8],%r57; .loc 1 79 0 mov.u32 %r58,0; st.u32 [%frame+40],%r58; .loc 1 80 0 cvt.rn.f64.s32 %r59,%r45; st.f64 [%frame+16],%r59; .loc 1 81 0 cvt.f64.f32 %r60,%r46; st.f64 [%frame+24],%r60; .loc 1 82 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r61,%r26,0; @ %r61 bra $L21; .loc 1 83 0 mov.f64 %r62,0dc7efffffe0000000; st.f64 [%frame+32],%r62; bra $L22; $L21: .loc 1 85 0 mov.f64 %r63,0dfff0000000000000; st.f64 [%frame+32],%r63; .loc 1 86 0 setp.ne.u32 %r64,%r26,2; @ %r64 bra $L22; .loc 1 87 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L23; $L22: .loc 1 88 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.ne.u32 %r69,%r68,0; @ %r69 bra $L23; .loc 1 89 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; $L23: .loc 1 91 0 ld.u32 %r72,[%frame+40]; setp.eq.u32 %r73,%r72,0; @ %r73 bra $L24; .loc 1 92 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r74],%r32; $L24: .loc 1 93 0 ld.f64 %r75,[%frame+32]; cvt.rn.f32.f64 %r44,%r75; bra $L17; $L43: .loc 1 95 0 setp.gt.f32 %r76,%r46,0f5a490fdb; @ ! %r76 bra $L17; .loc 1 97 0 mov.u32 %r77,5; st.u32 [%frame],%r77; .loc 1 98 0 cvta.const.u64 %r78,$LC1; st.u64 [%frame+8],%r78; .loc 1 99 0 mov.u32 %r79,0; st.u32 [%frame+40],%r79; .loc 1 100 0 cvt.rn.f64.s32 %r80,%r45; st.f64 [%frame+16],%r80; .loc 1 101 0 cvt.f64.f32 %r81,%r46; st.f64 [%frame+24],%r81; .loc 1 102 0 mov.f64 %r82,0d0000000000000000; st.f64 [%frame+32],%r82; .loc 1 103 0 ld.global.u32 %r83,[__fdlib_version]; setp.ne.u32 %r84,%r83,2; @ %r84 bra $L26; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r85,[%value_in]; } mov.u32 %r86,34; st.u32 [%r85],%r86; bra $L27; $L26: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r88,[%value_in]; } setp.ne.u32 %r89,%r88,0; @ %r89 bra $L27; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r90,[%value_in]; } mov.u32 %r91,34; st.u32 [%r90],%r91; $L27: .loc 1 108 0 ld.u32 %r92,[%frame+40]; setp.eq.u32 %r93,%r92,0; @ %r93 bra $L28; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r94,[%value_in]; } ld.u32 %r42,[%frame+40]; st.u32 [%r94],%r42; $L28: .loc 1 110 0 ld.f64 %r95,[%frame+32]; cvt.rn.f32.f64 %r44,%r95; $L17: .loc 1 114 0 mov.f32 %value,%r44; st.param.f32 [%value_out],%value; ret; } /1568 0 0 0 644 5170 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgammaf .visible .func (.param .f32 %value_out) lgammaf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .extern .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {108,103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: lgammaf .visible .func (.param .f32 %value_out) lgammaf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r27; .reg .u32 %r38; .reg .u32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .u64 %r45; .reg .u64 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f32 %r63; .reg .pred %r64; .reg .pred %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r42,%ar0; .loc 1 33 0 ld.global.u64 %r46,[_impure_ptr]; add.u64 %r45,%r46,224; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r45; call (%value_in),__ieee754_lgammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r47,[%value_in]; } mov.f32 %r41,%r47; .loc 1 34 0 ld.global.u32 %r48,[__fdlib_version]; setp.eq.u32 %r49,%r48,-1; @ %r49 bra $L1; .loc 1 35 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r47; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.ne.u32 %r52,%r51,0; @ %r52 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r54,[%value_in]; } setp.eq.u32 %r55,%r54,0; @ %r55 bra $L1; .loc 1 42 0 cvta.const.u64 %r56,$LC0; st.u64 [%frame+8],%r56; .loc 1 43 0 st.u32 [%frame+40],%r51; .loc 1 44 0 cvt.f64.f32 %r27,%r42; st.f64 [%frame+24],%r27; st.f64 [%frame+16],%r27; .loc 1 45 0 ld.global.u32 %r58,[__fdlib_version]; setp.ne.u32 %r59,%r58,0; @ %r59 bra $L3; .loc 1 46 0 mov.f64 %r60,0d47efffffe0000000; st.f64 [%frame+32],%r60; bra $L4; $L3: .loc 1 48 0 mov.f64 %r61,0d7ff0000000000000; st.f64 [%frame+32],%r61; $L4: .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r63,[%value_in]; } setp.neu.f32 %r64,%r63,%r42; @ %r64 bra $L5; ld.global.u32 %r40,[__fdlib_version]; setp.le.f32 %r65,%r42,0f00000000; @ ! %r65 bra $L6; .loc 1 51 0 mov.u32 %r66,2; st.u32 [%frame],%r66; .loc 1 52 0 setp.ne.u32 %r67,%r40,2; @ %r67 bra $L8; .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L9; $L8: .loc 1 54 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r71,[%value_in]; } setp.eq.u32 %r72,%r71,0; @ ! %r72 bra $L9; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } mov.u32 %r74,33; st.u32 [%r73],%r74; bra $L9; $L5: ld.global.u32 %r40,[__fdlib_version]; $L6: .loc 1 60 0 mov.u32 %r75,3; st.u32 [%frame],%r75; .loc 1 61 0 setp.ne.u32 %r76,%r40,2; @ %r76 bra $L11; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L9; $L11: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L9; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L9: .loc 1 67 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L13; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r38,[%frame+40]; st.u32 [%r86],%r38; $L13: .loc 1 69 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r41,%r87; $L1: .loc 1 73 0 mov.f32 %value,%r41; st.param.f32 [%value_out],%value; ret; } lib_a-wf_log.o/ 0 0 0 644 4971 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: logf .visible .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_log.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {108,111,103,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: logf .visible .func (.param .f32 %value_out) logf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .pred %r53; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .f64 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u64 %r76; .reg .f64 %r77; .reg .u32 %r79; .reg .u32 %r80; mov.f32 %r38,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r40,[%value_in]; } mov.f32 %r37,%r40; .loc 1 36 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; setp.gt.f32 %r46,%r38,0f00000000; @ %r46 bra $L1; .loc 1 43 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 44 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 45 0 cvt.f64.f32 %r24,%r38; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 46 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r49,%r25,0; @ %r49 bra $L3; .loc 1 47 0 mov.f64 %r50,0dc7efffffe0000000; st.f64 [%frame+32],%r50; .loc 1 50 0 setp.eq.f32 %r51,%r38,0f00000000; @ %r51 bra $L4; bra $L21; $L3: .loc 1 49 0 mov.f64 %r52,0dfff0000000000000; st.f64 [%frame+32],%r52; .loc 1 50 0 setp.neu.f32 %r53,%r38,0f00000000; @ %r53 bra $L6; .loc 1 52 0 mov.u32 %r54,2; st.u32 [%frame],%r54; .loc 1 53 0 setp.ne.u32 %r55,%r25,2; @ %r55 bra $L7; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,34; st.u32 [%r56],%r57; bra $L8; $L7: .loc 1 55 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.ne.u32 %r60,%r59,0; @ %r60 bra $L8; .loc 1 56 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } mov.u32 %r62,34; st.u32 [%r61],%r62; bra $L8; $L6: .loc 1 60 0 mov.u32 %r63,1; st.u32 [%frame],%r63; .loc 1 61 0 setp.ne.u32 %r64,%r25,2; @ %r64 bra $L9; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L10; $L9: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.ne.u32 %r69,%r68,0; @ %r69 bra $L10; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; $L10: .loc 1 66 0 cvta.const.u64 %r72,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r72; call (%value_in),nan,(%out_arg1); ld.param.f64 %r73,[%value_in]; } st.f64 [%frame+32],%r73; $L8: .loc 1 68 0 ld.u32 %r74,[%frame+40]; setp.eq.u32 %r75,%r74,0; @ %r75 bra $L11; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r76,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r76],%r35; $L11: .loc 1 70 0 ld.f64 %r77,[%frame+32]; cvt.rn.f32.f64 %r37,%r77; bra $L1; $L4: .loc 1 52 0 mov.u32 %r79,2; st.u32 [%frame],%r79; bra $L7; $L21: .loc 1 60 0 mov.u32 %r80,1; st.u32 [%frame],%r80; bra $L9; $L1: .loc 1 72 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /1587 0 0 0 644 5010 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: log10f .visible .func (.param .f32 %value_out) log10f (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_log10.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10f .extern .func (.param .f32 %value_out) __ieee754_log10f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {108,111,103,49,48,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: log10f .visible .func (.param .f32 %value_out) log10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .pred %r53; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .f64 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u64 %r76; .reg .f64 %r77; .reg .u32 %r79; .reg .u32 %r80; mov.f32 %r38,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__ieee754_log10f,(%out_arg1); ld.param.f32 %r40,[%value_in]; } mov.f32 %r37,%r40; .loc 1 36 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 37 0 setp.le.f32 %r46,%r38,0f00000000; @ ! %r46 bra $L1; .loc 1 44 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 45 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 46 0 cvt.f64.f32 %r24,%r38; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 47 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r49,%r25,0; @ %r49 bra $L4; .loc 1 48 0 mov.f64 %r50,0dc7efffffe0000000; st.f64 [%frame+32],%r50; .loc 1 51 0 setp.eq.f32 %r51,%r38,0f00000000; @ %r51 bra $L5; bra $L23; $L4: .loc 1 50 0 mov.f64 %r52,0dfff0000000000000; st.f64 [%frame+32],%r52; .loc 1 51 0 setp.neu.f32 %r53,%r38,0f00000000; @ %r53 bra $L7; .loc 1 53 0 mov.u32 %r54,2; st.u32 [%frame],%r54; .loc 1 54 0 setp.ne.u32 %r55,%r25,2; @ %r55 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,34; st.u32 [%r56],%r57; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.ne.u32 %r60,%r59,0; @ %r60 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } mov.u32 %r62,34; st.u32 [%r61],%r62; bra $L9; $L7: .loc 1 61 0 mov.u32 %r63,1; st.u32 [%frame],%r63; .loc 1 62 0 setp.ne.u32 %r64,%r25,2; @ %r64 bra $L10; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L11; $L10: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.ne.u32 %r69,%r68,0; @ %r69 bra $L11; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; $L11: .loc 1 67 0 cvta.const.u64 %r72,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r72; call (%value_in),nan,(%out_arg1); ld.param.f64 %r73,[%value_in]; } st.f64 [%frame+32],%r73; $L9: .loc 1 69 0 ld.u32 %r74,[%frame+40]; setp.eq.u32 %r75,%r74,0; @ %r75 bra $L12; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r76,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r76],%r35; $L12: .loc 1 71 0 ld.f64 %r77,[%frame+32]; cvt.rn.f32.f64 %r37,%r77; bra $L1; $L5: .loc 1 53 0 mov.u32 %r79,2; st.u32 [%frame],%r79; bra $L8; $L23: .loc 1 61 0 mov.u32 %r80,1; st.u32 [%frame],%r80; bra $L10; $L1: .loc 1 75 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-wf_pow.o/ 0 0 0 644 16084 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: powf .visible .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_pow.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_powf .extern .func (.param .f32 %value_out) __ieee754_powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {112,111,119,102,0 }; // BEGIN GLOBAL FUNCTION DEF: powf .visible .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u32 %r42; .reg .u32 %r46; .reg .u32 %r52; .reg .u32 %r60; .reg .u32 %r67; .reg .f64 %r72; .reg .f64 %r74; .reg .u32 %r82; .reg .u32 %r94; .reg .u32 %r96; .reg .f32 %r97; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r107; .reg .u32 %r108; .reg .pred %r109; .reg .u32 %r111; .reg .pred %r112; .reg .u32 %r114; .reg .pred %r115; .reg .pred %r116; .reg .u32 %r117; .reg .u64 %r118; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r127; .reg .u32 %r128; .reg .u16 %r129; .reg .u16 %r130; .reg .u16 %r131; .reg .u32 %r132; .reg .u16 %r133; .reg .pred %r134; .reg .u32 %r136; .reg .pred %r137; .reg .u64 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .pred %r141; .reg .f64 %r142; .reg .u64 %r143; .reg .f64 %r144; .reg .pred %r145; .reg .pred %r146; .reg .u32 %r147; .reg .u64 %r148; .reg .u32 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .u32 %r153; .reg .pred %r154; .reg .u32 %r156; .reg .pred %r157; .reg .u64 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .pred %r161; .reg .f64 %r162; .reg .u64 %r163; .reg .f64 %r164; .reg .u32 %r166; .reg .pred %r167; .reg .pred %r168; .reg .u32 %r169; .reg .u64 %r170; .reg .u32 %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .pred %r174; .reg .f64 %r175; .reg .f64 %r176; .reg .pred %r177; .reg .u64 %r178; .reg .u32 %r179; .reg .u32 %r181; .reg .pred %r182; .reg .u64 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .pred %r186; .reg .u64 %r187; .reg .f64 %r188; .reg .u32 %r190; .reg .pred %r191; .reg .u32 %r193; .reg .pred %r194; .reg .u32 %r196; .reg .pred %r197; .reg .u32 %r199; .reg .pred %r200; .reg .u32 %r201; .reg .u64 %r202; .reg .f64 %r204; .reg .f64 %r205; .reg .pred %r206; .reg .f64 %r207; .reg .f64 %r208; .reg .f64 %r209; .reg .pred %r210; .reg .u64 %r211; .reg .u32 %r212; .reg .u32 %r214; .reg .pred %r215; .reg .u64 %r216; .reg .u32 %r217; .reg .u32 %r218; .reg .pred %r219; .reg .u64 %r220; .reg .f64 %r221; .reg .u32 %r222; .reg .u64 %r223; .reg .f64 %r225; .reg .f64 %r226; .reg .pred %r228; .reg .f64 %r229; .reg .pred %r230; .reg .f64 %r232; .reg .pred %r233; .reg .f64 %r234; .reg .f64 %r235; .reg .pred %r236; .reg .f64 %r238; .reg .pred %r239; .reg .f64 %r240; .reg .pred %r242; .reg .u64 %r243; .reg .u32 %r244; .reg .u32 %r246; .reg .pred %r247; .reg .u64 %r248; .reg .u32 %r249; .reg .u32 %r250; .reg .pred %r251; .reg .u64 %r252; .reg .f64 %r253; .reg .pred %r254; .reg .u32 %r256; .reg .pred %r257; .reg .u32 %r259; .reg .pred %r260; .reg .u32 %r261; .reg .u64 %r262; .reg .u32 %r263; .reg .f64 %r264; .reg .f64 %r265; .reg .f64 %r266; .reg .u32 %r267; .reg .pred %r268; .reg .u64 %r269; .reg .u32 %r270; .reg .u32 %r272; .reg .pred %r273; .reg .u64 %r274; .reg .u32 %r275; .reg .u32 %r276; .reg .pred %r277; .reg .u64 %r278; .reg .f64 %r279; .reg .u32 %r281; mov.f32 %r103,%ar0; mov.f32 %r104,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r104; call (%value_in),__ieee754_powf,(%out_arg1,%out_arg2); ld.param.f32 %r107,[%value_in]; } mov.f32 %r102,%r107; .loc 1 36 0 ld.global.u32 %r108,[__fdlib_version]; setp.eq.u32 %r109,%r108,-1; @ %r109 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r111,[%value_in]; } setp.eq.u32 %r112,%r111,0; @ %r112 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r114,[%value_in]; } setp.ne.u32 %r115,%r114,0; @ %r115 bra $L3; .loc 1 38 0 setp.neu.f32 %r116,%r104,0f00000000; @ %r116 bra $L1; .loc 1 41 0 mov.u32 %r117,1; st.u32 [%frame],%r117; .loc 1 42 0 cvta.const.u64 %r118,$LC0; st.u64 [%frame+8],%r118; .loc 1 43 0 st.u32 [%frame+40],%r114; .loc 1 44 0 cvt.f64.f32 %r120,%r103; st.f64 [%frame+16],%r120; .loc 1 45 0 cvt.f64.f32 %r121,%r104; st.f64 [%frame+24],%r121; .loc 1 46 0 mov.f64 %r122,0d3ff0000000000000; st.f64 [%frame+32],%r122; .loc 1 47 0 ld.global.u32 %r96,[__fdlib_version]; set.u32.eq.u32 %r124,%r96,-1; neg.s32 %r125,%r124; set.u32.eq.u32 %r127,%r96,2; neg.s32 %r128,%r127; cvt.u16.u32 %r130,%r125; cvt.u16.u32 %r131,%r128; or.b16 %r129,%r130,%r131; cvt.u32.u16 %r132,%r129; cvt.u16.u8 %r133,%r132; setp.ne.u16 %r134,%r133,0; @ %r134 bra $L35; .loc 1 49 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r136,[%value_in]; } setp.ne.u32 %r137,%r136,0; @ %r137 bra $L5; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r138,[%value_in]; } mov.u32 %r139,33; st.u32 [%r138],%r139; $L5: .loc 1 52 0 ld.u32 %r140,[%frame+40]; setp.ne.u32 %r141,%r140,0; @ %r141 bra $L6; ld.f64 %r142,[%frame+32]; cvt.rn.f32.f64 %r102,%r142; bra $L1; $L6: .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r143,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r143],%r34; ld.f64 %r144,[%frame+32]; cvt.rn.f32.f64 %r102,%r144; bra $L1; $L35: mov.f32 %r102,0f3f800000; .loc 1 54 0 bra $L1; $L3: .loc 1 58 0 setp.neu.f32 %r145,%r103,0f00000000; @ %r145 bra $L7; .loc 1 59 0 setp.neu.f32 %r146,%r104,0f00000000; @ %r146 bra $L8; .loc 1 62 0 mov.u32 %r147,1; st.u32 [%frame],%r147; .loc 1 63 0 cvta.const.u64 %r148,$LC0; st.u64 [%frame+8],%r148; .loc 1 64 0 mov.u32 %r149,0; st.u32 [%frame+40],%r149; .loc 1 65 0 cvt.f64.f32 %r150,%r103; st.f64 [%frame+16],%r150; .loc 1 66 0 cvt.f64.f32 %r151,%r104; st.f64 [%frame+24],%r151; .loc 1 67 0 mov.f64 %r152,0d0000000000000000; st.f64 [%frame+32],%r152; .loc 1 68 0 ld.global.u32 %r153,[__fdlib_version]; setp.ne.u32 %r154,%r153,0; @ %r154 bra $L36; .loc 1 69 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r156,[%value_in]; } setp.ne.u32 %r157,%r156,0; @ %r157 bra $L10; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r158,[%value_in]; } mov.u32 %r159,33; st.u32 [%r158],%r159; $L10: .loc 1 72 0 ld.u32 %r160,[%frame+40]; setp.ne.u32 %r161,%r160,0; @ %r161 bra $L11; ld.f64 %r162,[%frame+32]; cvt.rn.f32.f64 %r102,%r162; bra $L1; $L11: .loc 1 73 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r163,[%value_in]; } ld.u32 %r42,[%frame+40]; st.u32 [%r163],%r42; ld.f64 %r164,[%frame+32]; cvt.rn.f32.f64 %r102,%r164; bra $L1; $L36: mov.f32 %r102,0f3f800000; .loc 1 74 0 bra $L1; $L8: .loc 1 76 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r166,[%value_in]; } setp.eq.u32 %r167,%r166,0; @ %r167 bra $L1; setp.lt.f32 %r168,%r104,0f00000000; @ ! %r168 bra $L1; .loc 1 78 0 mov.u32 %r169,1; st.u32 [%frame],%r169; .loc 1 79 0 cvta.const.u64 %r170,$LC0; st.u64 [%frame+8],%r170; .loc 1 80 0 mov.u32 %r171,0; st.u32 [%frame+40],%r171; .loc 1 81 0 cvt.f64.f32 %r172,%r103; st.f64 [%frame+16],%r172; .loc 1 82 0 cvt.f64.f32 %r173,%r104; st.f64 [%frame+24],%r173; .loc 1 83 0 ld.global.u32 %r46,[__fdlib_version]; setp.ne.u32 %r174,%r46,0; @ %r174 bra $L13; .loc 1 84 0 mov.f64 %r175,0d0000000000000000; st.f64 [%frame+32],%r175; bra $L14; $L13: .loc 1 86 0 mov.f64 %r176,0dfff0000000000000; st.f64 [%frame+32],%r176; .loc 1 87 0 setp.ne.u32 %r177,%r46,2; @ %r177 bra $L14; .loc 1 88 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r178,[%value_in]; } mov.u32 %r179,33; st.u32 [%r178],%r179; bra $L15; $L14: .loc 1 89 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r181,[%value_in]; } setp.ne.u32 %r182,%r181,0; @ %r182 bra $L15; .loc 1 90 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r183,[%value_in]; } mov.u32 %r184,33; st.u32 [%r183],%r184; $L15: .loc 1 92 0 ld.u32 %r185,[%frame+40]; setp.eq.u32 %r186,%r185,0; @ %r186 bra $L16; .loc 1 93 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r187,[%value_in]; } ld.u32 %r52,[%frame+40]; st.u32 [%r187],%r52; $L16: .loc 1 94 0 ld.f64 %r188,[%frame+32]; cvt.rn.f32.f64 %r102,%r188; bra $L1; $L7: .loc 1 98 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r107; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r190,[%value_in]; } setp.ne.u32 %r191,%r190,0; @ %r191 bra $L17; .loc 1 99 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r193,[%value_in]; } setp.eq.u32 %r194,%r193,0; @ %r194 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r196,[%value_in]; } setp.eq.u32 %r197,%r196,0; @ %r197 bra $L17; .loc 1 100 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r107; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r199,[%value_in]; } setp.ne.u32 %r200,%r199,0; @ %r200 bra $L18; .loc 1 102 0 mov.u32 %r201,1; st.u32 [%frame],%r201; .loc 1 103 0 cvta.const.u64 %r202,$LC0; st.u64 [%frame+8],%r202; .loc 1 104 0 st.u32 [%frame+40],%r199; .loc 1 105 0 cvt.f64.f32 %r204,%r103; st.f64 [%frame+16],%r204; .loc 1 106 0 cvt.f64.f32 %r205,%r104; st.f64 [%frame+24],%r205; .loc 1 107 0 ld.global.u32 %r60,[__fdlib_version]; setp.ne.u32 %r206,%r60,0; @ %r206 bra $L19; .loc 1 108 0 mov.f64 %r207,0d0000000000000000; st.f64 [%frame+32],%r207; bra $L20; $L19: .loc 1 110 0 mov.f64 %r209,0d0000000000000000; div.rn.f64 %r208,%r209,0d0000000000000000; st.f64 [%frame+32],%r208; .loc 1 111 0 setp.ne.u32 %r210,%r60,2; @ %r210 bra $L20; .loc 1 112 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r211,[%value_in]; } mov.u32 %r212,33; st.u32 [%r211],%r212; bra $L21; $L20: .loc 1 113 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r214,[%value_in]; } setp.ne.u32 %r215,%r214,0; @ %r215 bra $L21; .loc 1 114 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r216,[%value_in]; } mov.u32 %r217,33; st.u32 [%r216],%r217; $L21: .loc 1 116 0 ld.u32 %r218,[%frame+40]; setp.eq.u32 %r219,%r218,0; @ %r219 bra $L22; .loc 1 117 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r220,[%value_in]; } ld.u32 %r67,[%frame+40]; st.u32 [%r220],%r67; $L22: .loc 1 118 0 ld.f64 %r221,[%frame+32]; cvt.rn.f32.f64 %r102,%r221; bra $L1; $L18: .loc 1 121 0 mov.u32 %r222,3; st.u32 [%frame],%r222; .loc 1 122 0 cvta.const.u64 %r223,$LC0; st.u64 [%frame+8],%r223; .loc 1 123 0 st.u32 [%frame+40],%r190; .loc 1 124 0 cvt.f64.f32 %r225,%r103; st.f64 [%frame+16],%r225; .loc 1 125 0 cvt.f64.f32 %r226,%r104; st.f64 [%frame+24],%r226; mul.f32 %r97,%r104,0f3f000000; .loc 1 126 0 ld.global.u32 %r281,[__fdlib_version]; setp.ne.u32 %r228,%r281,0; @ %r228 bra $L23; .loc 1 127 0 mov.f64 %r229,0d47efffffe0000000; st.f64 [%frame+32],%r229; .loc 1 129 0 setp.lt.f32 %r230,%r103,0f00000000; @ ! %r230 bra $L24; cvt.f64.f32 %r72,%r97; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),rint,(%out_arg1); ld.param.f64 %r232,[%value_in]; } setp.neu.f64 %r233,%r72,%r232; @ %r233 bra $L26; ld.global.u32 %r281,[__fdlib_version]; bra $L27; $L26: mov.f64 %r234,0dc7efffffe0000000; st.f64 [%frame+32],%r234; ld.global.u32 %r281,[__fdlib_version]; bra $L27; $L23: .loc 1 131 0 mov.f64 %r235,0d7ff0000000000000; st.f64 [%frame+32],%r235; .loc 1 133 0 setp.lt.f32 %r236,%r103,0f00000000; @ ! %r236 bra $L27; cvt.f64.f32 %r74,%r97; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),rint,(%out_arg1); ld.param.f64 %r238,[%value_in]; } setp.eq.f64 %r239,%r74,%r238; @ ! %r239 bra $L74; ld.global.u32 %r281,[__fdlib_version]; bra $L27; $L74: mov.f64 %r240,0dfff0000000000000; st.f64 [%frame+32],%r240; ld.global.u32 %r281,[__fdlib_version]; $L27: .loc 1 135 0 setp.ne.u32 %r242,%r281,2; @ %r242 bra $L24; .loc 1 136 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r243,[%value_in]; } mov.u32 %r244,34; st.u32 [%r243],%r244; bra $L30; $L24: .loc 1 137 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r246,[%value_in]; } setp.ne.u32 %r247,%r246,0; @ %r247 bra $L30; .loc 1 138 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r248,[%value_in]; } mov.u32 %r249,34; st.u32 [%r248],%r249; $L30: .loc 1 140 0 ld.u32 %r250,[%frame+40]; setp.eq.u32 %r251,%r250,0; @ %r251 bra $L31; .loc 1 141 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r252,[%value_in]; } ld.u32 %r82,[%frame+40]; st.u32 [%r252],%r82; $L31: .loc 1 142 0 ld.f64 %r253,[%frame+32]; cvt.rn.f32.f64 %r102,%r253; bra $L1; $L17: .loc 1 146 0 setp.neu.f32 %r254,%r107,0f00000000; @ %r254 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r256,[%value_in]; } setp.eq.u32 %r257,%r256,0; @ %r257 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r259,[%value_in]; } setp.eq.u32 %r260,%r259,0; @ %r260 bra $L1; .loc 1 148 0 mov.u32 %r261,4; st.u32 [%frame],%r261; .loc 1 149 0 cvta.const.u64 %r262,$LC0; st.u64 [%frame+8],%r262; .loc 1 150 0 mov.u32 %r263,0; st.u32 [%frame+40],%r263; .loc 1 151 0 cvt.f64.f32 %r264,%r103; st.f64 [%frame+16],%r264; .loc 1 152 0 cvt.f64.f32 %r265,%r104; st.f64 [%frame+24],%r265; .loc 1 153 0 mov.f64 %r266,0d0000000000000000; st.f64 [%frame+32],%r266; .loc 1 154 0 ld.global.u32 %r267,[__fdlib_version]; setp.ne.u32 %r268,%r267,2; @ %r268 bra $L32; .loc 1 155 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r269,[%value_in]; } mov.u32 %r270,34; st.u32 [%r269],%r270; bra $L33; $L32: .loc 1 156 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r272,[%value_in]; } setp.ne.u32 %r273,%r272,0; @ %r273 bra $L33; .loc 1 157 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r274,[%value_in]; } mov.u32 %r275,34; st.u32 [%r274],%r275; $L33: .loc 1 159 0 ld.u32 %r276,[%frame+40]; setp.eq.u32 %r277,%r276,0; @ %r277 bra $L34; .loc 1 160 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r278,[%value_in]; } ld.u32 %r94,[%frame+40]; st.u32 [%r278],%r94; $L34: .loc 1 161 0 ld.f64 %r279,[%frame+32]; cvt.rn.f32.f64 %r102,%r279; $L1: .loc 1 165 0 mov.f32 %value,%r102; st.param.f32 [%value_out],%value; ret; } /1605 0 0 0 644 4046 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: remainderf .visible .func (.param .f32 %value_out) remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_remainder.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainderf .extern .func (.param .f32 %value_out) __ieee754_remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[11] = {114,101,109,97,105,110,100,101,114,102,0 }; // BEGIN GLOBAL FUNCTION DEF: remainderf .visible .func (.param .f32 %value_out) remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r33; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r43; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r47; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .u32 %r53; .reg .u16 %r54; .reg .u16 %r55; .reg .u16 %r56; .reg .u32 %r57; .reg .u16 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .f64 %r79; mov.f32 %r39,%ar0; mov.f32 %r40,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r40; call (%value_in),__ieee754_remainderf,(%out_arg1,%out_arg2); ld.param.f32 %r43,[%value_in]; } mov.f32 %r38,%r43; .loc 1 36 0 ld.global.u32 %r44,[__fdlib_version]; setp.eq.u32 %r45,%r44,-1; @ %r45 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r47,[%value_in]; } .loc 1 37 0 set.u32.eq.f32 %r49,%r40,0f00000000; neg.s32 %r50,%r49; .loc 1 36 0 set.u32.ne.u32 %r52,%r47,0; neg.s32 %r53,%r52; .loc 1 37 0 cvt.u16.u32 %r55,%r50; cvt.u16.u32 %r56,%r53; and.b16 %r54,%r55,%r56; cvt.u32.u16 %r57,%r54; cvt.u16.u8 %r58,%r57; setp.eq.u16 %r59,%r58,0; @ %r59 bra $L1; .loc 1 39 0 mov.u32 %r60,1; st.u32 [%frame],%r60; .loc 1 40 0 cvta.const.u64 %r61,$LC0; st.u64 [%frame+8],%r61; .loc 1 41 0 mov.u32 %r62,0; st.u32 [%frame+40],%r62; .loc 1 42 0 cvt.f64.f32 %r63,%r39; st.f64 [%frame+16],%r63; .loc 1 43 0 cvt.f64.f32 %r64,%r40; st.f64 [%frame+24],%r64; .loc 1 44 0 mov.f64 %r66,0d0000000000000000; div.rn.f64 %r65,%r66,0d0000000000000000; st.f64 [%frame+32],%r65; .loc 1 45 0 ld.global.u32 %r67,[__fdlib_version]; setp.ne.u32 %r68,%r67,2; @ %r68 bra $L3; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r69,[%value_in]; } mov.u32 %r70,33; st.u32 [%r69],%r70; bra $L4; $L3: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r72,[%value_in]; } setp.ne.u32 %r73,%r72,0; @ %r73 bra $L4; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } mov.u32 %r75,33; st.u32 [%r74],%r75; $L4: .loc 1 50 0 ld.u32 %r76,[%frame+40]; setp.eq.u32 %r77,%r76,0; @ %r77 bra $L5; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r78,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r78],%r33; $L5: .loc 1 52 0 ld.f64 %r79,[%frame+32]; cvt.rn.f32.f64 %r38,%r79; $L1: .loc 1 56 0 mov.f32 %value,%r38; st.param.f32 [%value_out],%value; ret; } /1627 0 0 0 644 6973 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: scalbf .visible .func (.param .f32 %value_out) scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/math/wf_scalb.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalbf .extern .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {115,99,97,108,98,102,0 }; // BEGIN GLOBAL FUNCTION DEF: scalbf .visible .func (.param .f32 %value_out) scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .f64 %r39; .reg .u32 %r48; .reg .f64 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r65; .reg .pred %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u32 %r70; .reg .u64 %r71; .reg .f64 %r73; .reg .f64 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .u64 %r87; .reg .f64 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r93; .reg .u32 %r94; .reg .u16 %r95; .reg .u16 %r96; .reg .u16 %r97; .reg .u32 %r98; .reg .u16 %r99; .reg .pred %r100; .reg .u32 %r101; .reg .u64 %r102; .reg .u32 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r107; .reg .u32 %r108; .reg .pred %r109; .reg .u64 %r110; .reg .u32 %r111; .reg .u32 %r113; .reg .pred %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .pred %r118; .reg .u64 %r119; .reg .f64 %r120; .reg .u32 %r122; .reg .pred %r123; .reg .u64 %r124; .reg .u32 %r125; mov.f32 %r54,%ar0; mov.f32 %r55,%ar1; .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r54; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r55; call (%value_in),__ieee754_scalbf,(%out_arg1,%out_arg2); ld.param.f32 %r58,[%value_in]; } mov.f32 %r53,%r58; .loc 1 52 0 ld.global.u32 %r59,[__fdlib_version]; setp.eq.u32 %r60,%r59,-1; @ %r60 bra $L1; .loc 1 53 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L3; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r65,[%value_in]; } setp.eq.u32 %r66,%r65,0; @ %r66 bra $L3; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r54; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.eq.u32 %r69,%r68,0; @ %r69 bra $L3; .loc 1 55 0 mov.u32 %r70,3; st.u32 [%frame],%r70; .loc 1 56 0 cvta.const.u64 %r71,$LC0; st.u64 [%frame+8],%r71; .loc 1 57 0 st.u32 [%frame+40],%r62; .loc 1 58 0 cvt.f64.f32 %r73,%r54; st.f64 [%frame+16],%r73; .loc 1 59 0 cvt.f64.f32 %r74,%r55; st.f64 [%frame+24],%r74; .loc 1 60 0 setp.gt.f32 %r75,%r54,0f00000000; selp.f64 %r52,0d7ff0000000000000,0dfff0000000000000,%r75; st.f64 [%frame+32],%r52; .loc 1 61 0 ld.global.u32 %r76,[__fdlib_version]; setp.ne.u32 %r77,%r76,2; @ %r77 bra $L5; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r78,[%value_in]; } mov.u32 %r79,34; st.u32 [%r78],%r79; bra $L6; $L5: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r81,[%value_in]; } setp.ne.u32 %r82,%r81,0; @ %r82 bra $L6; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } mov.u32 %r84,34; st.u32 [%r83],%r84; $L6: .loc 1 66 0 ld.u32 %r85,[%frame+40]; setp.eq.u32 %r86,%r85,0; @ %r86 bra $L7; .loc 1 67 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r87,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r87],%r34; $L7: .loc 1 68 0 ld.f64 %r88,[%frame+32]; cvt.rn.f32.f64 %r53,%r88; bra $L1; $L3: .loc 1 70 0 set.u32.eq.f32 %r90,%r58,0f00000000; neg.s32 %r91,%r90; set.u32.neu.f32 %r93,%r54,%r58; neg.s32 %r94,%r93; cvt.u16.u32 %r96,%r91; cvt.u16.u32 %r97,%r94; and.b16 %r95,%r96,%r97; cvt.u32.u16 %r98,%r95; cvt.u16.u8 %r99,%r98; setp.eq.u16 %r100,%r99,0; @ %r100 bra $L8; .loc 1 72 0 mov.u32 %r101,4; st.u32 [%frame],%r101; .loc 1 73 0 cvta.const.u64 %r102,$LC0; st.u64 [%frame+8],%r102; .loc 1 74 0 mov.u32 %r103,0; st.u32 [%frame+40],%r103; .loc 1 75 0 cvt.f64.f32 %r39,%r54; st.f64 [%frame+16],%r39; .loc 1 76 0 cvt.f64.f32 %r104,%r55; st.f64 [%frame+24],%r104; .loc 1 77 0 mov.f64 %r105,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r105; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r39; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r107,[%value_in]; } st.f64 [%frame+32],%r107; .loc 1 78 0 ld.global.u32 %r108,[__fdlib_version]; setp.ne.u32 %r109,%r108,2; @ %r109 bra $L9; .loc 1 79 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r110,[%value_in]; } mov.u32 %r111,34; st.u32 [%r110],%r111; bra $L10; $L9: .loc 1 80 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r113,[%value_in]; } setp.ne.u32 %r114,%r113,0; @ %r114 bra $L10; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r115,[%value_in]; } mov.u32 %r116,34; st.u32 [%r115],%r116; $L10: .loc 1 83 0 ld.u32 %r117,[%frame+40]; setp.eq.u32 %r118,%r117,0; @ %r118 bra $L11; .loc 1 84 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r119,[%value_in]; } ld.u32 %r48,[%frame+40]; st.u32 [%r119],%r48; $L11: .loc 1 85 0 ld.f64 %r120,[%frame+32]; cvt.rn.f32.f64 %r53,%r120; bra $L1; $L8: .loc 1 88 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r55; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r122,[%value_in]; } setp.ne.u32 %r123,%r122,0; @ %r123 bra $L1; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r124,[%value_in]; } mov.u32 %r125,34; st.u32 [%r124],%r125; $L1: .loc 1 92 0 mov.f32 %value,%r53; st.param.f32 [%value_out],%value; ret; } /1645 0 0 0 644 1241 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sincosf .visible .func sincosf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libm/math/wf_sincos.c" // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sincosf .visible .func sincosf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f32 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .f32 %r28; .reg .f32 %r30; mov.f32 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 15 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r28,[%value_in]; } st.f32 [%r25],%r28; .loc 1 16 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r30,[%value_in]; } st.f32 [%r26],%r30; .loc 1 17 0 ret; } lib_a-wf_sinh.o/0 0 0 644 3781 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sinhf .visible .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_sinh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinhf .extern .func (.param .f32 %value_out) __ieee754_sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {115,105,110,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: sinhf .visible .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r26; .reg .u32 %r32; .reg .f64 %r34; .reg .f64 %r35; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r39; .reg .u32 %r40; .reg .pred %r41; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .f64 %r65; mov.f32 %r37,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),__ieee754_sinhf,(%out_arg1); ld.param.f32 %r39,[%value_in]; } mov.f32 %r36,%r39; .loc 1 36 0 ld.global.u32 %r40,[__fdlib_version]; setp.eq.u32 %r41,%r40,-1; @ %r41 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r43,[%value_in]; } setp.ne.u32 %r44,%r43,0; @ %r44 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.eq.u32 %r47,%r46,0; @ %r47 bra $L1; .loc 1 45 0 mov.u32 %r48,3; st.u32 [%frame],%r48; .loc 1 46 0 cvta.const.u64 %r49,$LC0; st.u64 [%frame+8],%r49; .loc 1 47 0 st.u32 [%frame+40],%r43; .loc 1 48 0 cvt.f64.f32 %r25,%r37; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 49 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r51,%r26,0; @ %r51 bra $L3; .loc 1 50 0 setp.gt.f32 %r52,%r37,0f00000000; selp.f64 %r34,0d47efffffe0000000,0dc7efffffe0000000,%r52; st.f64 [%frame+32],%r34; bra $L5; $L3: .loc 1 52 0 setp.gt.f32 %r53,%r37,0f00000000; selp.f64 %r35,0d7ff0000000000000,0dfff0000000000000,%r53; st.f64 [%frame+32],%r35; .loc 1 53 0 setp.ne.u32 %r54,%r26,2; @ %r54 bra $L5; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; bra $L7; $L5: .loc 1 55 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L7; .loc 1 56 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,34; st.u32 [%r60],%r61; $L7: .loc 1 58 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L8; .loc 1 59 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r64],%r32; $L8: .loc 1 60 0 ld.f64 %r65,[%frame+32]; cvt.rn.f32.f64 %r36,%r65; $L1: .loc 1 64 0 mov.f32 %value,%r36; st.param.f32 [%value_out],%value; ret; } lib_a-wf_sqrt.o/0 0 0 644 3581 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sqrtf .visible .func (.param .f32 %value_out) sqrtf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_sqrt.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {115,113,114,116,102,0 }; // BEGIN GLOBAL FUNCTION DEF: sqrtf .visible .func (.param .f32 %value_out) sqrtf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .f64 %r62; mov.f32 %r35,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 36 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 37 0 setp.lt.f32 %r43,%r35,0f00000000; @ ! %r43 bra $L1; .loc 1 39 0 mov.u32 %r44,1; st.u32 [%frame],%r44; .loc 1 40 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 41 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 42 0 cvt.f64.f32 %r24,%r35; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 43 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r47,%r25,0; @ %r47 bra $L4; .loc 1 44 0 mov.f64 %r48,0d0000000000000000; st.f64 [%frame+32],%r48; bra $L5; $L4: .loc 1 46 0 mov.f64 %r50,0d0000000000000000; div.rn.f64 %r49,%r50,0d0000000000000000; st.f64 [%frame+32],%r49; .loc 1 47 0 setp.ne.u32 %r51,%r25,2; @ %r51 bra $L5; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,33; st.u32 [%r52],%r53; bra $L6; $L5: .loc 1 49 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L6; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,33; st.u32 [%r57],%r58; $L6: .loc 1 52 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L7; .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L7: .loc 1 54 0 ld.f64 %r62,[%frame+32]; cvt.rn.f32.f64 %r34,%r62; $L1: .loc 1 58 0 mov.f32 %value,%r34; st.param.f32 [%value_out],%value; ret; } /1664 0 0 0 644 3393 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tgammaf .visible .func (.param .f32 %value_out) tgammaf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/math/wf_tgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .extern .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_standard .extern .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: tgammaf .visible .func (.param .f32 %value_out) tgammaf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r29; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r34; .reg .u32 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .u32 %r43; .reg .pred %r44; .reg .f32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .u32 %r51; .reg .f64 %r52; .reg .u32 %r55; .reg .f64 %r56; mov.f32 %r31,%ar0; .loc 1 28 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_gammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r34,[%value_in]; } mov.f32 %r30,%r34; .loc 1 29 0 ld.u32 %r35,[%frame]; setp.ge.s32 %r36,%r35,0; @ %r36 bra $L2; neg.f32 %r30,%r30; $L2: .loc 1 33 0 ld.global.u32 %r37,[__fdlib_version]; setp.eq.u32 %r38,%r37,-1; @ %r38 bra $L1; .loc 1 35 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.ne.u32 %r41,%r40,0; @ %r41 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r43,[%value_in]; } setp.eq.u32 %r44,%r43,0; @ %r44 bra $L1; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r46,[%value_in]; } setp.neu.f32 %r47,%r46,%r31; @ %r47 bra $L4; cvt.f64.f32 %r29,%r31; setp.le.f32 %r48,%r31,0f00000000; @ ! %r48 bra $L5; .loc 1 38 0 mov.u32 %r51,141; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r51; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r52,[%value_in]; } cvt.rn.f32.f64 %r30,%r52; bra $L1; $L4: cvt.f64.f32 %r29,%r31; $L5: .loc 1 41 0 mov.u32 %r55,140; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r55; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r56,[%value_in]; } cvt.rn.f32.f64 %r30,%r56; $L1: .loc 1 45 0 mov.f32 %value,%r30; st.param.f32 [%value_out],%value; ret; } /1683 0 0 0 644 5024 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gamma_r .visible .func (.param .f64 %value_out) gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/wr_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .extern .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: gamma_r .visible .func (.param .f64 %value_out) gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .f64 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 35 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r39; call (%value_in),__ieee754_gamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r42,[%value_in]; } mov.f64 %r37,%r42; .loc 1 36 0 ld.global.u32 %r43,[__fdlib_version]; setp.eq.u32 %r44,%r43,-1; @ %r44 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),finite,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.ne.u32 %r47,%r46,0; @ %r47 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L1; .loc 1 44 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 45 0 st.u32 [%frame+40],%r46; .loc 1 46 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 47 0 ld.global.u32 %r53,[__fdlib_version]; setp.ne.u32 %r54,%r53,0; @ %r54 bra $L3; .loc 1 48 0 mov.f64 %r55,0d47efffffe0000000; st.f64 [%frame+32],%r55; bra $L4; $L3: .loc 1 50 0 mov.f64 %r56,0d7ff0000000000000; st.f64 [%frame+32],%r56; $L4: .loc 1 51 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),floor,(%out_arg1); ld.param.f64 %r58,[%value_in]; } setp.neu.f64 %r59,%r58,%r38; @ %r59 bra $L5; ld.global.u32 %r36,[__fdlib_version]; setp.le.f64 %r60,%r38,0d0000000000000000; @ ! %r60 bra $L6; .loc 1 53 0 mov.u32 %r61,2; st.u32 [%frame],%r61; .loc 1 54 0 setp.ne.u32 %r62,%r36,2; @ %r62 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.eq.u32 %r67,%r66,0; @ ! %r67 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L9; $L5: ld.global.u32 %r36,[__fdlib_version]; $L6: .loc 1 61 0 mov.u32 %r70,3; st.u32 [%frame],%r70; .loc 1 62 0 setp.ne.u32 %r71,%r36,2; @ %r71 bra $L11; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L9; $L11: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L9; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L9: .loc 1 68 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L13; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r81],%r35; $L13: .loc 1 70 0 ld.f64 %r37,[%frame+32]; $L1: .loc 1 74 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } /1701 0 0 0 644 5036 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgamma_r .visible .func (.param .f64 %value_out) lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/wr_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .extern .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {108,103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: lgamma_r .visible .func (.param .f64 %value_out) lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .f64 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 35 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r39; call (%value_in),__ieee754_lgamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r42,[%value_in]; } mov.f64 %r37,%r42; .loc 1 36 0 ld.global.u32 %r43,[__fdlib_version]; setp.eq.u32 %r44,%r43,-1; @ %r44 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),finite,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.ne.u32 %r47,%r46,0; @ %r47 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L1; .loc 1 44 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 45 0 st.u32 [%frame+40],%r46; .loc 1 46 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 47 0 ld.global.u32 %r53,[__fdlib_version]; setp.ne.u32 %r54,%r53,0; @ %r54 bra $L3; .loc 1 48 0 mov.f64 %r55,0d47efffffe0000000; st.f64 [%frame+32],%r55; bra $L4; $L3: .loc 1 50 0 mov.f64 %r56,0d7ff0000000000000; st.f64 [%frame+32],%r56; $L4: .loc 1 51 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),floor,(%out_arg1); ld.param.f64 %r58,[%value_in]; } setp.neu.f64 %r59,%r58,%r38; @ %r59 bra $L5; ld.global.u32 %r36,[__fdlib_version]; setp.le.f64 %r60,%r38,0d0000000000000000; @ ! %r60 bra $L6; .loc 1 53 0 mov.u32 %r61,2; st.u32 [%frame],%r61; .loc 1 54 0 setp.ne.u32 %r62,%r36,2; @ %r62 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.eq.u32 %r67,%r66,0; @ ! %r67 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L9; $L5: ld.global.u32 %r36,[__fdlib_version]; $L6: .loc 1 62 0 mov.u32 %r70,3; st.u32 [%frame],%r70; .loc 1 63 0 setp.ne.u32 %r71,%r36,2; @ %r71 bra $L11; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L9; $L11: .loc 1 65 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L9; .loc 1 66 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L9: .loc 1 69 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L13; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r81],%r35; $L13: .loc 1 71 0 ld.f64 %r37,[%frame+32]; $L1: .loc 1 75 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } /1720 0 0 0 644 5116 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gammaf_r .visible .func (.param .f32 %value_out) gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/wrf_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .extern .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: gammaf_r .visible .func (.param .f32 %value_out) gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r36; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .u64 %r41; .reg .f32 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f32 %r60; .reg .pred %r61; .reg .pred %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .f64 %r84; mov.f32 %r40,%ar0; mov.u64 %r41,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; call (%value_in),__ieee754_gammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } mov.f32 %r39,%r44; .loc 1 36 0 ld.global.u32 %r45,[__fdlib_version]; setp.eq.u32 %r46,%r45,-1; @ %r46 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.ne.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.eq.u32 %r52,%r51,0; @ %r52 bra $L1; .loc 1 44 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 45 0 st.u32 [%frame+40],%r48; .loc 1 46 0 cvt.f64.f32 %r25,%r40; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 47 0 ld.global.u32 %r55,[__fdlib_version]; setp.ne.u32 %r56,%r55,0; @ %r56 bra $L3; .loc 1 48 0 mov.f64 %r57,0d47efffffe0000000; st.f64 [%frame+32],%r57; bra $L4; $L3: .loc 1 50 0 mov.f64 %r58,0d7ff0000000000000; st.f64 [%frame+32],%r58; $L4: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r60,[%value_in]; } setp.neu.f32 %r61,%r60,%r40; @ %r61 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f32 %r62,%r40,0f00000000; @ ! %r62 bra $L6; .loc 1 53 0 mov.u32 %r63,2; st.u32 [%frame],%r63; .loc 1 54 0 setp.ne.u32 %r64,%r38,2; @ %r64 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.eq.u32 %r69,%r68,0; @ ! %r69 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 61 0 mov.u32 %r72,3; st.u32 [%frame],%r72; .loc 1 62 0 setp.ne.u32 %r73,%r38,2; @ %r73 bra $L11; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } mov.u32 %r75,34; st.u32 [%r74],%r75; bra $L9; $L11: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r77,[%value_in]; } setp.ne.u32 %r78,%r77,0; @ %r78 bra $L9; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } mov.u32 %r80,34; st.u32 [%r79],%r80; $L9: .loc 1 68 0 ld.u32 %r81,[%frame+40]; setp.eq.u32 %r82,%r81,0; @ %r82 bra $L13; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } ld.u32 %r36,[%frame+40]; st.u32 [%r83],%r36; $L13: .loc 1 70 0 ld.f64 %r84,[%frame+32]; cvt.rn.f32.f64 %r39,%r84; $L1: .loc 1 74 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } /1739 0 0 0 644 5128 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgammaf_r .visible .func (.param .f32 %value_out) lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/wrf_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .extern .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {108,103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: lgammaf_r .visible .func (.param .f32 %value_out) lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[48]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r25; .reg .u32 %r36; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .u64 %r41; .reg .f32 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f32 %r60; .reg .pred %r61; .reg .pred %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .f64 %r84; mov.f32 %r40,%ar0; mov.u64 %r41,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; call (%value_in),__ieee754_lgammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } mov.f32 %r39,%r44; .loc 1 36 0 ld.global.u32 %r45,[__fdlib_version]; setp.eq.u32 %r46,%r45,-1; @ %r46 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.ne.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.eq.u32 %r52,%r51,0; @ %r52 bra $L1; .loc 1 44 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 45 0 st.u32 [%frame+40],%r48; .loc 1 46 0 cvt.f64.f32 %r25,%r40; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 47 0 ld.global.u32 %r55,[__fdlib_version]; setp.ne.u32 %r56,%r55,0; @ %r56 bra $L3; .loc 1 48 0 mov.f64 %r57,0d47efffffe0000000; st.f64 [%frame+32],%r57; bra $L4; $L3: .loc 1 50 0 mov.f64 %r58,0d7ff0000000000000; st.f64 [%frame+32],%r58; $L4: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r60,[%value_in]; } setp.neu.f32 %r61,%r60,%r40; @ %r61 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f32 %r62,%r40,0f00000000; @ ! %r62 bra $L6; .loc 1 53 0 mov.u32 %r63,2; st.u32 [%frame],%r63; .loc 1 54 0 setp.ne.u32 %r64,%r38,2; @ %r64 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.eq.u32 %r69,%r68,0; @ ! %r69 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 62 0 mov.u32 %r72,3; st.u32 [%frame],%r72; .loc 1 63 0 setp.ne.u32 %r73,%r38,2; @ %r73 bra $L11; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } mov.u32 %r75,34; st.u32 [%r74],%r75; bra $L9; $L11: .loc 1 65 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r77,[%value_in]; } setp.ne.u32 %r78,%r77,0; @ %r78 bra $L9; .loc 1 66 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } mov.u32 %r80,34; st.u32 [%r79],%r80; $L9: .loc 1 69 0 ld.u32 %r81,[%frame+40]; setp.eq.u32 %r82,%r81,0; @ %r82 bra $L13; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } ld.u32 %r36,[%frame+40]; st.u32 [%r83],%r36; $L13: .loc 1 71 0 ld.f64 %r84,[%frame+32]; cvt.rn.f32.f64 %r39,%r84; $L1: .loc 1 75 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } 07070100000070000041ed0000000000000000000000016181424500000000000000000000000000000000000000000000001b00000000./usr/nvptx-none/lib/mgomp07070100000073000081a4000000000000000000000001618142440012a11e000000000000000000000000000000000000002200000000./usr/nvptx-none/lib/mgomp/libm.a! // 1760 ` lib_a-cephes_subr.o/ lib_a-cephes_subrf.o/ lib_a-copysignl.o/ lib_a-e_rem_pio2.o/ lib_a-e_remainder.o/ lib_a-ef_acosh.o/ lib_a-ef_atan2.o/ lib_a-ef_atanh.o/ lib_a-ef_hypot.o/ lib_a-ef_log10.o/ lib_a-ef_rem_pio2.o/ lib_a-ef_remainder.o/ lib_a-ef_scalb.o/ lib_a-er_gamma.o/ lib_a-er_lgamma.o/ lib_a-erf_gamma.o/ lib_a-erf_lgamma.o/ lib_a-k_rem_pio2.o/ lib_a-k_standard.o/ lib_a-kf_rem_pio2.o/ lib_a-llroundl.o/ lib_a-nearbyintl.o/ lib_a-nextafterl.o/ lib_a-remainderl.o/ lib_a-s_copysign.o/ lib_a-s_finite.o/ lib_a-s_fpclassify.o/ lib_a-s_infconst.o/ lib_a-s_infinity.o/ lib_a-s_isinfd.o/ lib_a-s_isnand.o/ lib_a-s_lib_ver.o/ lib_a-s_llrint.o/ lib_a-s_llround.o/ lib_a-s_lround.o/ lib_a-s_matherr.o/ lib_a-s_nearbyint.o/ lib_a-s_nextafter.o/ lib_a-s_remquo.o/ lib_a-s_scalbln.o/ lib_a-s_scalbn.o/ lib_a-s_signbit.o/ lib_a-s_signif.o/ lib_a-scalblnl.o/ lib_a-sf_asinh.o/ lib_a-sf_copysign.o/ lib_a-sf_exp10.o/ lib_a-sf_expm1.o/ lib_a-sf_finite.o/ lib_a-sf_floor.o/ lib_a-sf_fpclassify.o/ lib_a-sf_frexp.o/ lib_a-sf_ilogb.o/ lib_a-sf_infinity.o/ lib_a-sf_isinf.o/ lib_a-sf_isinff.o/ lib_a-sf_isnan.o/ lib_a-sf_isnanf.o/ lib_a-sf_ldexp.o/ lib_a-sf_llrint.o/ lib_a-sf_llround.o/ lib_a-sf_log1p.o/ lib_a-sf_lrint.o/ lib_a-sf_lround.o/ lib_a-sf_nearbyint.o/ lib_a-sf_nextafter.o/ lib_a-sf_pow10.o/ lib_a-sf_remquo.o/ lib_a-sf_round.o/ lib_a-sf_scalbln.o/ lib_a-sf_scalbn.o/ lib_a-sf_signif.o/ lib_a-sf_trunc.o/ lib_a-w_lgamma.o/ lib_a-w_remainder.o/ lib_a-w_sincos.o/ lib_a-w_tgamma.o/ lib_a-wf_acosh.o/ lib_a-wf_atan2.o/ lib_a-wf_atanh.o/ lib_a-wf_gamma.o/ lib_a-wf_hypot.o/ lib_a-wf_lgamma.o/ lib_a-wf_log10.o/ lib_a-wf_remainder.o/ lib_a-wf_scalb.o/ lib_a-wf_sincos.o/ lib_a-wf_tgamma.o/ lib_a-wr_gamma.o/ lib_a-wr_lgamma.o/ lib_a-wrf_gamma.o/ lib_a-wrf_lgamma.o/ lib_a-acoshl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: acoshl .visible .func (.param .f64 %value_out) acoshl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/acoshl.c" // BEGIN GLOBAL FUNCTION DECL: acosh .extern .func (.param .f64 %value_out) acosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: acoshl .visible .func (.param .f64 %value_out) acoshl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),acosh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-acosl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: acosl .visible .func (.param .f64 %value_out) acosl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/acosl.c" // BEGIN GLOBAL FUNCTION DECL: acos .extern .func (.param .f64 %value_out) acos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: acosl .visible .func (.param .f64 %value_out) acosl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),acos,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-asinhl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinhl .visible .func (.param .f64 %value_out) asinhl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/asinhl.c" // BEGIN GLOBAL FUNCTION DECL: asinh .extern .func (.param .f64 %value_out) asinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinhl .visible .func (.param .f64 %value_out) asinhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),asinh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-asinl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinl .visible .func (.param .f64 %value_out) asinl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/asinl.c" // BEGIN GLOBAL FUNCTION DECL: asin .extern .func (.param .f64 %value_out) asin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinl .visible .func (.param .f64 %value_out) asinl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),asin,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-atan2l.o/ 0 0 0 644 1010 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan2l .visible .func (.param .f64 %value_out) atan2l (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/atan2l.c" // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atan2l .visible .func (.param .f64 %value_out) atan2l (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-atanhl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atanhl .visible .func (.param .f64 %value_out) atanhl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/atanhl.c" // BEGIN GLOBAL FUNCTION DECL: atanh .extern .func (.param .f64 %value_out) atanh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: atanhl .visible .func (.param .f64 %value_out) atanhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),atanh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-atanl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atanl .visible .func (.param .f64 %value_out) atanl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/atanl.c" // BEGIN GLOBAL FUNCTION DECL: atan .extern .func (.param .f64 %value_out) atan (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: atanl .visible .func (.param .f64 %value_out) atanl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),atan,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-cabs.o/ 0 0 0 644 1709 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cabs .visible .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/cabs.c" // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: hypot .extern .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cabs .visible .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r29; .reg .f64 %r32; .reg .f64 %r35; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 52 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r29,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r32,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; call (%value_in),hypot,(%out_arg1,%out_arg2); ld.param.f64 %r35,[%value_in]; } .loc 1 53 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-cabsf.o/ 0 0 0 644 1723 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cabsf .visible .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/cabsf.c" // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: hypotf .extern .func (.param .f32 %value_out) hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cabsf .visible .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r29; .reg .f32 %r32; .reg .f32 %r35; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 18 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r29,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r32,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r29; call (%value_in),hypotf,(%out_arg1,%out_arg2); ld.param.f32 %r35,[%value_in]; } .loc 1 19 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } lib_a-cacos.o/ 0 0 0 644 2634 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacos .visible .func cacos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cacos.c" // BEGIN GLOBAL FUNCTION DECL: casin .extern .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cacos .visible .func cacos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .f64 %r25; .reg .u64 %r30; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r38; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; mov.u64 %r30,%ar0; mov.f64 %r31,%ar1; mov.f64 %r32,%ar2; .loc 1 94 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r31; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r32; call casin,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r24,[%frame]; ld.f64 %r25,[%frame+8]; .loc 1 95 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r25; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r25; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } .loc 1 95 0 mov.f64 %r44,0d3ff921fb54442d18; sub.f64 %r43,%r44,%r38; .loc 1 96 0 fma.rn.f64 %r45,%r41,0d8000000000000000,%r43; .loc 1 98 0 st.f64 [%r30],%r45; .loc 1 96 0 mov.f64 %r47,0d0000000000000000; sub.f64 %r46,%r47,%r41; .loc 1 98 0 st.f64 [%r30+8],%r46; .loc 1 99 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-cacosf.o/ 0 0 0 644 2517 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacosf .visible .func cacosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cacosf.c" // BEGIN GLOBAL FUNCTION DECL: casinf .extern .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cacosf .visible .func cacosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r26; .reg .f32 %r27; .reg .u64 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r38; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; mov.u64 %r30,%ar0; mov.f32 %r31,%ar1; mov.f32 %r32,%ar2; .loc 1 43 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r31; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r32; call casinf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r26,[%frame]; ld.f32 %r27,[%frame+4]; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r27; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r38,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r27; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r41,[%value_in]; } neg.f32 %r42,%r38; mov.f32 %r44,0f3fc90fdb; sub.f32 %r43,%r44,%r41; fma.rn.f32 %r45,%r42,0f00000000,%r43; .loc 1 45 0 st.f32 [%r30],%r45; st.f32 [%r30+4],%r42; .loc 1 46 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-cacosh.o/ 0 0 0 644 3132 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacosh .visible .func cacosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cacosh.c" // BEGIN GLOBAL FUNCTION DECL: csqrt .extern .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: clog .extern .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cacosh .visible .func cacosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r30; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r36; .reg .f64 %r37; .reg .u64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .f64 %r59; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r82; .reg .f64 %r85; mov.u64 %r50,%ar0; mov.f64 %r51,%ar1; mov.f64 %r52,%ar2; .loc 1 90 0 add.f64 %r59,%r51,0d3ff0000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r59; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r52; call csqrt,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r25,[%frame]; ld.f64 %r26,[%frame+8]; mov.f64 %r70,0d3ff0000000000000; sub.f64 %r69,%r51,%r70; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r69; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r52; call csqrt,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r30,[%frame]; ld.f64 %r31,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r25; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r26; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r30; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r31; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r32,[%frame]; ld.f64 %r33,[%frame+8]; add.f64 %r82,%r33,%r52; add.f64 %r85,%r32,%r51; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r85; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r82; call clog,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r36,[%frame]; ld.f64 %r37,[%frame+8]; .loc 1 92 0 st.f64 [%r50],%r36; st.f64 [%r50+8],%r37; .loc 1 93 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-cacoshf.o/0 0 0 644 3127 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cacoshf .visible .func cacoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cacoshf.c" // BEGIN GLOBAL FUNCTION DECL: csqrtf .extern .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: clogf .extern .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cacoshf .visible .func cacoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .f32 %r36; .reg .f32 %r37; .reg .u64 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r59; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r82; .reg .f32 %r85; mov.u64 %r50,%ar0; mov.f32 %r51,%ar1; mov.f32 %r52,%ar2; .loc 1 45 0 add.f32 %r59,%r51,0f3f800000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r59; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r52; call csqrtf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r25,[%frame]; ld.f32 %r26,[%frame+4]; mov.f32 %r70,0f3f800000; sub.f32 %r69,%r51,%r70; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r69; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r52; call csqrtf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r30,[%frame]; ld.f32 %r31,[%frame+4]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r25; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r26; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r30; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r31; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r32,[%frame]; ld.f32 %r33,[%frame+4]; add.f32 %r82,%r33,%r52; add.f32 %r85,%r32,%r51; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r85; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r82; call clogf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r36,[%frame]; ld.f32 %r37,[%frame+4]; .loc 1 47 0 st.f32 [%r50],%r36; st.f32 [%r50+4],%r37; .loc 1 48 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-carg.o/ 0 0 0 644 1709 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: carg .visible .func (.param .f64 %value_out) carg (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/carg.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: carg .visible .func (.param .f64 %value_out) carg (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r29; .reg .f64 %r32; .reg .f64 %r35; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 58 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r29,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r32,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r35,[%value_in]; } .loc 1 59 0 mov.f64 %value,%r35; st.param.f64 [%value_out],%value; ret; } lib_a-cargf.o/ 0 0 0 644 1723 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cargf .visible .func (.param .f32 %value_out) cargf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/cargf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2f .extern .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: cargf .visible .func (.param .f32 %value_out) cargf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r29; .reg .f32 %r32; .reg .f32 %r35; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 18 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r29,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r26; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r32,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r29; call (%value_in),atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r35,[%value_in]; } .loc 1 19 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } lib_a-casin.o/ 0 0 0 644 5069 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casin .visible .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/casin.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: csqrt .extern .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: clog .extern .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: casin .visible .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r66; .reg .f64 %r69; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .f64 %r79; .reg .f64 %r80; .reg .f64 %r83; .reg .f64 %r86; .reg .f64 %r94; .reg .f64 %r98; .reg .f64 %r100; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r112; .reg .f64 %r113; mov.u64 %r61,%ar0; mov.f64 %r62,%ar1; mov.f64 %r63,%ar2; .loc 1 92 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r63; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r66,[%value_in]; } .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r63; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r69,[%value_in]; } .loc 1 150 0 fma.rn.f64 %r75,%r69,0d0000000000000000,%r66; .loc 1 151 0 mov.f64 %r74,0d3ff0000000000000; mov.f64 %r73,0d0000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r75; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r69; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r73; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r74; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r34,[%frame]; ld.f64 %r35,[%frame+8]; .loc 1 155 0 add.f64 %r76,%r66,%r66; mul.f64 %r36,%r76,%r69; sub.f64 %r77,%r66,%r69; mul.f64 %r78,%r36,0d0000000000000000; add.f64 %r79,%r66,%r69; fma.rn.f64 %r80,%r77,%r79,%r78; .loc 1 157 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r80; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r83,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r80; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r86,[%value_in]; } neg.f64 %r94,%r83; sub.f64 %r98,%r74,%r86; fma.rn.f64 %r100,%r94,0d0000000000000000,%r98; .loc 1 158 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r100; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r94; call csqrt,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r42,[%frame]; ld.f64 %r43,[%frame+8]; .loc 1 160 0 add.f64 %r104,%r34,%r42; add.f64 %r105,%r35,%r43; .loc 1 161 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r104; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r105; call clog,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r46,[%frame]; ld.f64 %r47,[%frame+8]; .loc 1 163 0 mov.f64 %r113,0dbff0000000000000; mov.f64 %r112,0d8000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r46; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r47; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r112; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r113; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r48,[%frame]; ld.f64 %r49,[%frame+8]; .loc 1 164 0 st.f64 [%r61],%r48; st.f64 [%r61+8],%r49; .loc 1 165 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-casinf.o/ 0 0 0 644 5031 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casinf .visible .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/casinf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: csqrtf .extern .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: clogf .extern .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: casinf .visible .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .u64 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r66; .reg .f32 %r69; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r83; .reg .f32 %r86; .reg .f32 %r94; .reg .f32 %r98; .reg .f32 %r100; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r112; .reg .f32 %r113; mov.u64 %r61,%ar0; mov.f32 %r62,%ar1; mov.f32 %r63,%ar2; .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r63; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r66,[%value_in]; } .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r63; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r69,[%value_in]; } .loc 1 107 0 fma.rn.f32 %r75,%r69,0f00000000,%r66; .loc 1 108 0 mov.f32 %r74,0f3f800000; mov.f32 %r73,0f00000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r75; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r69; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r73; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r74; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r34,[%frame]; ld.f32 %r35,[%frame+4]; .loc 1 112 0 add.f32 %r76,%r66,%r66; mul.f32 %r36,%r76,%r69; sub.f32 %r77,%r66,%r69; mul.f32 %r78,%r36,0f00000000; add.f32 %r79,%r66,%r69; fma.rn.f32 %r80,%r77,%r79,%r78; .loc 1 114 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r80; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r83,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r80; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r86,[%value_in]; } neg.f32 %r94,%r83; sub.f32 %r98,%r74,%r86; fma.rn.f32 %r100,%r94,0f00000000,%r98; .loc 1 115 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r100; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r94; call csqrtf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r42,[%frame]; ld.f32 %r43,[%frame+4]; .loc 1 117 0 add.f32 %r104,%r34,%r42; add.f32 %r105,%r35,%r43; .loc 1 118 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r104; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r105; call clogf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r46,[%frame]; ld.f32 %r47,[%frame+4]; .loc 1 120 0 mov.f32 %r113,0fbf800000; mov.f32 %r112,0f80000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r46; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r47; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r112; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r113; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r48,[%frame]; ld.f32 %r49,[%frame+4]; .loc 1 121 0 st.f32 [%r61],%r48; st.f32 [%r61+4],%r49; .loc 1 122 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-casinh.o/ 0 0 0 644 2827 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casinh .visible .func casinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/casinh.c" // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: casin .extern .func casin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: casinh .visible .func casinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r22; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 95 0 mov.f64 %r41,0d3ff0000000000000; mov.f64 %r40,0d0000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r36; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r40; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r41; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r22,[%frame]; ld.f64 %r23,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r22; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r23; call casin,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r24,[%frame]; ld.f64 %r25,[%frame+8]; mov.f64 %r49,0dbff0000000000000; mov.f64 %r48,0d8000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r25; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r48; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r49; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r26,[%frame]; ld.f64 %r27,[%frame+8]; .loc 1 96 0 st.f64 [%r34],%r26; st.f64 [%r34+8],%r27; .loc 1 97 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-casinhf.o/0 0 0 644 2802 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: casinhf .visible .func casinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/casinhf.c" // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: casinf .extern .func casinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: casinhf .visible .func casinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r22; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r27; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 42 0 mov.f32 %r41,0f3f800000; mov.f32 %r40,0f00000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r35; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r36; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r40; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r41; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r22,[%frame]; ld.f32 %r23,[%frame+4]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r22; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r23; call casinf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r24,[%frame]; ld.f32 %r25,[%frame+4]; mov.f32 %r49,0fbf800000; mov.f32 %r48,0f80000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r25; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r48; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r49; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r26,[%frame]; ld.f32 %r27,[%frame+4]; .loc 1 43 0 st.f32 [%r34],%r26; st.f32 [%r34+4],%r27; .loc 1 44 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-catan.o/ 0 0 0 644 3776 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: catan .visible .func catan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/catan.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _redupi .extern .func (.param .f64 %value_out) _redupi (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 8 .u64 $LC0[2] = {9221120237041090560,9218868437227405312 }; // BEGIN GLOBAL FUNCTION DEF: catan .visible .func catan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r38; .reg .u64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r46; .reg .f64 %r49; .reg .pred %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .pred %r55; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .pred %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; mov.u64 %r41,%ar0; mov.f64 %r42,%ar1; mov.f64 %r43,%ar2; .loc 1 100 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r49,[%value_in]; } .loc 1 103 0 setp.neu.f64 %r50,%r46,0d0000000000000000; @ %r50 bra $L2; setp.gt.f64 %r51,%r49,0d3ff0000000000000; @ %r51 bra $L3; $L2: .loc 1 106 0 mul.f64 %r31,%r46,%r46; .loc 1 107 0 neg.f64 %r52,%r49; mov.f64 %r54,0d3ff0000000000000; sub.f64 %r53,%r54,%r31; fma.rn.f64 %r32,%r52,%r49,%r53; .loc 1 108 0 setp.eq.f64 %r55,%r32,0d0000000000000000; @ %r55 bra $L3; .loc 1 111 0 add.f64 %r58,%r46,%r46; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r58; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r59,[%value_in]; } mul.f64 %r61,%r59,0d3fe0000000000000; .loc 1 112 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r61; call (%value_in),_redupi,(%out_arg1); ld.param.f64 %r62,[%value_in]; } .loc 1 114 0 sub.f64 %r34,%r49,%r54; .loc 1 115 0 fma.rn.f64 %r35,%r34,%r34,%r31; .loc 1 116 0 setp.eq.f64 %r64,%r35,0d0000000000000000; @ %r64 bra $L3; .loc 1 119 0 add.f64 %r36,%r49,0d3ff0000000000000; .loc 1 120 0 fma.rn.f64 %r66,%r36,%r36,%r31; div.rn.f64 %r67,%r66,%r35; .loc 1 121 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r67; call (%value_in),log,(%out_arg1); ld.param.f64 %r68,[%value_in]; } mul.f64 %r38,%r68,0d3fd0000000000000; fma.rn.f64 %r69,%r38,0d0000000000000000,%r62; .loc 1 122 0 st.f64 [%r41],%r69; .loc 1 121 0 add.f64 %r70,%r38,0d0000000000000000; .loc 1 122 0 st.f64 [%r41+8],%r70; bra $L1; $L3: .loc 1 129 0 ld.const.f64 %r71,[$LC0]; st.f64 [%r41],%r71; ld.const.f64 %r72,[$LC0+8]; st.f64 [%r41+8],%r72; $L1: .loc 1 130 0 ret; } lib_a-catanf.o/ 0 0 0 644 3679 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: catanf .visible .func catanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/catanf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2f .extern .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _redupif .extern .func (.param .f32 %value_out) _redupif (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 4 .u32 $LC0[2] = {2143289344,2139095040 }; // BEGIN GLOBAL FUNCTION DEF: catanf .visible .func catanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r38; .reg .u64 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r46; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .pred %r55; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r61; .reg .f32 %r62; .reg .pred %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; mov.u64 %r41,%ar0; mov.f32 %r42,%ar1; mov.f32 %r43,%ar2; .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r43; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r43; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r49,[%value_in]; } .loc 1 52 0 setp.neu.f32 %r50,%r46,0f00000000; @ %r50 bra $L2; setp.gt.f32 %r51,%r49,0f3f800000; @ %r51 bra $L3; $L2: .loc 1 55 0 mul.f32 %r31,%r46,%r46; .loc 1 56 0 neg.f32 %r52,%r49; mov.f32 %r54,0f3f800000; sub.f32 %r53,%r54,%r31; fma.rn.f32 %r32,%r52,%r49,%r53; .loc 1 57 0 setp.eq.f32 %r55,%r32,0f00000000; @ %r55 bra $L3; .loc 1 60 0 add.f32 %r58,%r46,%r46; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r59,[%value_in]; } mul.f32 %r61,%r59,0f3f000000; .loc 1 61 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),_redupif,(%out_arg1); ld.param.f32 %r62,[%value_in]; } .loc 1 63 0 sub.f32 %r34,%r49,%r54; .loc 1 64 0 fma.rn.f32 %r35,%r34,%r34,%r31; .loc 1 65 0 setp.eq.f32 %r64,%r35,0f00000000; @ %r64 bra $L3; .loc 1 68 0 add.f32 %r36,%r49,0f3f800000; .loc 1 69 0 fma.rn.f32 %r66,%r36,%r36,%r31; div.rn.f32 %r67,%r66,%r35; .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),logf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } mul.f32 %r38,%r68,0f3e800000; fma.rn.f32 %r69,%r38,0f00000000,%r62; .loc 1 71 0 st.f32 [%r41],%r69; .loc 1 70 0 add.f32 %r70,%r38,0f00000000; .loc 1 71 0 st.f32 [%r41+4],%r70; bra $L1; $L3: .loc 1 78 0 ld.const.f32 %r71,[$LC0]; st.f32 [%r41],%r71; ld.const.f32 %r72,[$LC0+4]; st.f32 [%r41+4],%r72; $L1: .loc 1 79 0 ret; } lib_a-catanh.o/ 0 0 0 644 2827 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: catanh .visible .func catanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/catanh.c" // BEGIN GLOBAL FUNCTION DECL: __muldc3 .extern .func __muldc3 (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: catan .extern .func catan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: catanh .visible .func catanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r22; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 88 0 mov.f64 %r41,0d3ff0000000000000; mov.f64 %r40,0d0000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r36; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r40; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r41; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r22,[%frame]; ld.f64 %r23,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r22; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r23; call catan,(%out_arg1,%out_arg2,%out_arg3); } ld.f64 %r24,[%frame]; ld.f64 %r25,[%frame+8]; mov.f64 %r49,0dbff0000000000000; mov.f64 %r48,0d8000000000000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r25; .param .f64 %out_arg4; st.param.f64 [%out_arg4],%r48; .param .f64 %out_arg5; st.param.f64 [%out_arg5],%r49; call __muldc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f64 %r26,[%frame]; ld.f64 %r27,[%frame+8]; .loc 1 89 0 st.f64 [%r34],%r26; st.f64 [%r34+8],%r27; .loc 1 90 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-catanhf.o/0 0 0 644 2802 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: catanhf .visible .func catanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/catanhf.c" // BEGIN GLOBAL FUNCTION DECL: __mulsc3 .extern .func __mulsc3 (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: catanf .extern .func catanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: catanhf .visible .func catanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r22; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r27; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 42 0 mov.f32 %r41,0f3f800000; mov.f32 %r40,0f00000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r35; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r36; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r40; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r41; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r22,[%frame]; ld.f32 %r23,[%frame+4]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r22; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r23; call catanf,(%out_arg1,%out_arg2,%out_arg3); } ld.f32 %r24,[%frame]; ld.f32 %r25,[%frame+4]; mov.f32 %r49,0fbf800000; mov.f32 %r48,0f80000000; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; .param .f32 %out_arg3; st.param.f32 [%out_arg3],%r25; .param .f32 %out_arg4; st.param.f32 [%out_arg4],%r48; .param .f32 %out_arg5; st.param.f32 [%out_arg5],%r49; call __mulsc3,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); } ld.f32 %r26,[%frame]; ld.f32 %r27,[%frame+4]; .loc 1 43 0 st.f32 [%r34],%r26; st.f32 [%r34+4],%r27; .loc 1 44 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-cbrtl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cbrtl .visible .func (.param .f64 %value_out) cbrtl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/cbrtl.c" // BEGIN GLOBAL FUNCTION DECL: cbrt .extern .func (.param .f64 %value_out) cbrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cbrtl .visible .func (.param .f64 %value_out) cbrtl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),cbrt,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-ccos.o/ 0 0 0 644 3326 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccos .visible .func ccos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ccos.c" // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchsh .extern .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: ccos .visible .func ccos (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r32; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r39; .reg .u64 %r43; .reg .f64 %r46; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r52; .reg .f64 %r54; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } add.u64 %r43,%frame,8; { .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchsh,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r46; call (%value_in),sin,(%out_arg1); ld.param.f64 %r48,[%value_in]; } ld.f64 %r49,[%frame]; mul.f64 %r32,%r48,%r49; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r52,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),cos,(%out_arg1); ld.param.f64 %r54,[%value_in]; } mul.f64 %r56,%r32,0d8000000000000000; ld.f64 %r58,[%frame+8]; fma.rn.f64 %r57,%r54,%r58,%r56; .loc 1 80 0 st.f64 [%r34],%r57; .loc 1 79 0 neg.f64 %r59,%r32; .loc 1 80 0 st.f64 [%r34+8],%r59; .loc 1 81 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-ccosf.o/ 0 0 0 644 3338 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccosf .visible .func ccosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ccosf.c" // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchshf .extern .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: ccosf .visible .func ccosf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r32; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r39; .reg .u64 %r43; .reg .f32 %r46; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r52; .reg .f32 %r54; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } add.u64 %r43,%frame,4; { .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchshf,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r48,[%value_in]; } ld.f32 %r49,[%frame]; mul.f32 %r32,%r48,%r49; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r52,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r52; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r54,[%value_in]; } mul.f32 %r56,%r32,0f80000000; ld.f32 %r58,[%frame+4]; fma.rn.f32 %r57,%r54,%r58,%r56; .loc 1 47 0 st.f32 [%r34],%r57; .loc 1 46 0 neg.f32 %r59,%r32; .loc 1 47 0 st.f32 [%r34+4],%r59; .loc 1 48 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-ccosh.o/ 0 0 0 644 2637 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccosh .visible .func ccosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ccosh.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ccosh .visible .func ccosh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r30; .reg .u64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r36; .reg .f64 %r39; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r45; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r31,%ar0; mov.f64 %r32,%ar1; mov.f64 %r33,%ar2; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r36,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r41,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),sin,(%out_arg1); ld.param.f64 %r43,[%value_in]; } mul.f64 %r30,%r41,%r43; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r45,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),cos,(%out_arg1); ld.param.f64 %r47,[%value_in]; } mul.f64 %r48,%r30,0d0000000000000000; fma.rn.f64 %r49,%r45,%r47,%r48; .loc 1 80 0 st.f64 [%r31],%r49; st.f64 [%r31+8],%r30; .loc 1 81 0 ret; } lib_a-ccoshf.o/ 0 0 0 644 2652 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ccoshf .visible .func ccoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ccoshf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ccoshf .visible .func ccoshf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r30; .reg .u64 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .f32 %r36; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r43; .reg .f32 %r45; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r31,%ar0; mov.f32 %r32,%ar1; mov.f32 %r33,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r36,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r41,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r43,[%value_in]; } mul.f32 %r30,%r41,%r43; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } mul.f32 %r48,%r30,0f00000000; fma.rn.f32 %r49,%r45,%r47,%r48; .loc 1 47 0 st.f32 [%r31],%r49; st.f32 [%r31+4],%r30; .loc 1 48 0 ret; } lib_a-ceill.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ceill .visible .func (.param .f64 %value_out) ceill (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/ceill.c" // BEGIN GLOBAL FUNCTION DECL: ceil .extern .func (.param .f64 %value_out) ceil (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ceill .visible .func (.param .f64 %value_out) ceill (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),ceil,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /0 0 0 0 644 7183 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _cchsh .visible .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cephes_subr.c" // BEGIN GLOBAL FUNCTION DECL: _redupi .visible .func (.param .f64 %value_out) _redupi (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctans .visible .func (.param .f64 %value_out) _ctans (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _cchsh .visible .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f64 %r28; .reg .f64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .f64 %r34; .reg .pred %r35; .reg .f64 %r37; .reg .f64 %r39; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; mov.f64 %r30,%ar0; mov.u64 %r31,%ar1; mov.u64 %r32,%ar2; .loc 1 46 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r34,[%value_in]; } setp.le.f64 %r35,%r34,0d3fe0000000000000; @ ! %r35 bra $L6; .loc 1 47 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r37,[%value_in]; } st.f64 [%r31],%r37; .loc 1 48 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r39,[%value_in]; } st.f64 [%r32],%r39; bra $L1; $L6: .loc 1 50 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),exp,(%out_arg1); ld.param.f64 %r41,[%value_in]; } .loc 1 51 0 mov.f64 %r42,0d3fe0000000000000; div.rn.f64 %r28,%r42,%r41; .loc 1 53 0 neg.f64 %r43,%r28; fma.rn.f64 %r44,%r41,0d3fe0000000000000,%r43; st.f64 [%r32],%r44; .loc 1 54 0 fma.rn.f64 %r45,%r41,0d3fe0000000000000,%r28; st.f64 [%r31],%r45; $L1: .loc 1 56 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _redupi .visible .func (.param .f64 %value_out) _redupi (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .u64 %r26; .reg .f64 %r27; .reg .f64 %r32; .reg .pred %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r37; mov.f64 %r32,%ar0; .loc 1 72 0 div.rn.f64 %r25,%r32,0d400921fb54442d18; .loc 1 73 0 setp.ge.f64 %r33,%r25,0d0000000000000000; @ ! %r33 bra $L12; .loc 1 74 0 add.f64 %r24,%r25,0d3fe0000000000000; bra $L10; $L12: .loc 1 76 0 mov.f64 %r34,0d3fe0000000000000; sub.f64 %r24,%r25,%r34; $L10: .loc 1 78 0 cvt.rzi.s64.f64 %r26,%r24; .loc 1 79 0 cvt.rn.f64.s64 %r27,%r26; .loc 1 80 0 neg.f64 %r35,%r27; fma.rn.f64 %r37,%r35,0d400921fb54000000,%r32; fma.rn.f64 %r23,%r35,0d3e210b4610000000,%r37; fma.rn.f64 %value,%r35,0d3c6a62633145c06e,%r23; .loc 1 82 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _ctans .visible .func (.param .f64 %value_out) _ctans (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r31; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .u64 %r51; .reg .f64 %r52; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r70; .reg .f64 %r72; .reg .f64 %r73; .reg .pred %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r78; .reg .f64 %r79; .reg .f64 %r81; .reg .f64 %r82; .reg .pred %r83; mov.f64 %r60,%ar0; mov.f64 %r61,%ar1; .loc 1 92 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r60; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r61; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r64,[%value_in]; } add.f64 %r66,%r64,%r64; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r67,[%value_in]; } .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r60; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r61; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r70,[%value_in]; } add.f64 %r72,%r70,%r70; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r73,[%value_in]; } .loc 1 72 0 div.rn.f64 %r34,%r67,0d400921fb54442d18; .loc 1 73 0 setp.ge.f64 %r74,%r34,0d0000000000000000; @ ! %r74 bra $L20; .loc 1 74 0 add.f64 %r50,%r34,0d3fe0000000000000; bra $L16; $L20: .loc 1 76 0 mov.f64 %r75,0d3fe0000000000000; sub.f64 %r50,%r34,%r75; $L16: .loc 1 78 0 cvt.rzi.s64.f64 %r51,%r50; .loc 1 79 0 cvt.rn.f64.s64 %r52,%r51; .loc 1 80 0 neg.f64 %r76,%r52; fma.rn.f64 %r78,%r76,0d400921fb54000000,%r67; fma.rn.f64 %r54,%r76,0d3e210b4610000000,%r78; fma.rn.f64 %r55,%r76,0d3c6a62633145c06e,%r54; .loc 1 97 0 mul.f64 %r35,%r55,%r55; .loc 1 98 0 mul.f64 %r36,%r73,%r73; .loc 1 103 0 mov.f64 %r59,0d0000000000000000; .loc 1 102 0 mov.f64 %r31,%r59; .loc 1 100 0 mov.f64 %r30,0d3ff0000000000000; .loc 1 99 0 mov.f64 %r29,%r30; .loc 1 101 0 mov.f64 %r28,%r30; $L17: .loc 1 105 0 add.f64 %r37,%r31,0d3ff0000000000000; .loc 1 106 0 mul.f64 %r38,%r28,%r37; .loc 1 107 0 add.f64 %r39,%r37,0d3ff0000000000000; .loc 1 108 0 mul.f64 %r40,%r38,%r39; .loc 1 109 0 mul.f64 %r41,%r29,%r35; .loc 1 110 0 mul.f64 %r42,%r30,%r36; .loc 1 111 0 add.f64 %r43,%r41,%r42; .loc 1 112 0 div.rn.f64 %r79,%r43,%r40; .loc 1 113 0 add.f64 %r45,%r79,%r59; .loc 1 115 0 add.f64 %r46,%r39,0d3ff0000000000000; .loc 1 116 0 mul.f64 %r47,%r40,%r46; .loc 1 117 0 add.f64 %r31,%r46,0d3ff0000000000000; .loc 1 118 0 mul.f64 %r28,%r47,%r31; .loc 1 119 0 mul.f64 %r29,%r35,%r41; .loc 1 120 0 mul.f64 %r30,%r36,%r42; .loc 1 121 0 sub.f64 %r48,%r30,%r29; .loc 1 122 0 div.rn.f64 %r49,%r48,%r28; .loc 1 123 0 add.f64 %r59,%r45,%r49; .loc 1 124 0 div.rn.f64 %r81,%r49,%r59; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r82,[%value_in]; } setp.gt.f64 %r83,%r82,0d3c9fb49140a1644f; @ %r83 bra $L17; .loc 1 126 0 mov.f64 %value,%r59; st.param.f64 [%value_out],%value; ret; } /21 0 0 0 644 7351 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _cchshf .visible .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cephes_subrf.c" // BEGIN GLOBAL FUNCTION DECL: _redupif .visible .func (.param .f32 %value_out) _redupif (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctansf .visible .func (.param .f32 %value_out) _ctansf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expf .extern .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _cchshf .visible .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f32 %r28; .reg .f32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .f32 %r34; .reg .pred %r35; .reg .f32 %r37; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; mov.f32 %r30,%ar0; mov.u64 %r31,%ar1; mov.u64 %r32,%ar2; .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r34,[%value_in]; } setp.le.f32 %r35,%r34,0f3f000000; @ ! %r35 bra $L6; .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } st.f32 [%r31],%r37; .loc 1 48 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r39,[%value_in]; } st.f32 [%r32],%r39; bra $L1; $L6: .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),expf,(%out_arg1); ld.param.f32 %r41,[%value_in]; } .loc 1 51 0 mov.f32 %r42,0f3f000000; div.rn.f32 %r28,%r42,%r41; .loc 1 53 0 neg.f32 %r43,%r28; fma.rn.f32 %r44,%r41,0f3f000000,%r43; st.f32 [%r32],%r44; .loc 1 54 0 fma.rn.f32 %r45,%r41,0f3f000000,%r28; st.f32 [%r31],%r45; $L1: .loc 1 56 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _redupif .visible .func (.param .f32 %value_out) _redupif (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f32 %r27; .reg .f32 %r28; .reg .u64 %r29; .reg .f32 %r35; .reg .pred %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .f64 %r40; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; mov.f32 %r35,%ar0; .loc 1 72 0 div.rn.f32 %r28,%r35,0f40490fdb; .loc 1 73 0 setp.ge.f32 %r36,%r28,0f00000000; @ ! %r36 bra $L12; .loc 1 74 0 add.f32 %r27,%r28,0f3f000000; bra $L10; $L12: .loc 1 76 0 mov.f32 %r37,0f3f000000; sub.f32 %r27,%r28,%r37; $L10: .loc 1 78 0 cvt.rzi.s64.f32 %r29,%r27; .loc 1 79 0 cvt.rn.f32.s64 %r38,%r29; .loc 1 80 0 cvt.f64.f32 %r23,%r38; neg.f64 %r40,%r23; cvt.f64.f32 %r43,%r35; fma.rn.f64 %r44,%r40,0d4009200000000000,%r43; fma.rn.f64 %r45,%r40,0d3f4fb40000000000,%r44; fma.rn.f64 %r46,%r40,0d3e84442d18469899,%r45; cvt.rn.f32.f64 %value,%r46; .loc 1 82 0 st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _ctansf .visible .func (.param .f32 %value_out) _ctansf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .u64 %r52; .reg .f64 %r55; .reg .f32 %r59; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r74; .reg .f32 %r76; .reg .f32 %r77; .reg .pred %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f64 %r81; .reg .f64 %r84; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r87; .reg .f32 %r88; .reg .f32 %r90; .reg .f32 %r91; .reg .f64 %r92; .reg .pred %r93; mov.f32 %r64,%ar0; mov.f32 %r65,%ar1; .loc 1 91 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r64; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r65; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r68,[%value_in]; } add.f32 %r70,%r68,%r68; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 92 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r64; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r65; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r74,[%value_in]; } add.f32 %r76,%r74,%r74; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r76; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r77,[%value_in]; } .loc 1 72 0 div.rn.f32 %r35,%r71,0f40490fdb; .loc 1 73 0 setp.ge.f32 %r78,%r35,0f00000000; @ ! %r78 bra $L20; .loc 1 74 0 add.f32 %r51,%r35,0f3f000000; bra $L16; $L20: .loc 1 76 0 mov.f32 %r79,0f3f000000; sub.f32 %r51,%r35,%r79; $L16: .loc 1 78 0 cvt.rzi.s64.f32 %r52,%r51; .loc 1 79 0 cvt.rn.f32.s64 %r80,%r52; .loc 1 80 0 cvt.f64.f32 %r55,%r80; neg.f64 %r81,%r55; cvt.f64.f32 %r84,%r71; fma.rn.f64 %r85,%r81,0d4009200000000000,%r84; fma.rn.f64 %r86,%r81,0d3f4fb40000000000,%r85; fma.rn.f64 %r87,%r81,0d3e84442d18469899,%r86; cvt.rn.f32.f64 %r59,%r87; .loc 1 96 0 mul.f32 %r36,%r59,%r59; .loc 1 97 0 mul.f32 %r37,%r77,%r77; .loc 1 102 0 mov.f32 %r63,0f00000000; .loc 1 101 0 mov.f32 %r32,%r63; .loc 1 99 0 mov.f32 %r31,0f3f800000; .loc 1 98 0 mov.f32 %r30,%r31; .loc 1 100 0 mov.f32 %r29,%r31; $L17: .loc 1 104 0 add.f32 %r38,%r32,0f3f800000; .loc 1 105 0 mul.f32 %r39,%r29,%r38; .loc 1 106 0 add.f32 %r40,%r38,0f3f800000; .loc 1 107 0 mul.f32 %r41,%r39,%r40; .loc 1 108 0 mul.f32 %r42,%r30,%r36; .loc 1 109 0 mul.f32 %r43,%r31,%r37; .loc 1 110 0 add.f32 %r44,%r42,%r43; .loc 1 111 0 div.rn.f32 %r88,%r44,%r41; .loc 1 112 0 add.f32 %r46,%r88,%r63; .loc 1 114 0 add.f32 %r47,%r40,0f3f800000; .loc 1 115 0 mul.f32 %r48,%r41,%r47; .loc 1 116 0 add.f32 %r32,%r47,0f3f800000; .loc 1 117 0 mul.f32 %r29,%r48,%r32; .loc 1 118 0 mul.f32 %r30,%r36,%r42; .loc 1 119 0 mul.f32 %r31,%r37,%r43; .loc 1 120 0 sub.f32 %r49,%r31,%r30; .loc 1 121 0 div.rn.f32 %r50,%r49,%r29; .loc 1 122 0 add.f32 %r63,%r46,%r50; .loc 1 123 0 div.rn.f32 %r90,%r50,%r63; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r90; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } cvt.f64.f32 %r92,%r91; setp.gt.f64 %r93,%r92,0d3e601b2b29a4692b; @ %r93 bra $L17; .loc 1 125 0 mov.f32 %value,%r63; st.param.f32 [%value_out],%value; ret; } lib_a-cexp.o/ 0 0 0 644 2375 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cexp .visible .func cexp (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cexp.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cexp .visible .func cexp (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r29; .reg .u64 %r30; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r35; .reg .f64 %r38; .reg .f64 %r40; .reg .f64 %r42; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; mov.u64 %r30,%ar0; mov.f64 %r31,%ar1; mov.f64 %r32,%ar2; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r35,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),exp,(%out_arg1); ld.param.f64 %r40,[%value_in]; } .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),sin,(%out_arg1); ld.param.f64 %r42,[%value_in]; } mul.f64 %r29,%r42,%r40; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),cos,(%out_arg1); ld.param.f64 %r44,[%value_in]; } mul.f64 %r45,%r29,0d0000000000000000; fma.rn.f64 %r46,%r44,%r40,%r45; .loc 1 81 0 st.f64 [%r30],%r46; st.f64 [%r30+8],%r29; .loc 1 82 0 ret; } lib_a-cexpf.o/ 0 0 0 644 2387 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cexpf .visible .func cexpf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cexpf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: expf .extern .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cexpf .visible .func cexpf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r29; .reg .u64 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .f32 %r35; .reg .f32 %r38; .reg .f32 %r40; .reg .f32 %r42; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; mov.u64 %r30,%ar0; mov.f32 %r31,%ar1; mov.f32 %r32,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r35,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r38,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),expf,(%out_arg1); ld.param.f32 %r40,[%value_in]; } .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r42,[%value_in]; } mul.f32 %r29,%r42,%r40; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } mul.f32 %r45,%r29,0f00000000; fma.rn.f32 %r46,%r44,%r40,%r45; .loc 1 48 0 st.f32 [%r30],%r46; st.f32 [%r30+4],%r29; .loc 1 49 0 ret; } lib_a-cimag.o/ 0 0 0 644 570 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cimag .visible .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/cimag.c" // BEGIN GLOBAL FUNCTION DEF: cimag .visible .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; mov.f64 %value,%ar1; .loc 1 53 0 st.param.f64 [%value_out],%value; ret; } lib_a-cimagf.o/ 0 0 0 644 575 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cimagf .visible .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/cimagf.c" // BEGIN GLOBAL FUNCTION DEF: cimagf .visible .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; mov.f32 %value,%ar1; .loc 1 20 0 st.param.f32 [%value_out],%value; ret; } lib_a-clog.o/ 0 0 0 644 2474 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: clog .visible .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/clog.c" // BEGIN GLOBAL FUNCTION DECL: cabs .extern .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2 .extern .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: clog .visible .func clog (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r33; .reg .f64 %r35; .reg .f64 %r38; .reg .f64 %r41; .reg .f64 %r44; .reg .f64 %r45; mov.u64 %r28,%ar0; mov.f64 %r29,%ar1; mov.f64 %r30,%ar2; .loc 1 86 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cabs,(%out_arg1,%out_arg2); ld.param.f64 %r33,[%value_in]; } .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),log,(%out_arg1); ld.param.f64 %r35,[%value_in]; } .loc 1 88 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r41; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r38; call (%value_in),atan2,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } .loc 1 89 0 fma.rn.f64 %r45,%r44,0d0000000000000000,%r35; .loc 1 90 0 st.f64 [%r28],%r45; st.f64 [%r28+8],%r44; .loc 1 91 0 ret; } lib_a-clogf.o/ 0 0 0 644 2486 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: clogf .visible .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/clogf.c" // BEGIN GLOBAL FUNCTION DECL: cabsf .extern .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: atan2f .extern .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: clogf .visible .func clogf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %r28; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r33; .reg .f32 %r35; .reg .f32 %r38; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r45; mov.u64 %r28,%ar0; mov.f32 %r29,%ar1; mov.f32 %r30,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cabsf,(%out_arg1,%out_arg2); ld.param.f32 %r33,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; call (%value_in),logf,(%out_arg1); ld.param.f32 %r35,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r38,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r41,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r38; call (%value_in),atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } .loc 1 47 0 fma.rn.f32 %r45,%r44,0f00000000,%r35; .loc 1 48 0 st.f32 [%r28],%r45; st.f32 [%r28+4],%r44; .loc 1 49 0 ret; } lib_a-conj.o/ 0 0 0 644 1164 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: conj .visible .func conj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/conj.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: conj .visible .func conj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; } .reg .u64 %r26; .reg .f64 %r27; .reg .f64 %r28; .reg .f64 %r29; mov.u64 %r26,%ar0; mov.f64 %r27,%ar1; mov.f64 %r28,%ar2; .loc 1 52 0 neg.f64 %r29,%r28; .loc 1 54 0 st.f64 [%r26],%r27; st.f64 [%r26+8],%r29; .loc 1 55 0 ret; } lib_a-conjf.o/ 0 0 0 644 1168 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: conjf .visible .func conjf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/conjf.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: conjf .visible .func conjf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u64 %r26; .reg .f32 %r27; .reg .f32 %r28; .reg .f32 %r29; mov.u64 %r26,%ar0; mov.f32 %r27,%ar1; mov.f32 %r28,%ar2; .loc 1 19 0 neg.f32 %r29,%r28; .loc 1 21 0 st.f32 [%r26],%r27; st.f32 [%r26+4],%r29; .loc 1 22 0 ret; } /43 0 0 0 644 1034 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysignl .visible .func (.param .f64 %value_out) copysignl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/copysignl.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: copysignl .visible .func (.param .f64 %value_out) copysignl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-coshl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: coshl .visible .func (.param .f64 %value_out) coshl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/coshl.c" // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: coshl .visible .func (.param .f64 %value_out) coshl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-cosl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cosl .visible .func (.param .f64 %value_out) cosl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/cosl.c" // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: cosl .visible .func (.param .f64 %value_out) cosl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),cos,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-cpow.o/ 0 0 0 644 4601 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: cpow .visible .func cpow (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4); .file 1 "../../../../../../newlib/libm/complex/cpow.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cabs .extern .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: carg .extern .func (.param .f64 %value_out) carg (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 8 .u64 $LC0[2] = {0,0 }; // BEGIN GLOBAL FUNCTION DEF: cpow .visible .func cpow (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2, .param .f64 %in_ar3, .param .f64 %in_ar4) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %ar3; ld.param.f64 %ar3,[%in_ar3]; .reg .f64 %ar4; ld.param.f64 %ar4,[%in_ar4]; .reg .f64 %r30; .reg .f64 %r31; .reg .f64 %r36; .reg .u64 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r44; .reg .f64 %r47; .reg .f64 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r56; .reg .f64 %r59; .reg .pred %r60; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r66; .reg .f64 %r68; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; mov.u64 %r37,%ar0; mov.f64 %r38,%ar1; mov.f64 %r39,%ar2; mov.f64 %r40,%ar3; mov.f64 %r41,%ar4; .loc 1 86 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r47,[%value_in]; } .loc 1 88 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r39; call (%value_in),cabs,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } .loc 1 89 0 setp.neu.f64 %r51,%r50,0d0000000000000000; @ %r51 bra $L2; .loc 1 90 0 ld.const.f64 %r52,[$LC0]; st.f64 [%r37],%r52; ld.const.f64 %r53,[$LC0+8]; st.f64 [%r37+8],%r53; bra $L1; $L2: .loc 1 92 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r39; call (%value_in),carg,(%out_arg1,%out_arg2); ld.param.f64 %r56,[%value_in]; } .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r44; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r59,[%value_in]; } mov.f64 %r30,%r59; .loc 1 94 0 mul.f64 %r31,%r44,%r56; .loc 1 95 0 setp.eq.f64 %r60,%r47,0d0000000000000000; @ %r60 bra $L4; .loc 1 96 0 neg.f64 %r62,%r47; mul.f64 %r63,%r62,%r56; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r63; call (%value_in),exp,(%out_arg1); ld.param.f64 %r64,[%value_in]; } mul.f64 %r30,%r30,%r64; .loc 1 97 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; call (%value_in),log,(%out_arg1); ld.param.f64 %r66,[%value_in]; } fma.rn.f64 %r31,%r66,%r47,%r31; $L4: .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),sin,(%out_arg1); ld.param.f64 %r68,[%value_in]; } mul.f64 %r36,%r68,%r30; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),cos,(%out_arg1); ld.param.f64 %r70,[%value_in]; } mul.f64 %r71,%r36,0d0000000000000000; fma.rn.f64 %r72,%r70,%r30,%r71; .loc 1 100 0 st.f64 [%r37],%r72; st.f64 [%r37+8],%r36; $L1: .loc 1 101 0 ret; } lib_a-cpowf.o/ 0 0 0 644 4607 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: cpowf .visible .func cpowf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4); .file 1 "../../../../../../newlib/libm/complex/cpowf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cabsf .extern .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cargf .extern .func (.param .f32 %value_out) cargf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: expf .extern .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 4 .u32 $LC0[2] = {0,0 }; // BEGIN GLOBAL FUNCTION DEF: cpowf .visible .func cpowf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2, .param .f32 %in_ar3, .param .f32 %in_ar4) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %ar3; ld.param.f32 %ar3,[%in_ar3]; .reg .f32 %ar4; ld.param.f32 %ar4,[%in_ar4]; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r36; .reg .u64 %r37; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r47; .reg .f32 %r50; .reg .pred %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r56; .reg .f32 %r59; .reg .pred %r60; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r66; .reg .f32 %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; mov.u64 %r37,%ar0; mov.f32 %r38,%ar1; mov.f32 %r39,%ar2; mov.f32 %r40,%ar3; mov.f32 %r41,%ar4; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r47,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r39; call (%value_in),cabsf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } .loc 1 47 0 setp.neu.f32 %r51,%r50,0f00000000; @ %r51 bra $L2; .loc 1 48 0 ld.const.f32 %r52,[$LC0]; st.f32 [%r37],%r52; ld.const.f32 %r53,[$LC0+4]; st.f32 [%r37+4],%r53; bra $L1; $L2: .loc 1 50 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r39; call (%value_in),cargf,(%out_arg1,%out_arg2); ld.param.f32 %r56,[%value_in]; } .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r44; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r59,[%value_in]; } mov.f32 %r30,%r59; .loc 1 52 0 mul.f32 %r31,%r44,%r56; .loc 1 53 0 setp.eq.f32 %r60,%r47,0f00000000; @ %r60 bra $L4; .loc 1 54 0 neg.f32 %r62,%r47; mul.f32 %r63,%r62,%r56; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r63; call (%value_in),expf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } mul.f32 %r30,%r30,%r64; .loc 1 55 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; call (%value_in),logf,(%out_arg1); ld.param.f32 %r66,[%value_in]; } fma.rn.f32 %r31,%r66,%r47,%r31; $L4: .loc 1 57 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } mul.f32 %r36,%r68,%r30; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r70,[%value_in]; } mul.f32 %r71,%r36,0f00000000; fma.rn.f32 %r72,%r70,%r30,%r71; .loc 1 58 0 st.f32 [%r37],%r72; st.f32 [%r37+4],%r36; $L1: .loc 1 59 0 ret; } lib_a-cproj.o/ 0 0 0 644 3307 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cproj .visible .func cproj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cproj.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cproj .visible .func cproj (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r33; .reg .u32 %r35; .reg .pred %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r46; .reg .u32 %r48; .reg .pred %r49; mov.u64 %r28,%ar0; mov.f64 %r29,%ar1; mov.f64 %r30,%ar2; .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r33,[%value_in]; } { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r35,[%value_in]; } setp.ne.u32 %r36,%r35,1; @ %r36 bra $L2; $L4: .loc 1 100 0 mov.f64 %r37,0d7ff0000000000000; st.f64 [%frame],%r37; .loc 1 102 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r40,[%value_in]; } mov.f64 %r41,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r41; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r40; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r43,[%value_in]; } ld.f64 %r29,[%frame]; mov.f64 %r30,%r43; bra $L3; $L2: .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r30; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r46; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,1; @ %r49 bra $L4; $L3: .loc 1 105 0 st.f64 [%r28],%r29; st.f64 [%r28+8],%r30; .loc 1 106 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-cprojf.o/ 0 0 0 644 3301 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cprojf .visible .func cprojf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/cprojf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cprojf .visible .func cprojf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r28; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r33; .reg .u32 %r35; .reg .pred %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r43; .reg .f32 %r46; .reg .u32 %r48; .reg .pred %r49; mov.u64 %r28,%ar0; mov.f32 %r29,%ar1; mov.f32 %r30,%ar2; .loc 1 58 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r33,[%value_in]; } { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r35,[%value_in]; } setp.ne.u32 %r36,%r35,1; @ %r36 bra $L2; $L4: .loc 1 62 0 mov.f32 %r37,0f7f800000; st.f32 [%frame],%r37; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r40,[%value_in]; } mov.f32 %r41,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r40; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r43,[%value_in]; } ld.f32 %r29,[%frame]; mov.f32 %r30,%r43; bra $L3; $L2: .loc 1 58 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r29; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r30; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,1; @ %r49 bra $L4; $L3: .loc 1 67 0 st.f32 [%r28],%r29; st.f32 [%r28+4],%r30; .loc 1 68 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-creal.o/ 0 0 0 644 570 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: creal .visible .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/creal.c" // BEGIN GLOBAL FUNCTION DEF: creal .visible .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; mov.f64 %value,%ar0; .loc 1 53 0 st.param.f64 [%value_out],%value; ret; } lib_a-crealf.o/ 0 0 0 644 575 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: crealf .visible .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/complex/crealf.c" // BEGIN GLOBAL FUNCTION DEF: crealf .visible .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; mov.f32 %value,%ar0; .loc 1 20 0 st.param.f32 [%value_out],%value; ret; } lib_a-csin.o/ 0 0 0 644 3267 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csin .visible .func csin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/csin.c" // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchsh .extern .func _cchsh (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: csin .visible .func csin (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r31; .reg .u64 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r37; .reg .u64 %r41; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r50; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .f64 %r55; mov.u64 %r32,%ar0; mov.f64 %r33,%ar1; mov.f64 %r34,%ar2; .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r34; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r37,[%value_in]; } add.u64 %r41,%frame,8; { .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchsh,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r34; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),cos,(%out_arg1); ld.param.f64 %r46,[%value_in]; } ld.f64 %r47,[%frame]; mul.f64 %r31,%r46,%r47; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r34; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; call (%value_in),sin,(%out_arg1); ld.param.f64 %r52,[%value_in]; } mul.f64 %r53,%r31,0d0000000000000000; ld.f64 %r55,[%frame+8]; fma.rn.f64 %r54,%r52,%r55,%r53; .loc 1 80 0 st.f64 [%r32],%r54; st.f64 [%r32+8],%r31; .loc 1 81 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-csinf.o/ 0 0 0 644 3279 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csinf .visible .func csinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/csinf.c" // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _cchshf .extern .func _cchshf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: csinf .visible .func csinf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f32 %r31; .reg .u64 %r32; .reg .f32 %r33; .reg .f32 %r34; .reg .f32 %r37; .reg .u64 %r41; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r50; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; mov.u64 %r32,%ar0; mov.f32 %r33,%ar1; mov.f32 %r34,%ar2; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r34; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r37,[%value_in]; } add.u64 %r41,%frame,4; { .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call _cchshf,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r34; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r46,[%value_in]; } ld.f32 %r47,[%frame]; mul.f32 %r31,%r46,%r47; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r33; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r34; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r52,[%value_in]; } mul.f32 %r53,%r31,0f00000000; ld.f32 %r55,[%frame+4]; fma.rn.f32 %r54,%r52,%r55,%r53; .loc 1 47 0 st.f32 [%r32],%r54; st.f32 [%r32+4],%r31; .loc 1 48 0 st.shared.u64 [%sspslot],%sspprev; ret; } lib_a-csinh.o/ 0 0 0 644 2637 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csinh .visible .func csinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/csinh.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: csinh .visible .func csinh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r30; .reg .u64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r36; .reg .f64 %r39; .reg .f64 %r41; .reg .f64 %r43; .reg .f64 %r45; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; mov.u64 %r31,%ar0; mov.f64 %r32,%ar1; mov.f64 %r33,%ar2; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r36,[%value_in]; } .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r33; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r41,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),sin,(%out_arg1); ld.param.f64 %r43,[%value_in]; } mul.f64 %r30,%r41,%r43; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r45,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),cos,(%out_arg1); ld.param.f64 %r47,[%value_in]; } mul.f64 %r48,%r30,0d0000000000000000; fma.rn.f64 %r49,%r45,%r47,%r48; .loc 1 79 0 st.f64 [%r31],%r49; st.f64 [%r31+8],%r30; .loc 1 80 0 ret; } lib_a-csinhf.o/ 0 0 0 644 2652 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csinhf .visible .func csinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/csinhf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: csinhf .visible .func csinhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r30; .reg .u64 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .f32 %r36; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r43; .reg .f32 %r45; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; mov.u64 %r31,%ar0; mov.f32 %r32,%ar1; mov.f32 %r33,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r36,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r33; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r41,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r43,[%value_in]; } mul.f32 %r30,%r41,%r43; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } mul.f32 %r48,%r30,0f00000000; fma.rn.f32 %r49,%r45,%r47,%r48; .loc 1 47 0 st.f32 [%r31],%r49; st.f32 [%r31+4],%r30; .loc 1 48 0 ret; } lib_a-csqrt.o/ 0 0 0 644 6628 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csqrt .visible .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/csqrt.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sqrt .extern .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cabs .extern .func (.param .f64 %value_out) cabs (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: csqrt .visible .func csqrt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r25; .reg .f64 %r38; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r69; .reg .u64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r75; .reg .f64 %r78; .reg .pred %r79; .reg .pred %r80; .reg .f64 %r83; .reg .f64 %r85; .reg .pred %r86; .reg .pred %r89; .reg .f64 %r91; .reg .f64 %r93; .reg .pred %r94; .reg .f64 %r96; .reg .f64 %r100; .reg .pred %r101; .reg .f64 %r103; .reg .pred %r104; .reg .f64 %r110; .reg .f64 %r113; .reg .pred %r114; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r124; .reg .f64 %r126; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .pred %r131; mov.u64 %r70,%ar0; mov.f64 %r71,%ar1; mov.f64 %r72,%ar2; .loc 1 79 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r71; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r72; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r75,[%value_in]; } .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r71; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r72; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r78,[%value_in]; } .loc 1 82 0 setp.neu.f64 %r79,%r78,0d0000000000000000; @ %r79 bra $L2; .loc 1 83 0 setp.neu.f64 %r80,%r75,0d0000000000000000; @ %r80 bra $L3; .loc 1 84 0 fma.rn.f64 %r45,%r78,0d0000000000000000,0d0000000000000000; mov.f64 %r46,%r78; bra $L4; $L3: .loc 1 86 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r75; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r83,[%value_in]; } .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r83; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r85,[%value_in]; } .loc 1 88 0 setp.lt.f64 %r86,%r75,0d0000000000000000; @ ! %r86 bra $L26; .loc 1 89 0 fma.rn.f64 %r45,%r85,0d0000000000000000,0d0000000000000000; mov.f64 %r46,%r85; bra $L4; $L26: .loc 1 91 0 fma.rn.f64 %r45,%r78,0d0000000000000000,%r85; mov.f64 %r46,%r78; $L4: .loc 1 94 0 st.f64 [%r70],%r45; st.f64 [%r70+8],%r46; bra $L1; $L2: .loc 1 96 0 setp.neu.f64 %r89,%r75,0d0000000000000000; @ %r89 bra $L8; .loc 1 97 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r78; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r91,[%value_in]; } .loc 1 98 0 mul.f64 %r25,%r91,0d3fe0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r93,[%value_in]; } .loc 1 99 0 setp.gt.f64 %r94,%r78,0d0000000000000000; @ ! %r94 bra $L27; .loc 1 100 0 fma.rn.f64 %r47,%r93,0d0000000000000000,%r93; mov.f64 %r48,%r93; bra $L11; $L27: .loc 1 102 0 neg.f64 %r96,%r93; fma.rn.f64 %r47,%r96,0d0000000000000000,%r93; mov.f64 %r48,%r96; $L11: .loc 1 103 0 st.f64 [%r70],%r47; st.f64 [%r70+8],%r48; bra $L1; $L8: .loc 1 106 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r75; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r100,[%value_in]; } setp.gt.f64 %r101,%r100,0d4010000000000000; @ ! %r101 bra $L28; $L15: .loc 1 107 0 mul.f64 %r51,%r75,0d3fd0000000000000; .loc 1 108 0 mul.f64 %r52,%r78,0d3fd0000000000000; .loc 1 109 0 mov.f64 %r55,0d4000000000000000; bra $L14; $L28: .loc 1 106 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r78; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r103,[%value_in]; } setp.gt.f64 %r104,%r103,0d4010000000000000; @ %r104 bra $L15; .loc 1 112 0 mul.f64 %r51,%r75,0d4350000000000000; .loc 1 113 0 mul.f64 %r52,%r78,0d4350000000000000; .loc 1 114 0 mov.f64 %r55,0d3e40000000000000; $L14: .loc 1 121 0 fma.rn.f64 %r110,%r52,0d0000000000000000,%r51; .loc 1 122 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r110; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),cabs,(%out_arg1,%out_arg2); ld.param.f64 %r113,[%value_in]; } .loc 1 123 0 setp.gt.f64 %r114,%r51,0d0000000000000000; @ ! %r114 bra $L29; .loc 1 124 0 mul.f64 %r116,%r51,0d3fe0000000000000; fma.rn.f64 %r117,%r113,0d3fe0000000000000,%r116; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r117; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r118,[%value_in]; } .loc 1 125 0 mul.f64 %r120,%r52,0d3fe0000000000000; div.rn.f64 %r121,%r120,%r118; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r121; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r122,[%value_in]; } mul.f64 %r53,%r122,%r55; .loc 1 126 0 mul.f64 %r54,%r55,%r118; bra $L18; $L29: .loc 1 128 0 mul.f64 %r124,%r51,0dbfe0000000000000; fma.rn.f64 %r38,%r113,0d3fe0000000000000,%r124; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r126,[%value_in]; } .loc 1 129 0 mul.f64 %r128,%r52,0d3fe0000000000000; div.rn.f64 %r129,%r128,%r126; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r129; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r130,[%value_in]; } mul.f64 %r54,%r130,%r55; .loc 1 130 0 mul.f64 %r53,%r55,%r126; $L18: mul.f64 %r69,%r53,0d0000000000000000; .loc 1 132 0 setp.lt.f64 %r131,%r52,0d0000000000000000; @ ! %r131 bra $L30; .loc 1 133 0 sub.f64 %r49,%r54,%r69; neg.f64 %r50,%r53; bra $L21; $L30: .loc 1 135 0 add.f64 %r49,%r54,%r69; mov.f64 %r50,%r53; $L21: .loc 1 136 0 st.f64 [%r70],%r49; st.f64 [%r70+8],%r50; $L1: .loc 1 137 0 ret; } lib_a-csqrtf.o/ 0 0 0 644 6447 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: csqrtf .visible .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/csqrtf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sqrtf .extern .func (.param .f32 %value_out) sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cabsf .extern .func (.param .f32 %value_out) cabsf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: csqrtf .visible .func csqrtf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r27; .reg .f32 %r40; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r68; .reg .u64 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r74; .reg .f32 %r77; .reg .pred %r78; .reg .pred %r79; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r83; .reg .pred %r84; .reg .f32 %r85; .reg .f32 %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r91; .reg .f32 %r93; .reg .pred %r94; .reg .f32 %r96; .reg .f32 %r100; .reg .pred %r101; .reg .f32 %r103; .reg .pred %r104; .reg .f32 %r110; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r124; .reg .f32 %r126; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .pred %r131; mov.u64 %r69,%ar0; mov.f32 %r70,%ar1; mov.f32 %r71,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r71; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r74,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r71; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r77,[%value_in]; } .loc 1 47 0 setp.neu.f32 %r78,%r77,0f00000000; @ %r78 bra $L2; .loc 1 48 0 setp.lt.f32 %r79,%r74,0f00000000; @ ! %r79 bra $L25; .loc 1 49 0 neg.f32 %r81,%r74; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r81; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r82,[%value_in]; } fma.rn.f32 %r83,%r82,0f00000000,0f00000000; .loc 1 50 0 st.f32 [%r69],%r83; st.f32 [%r69+4],%r82; bra $L1; $L25: .loc 1 51 0 setp.neu.f32 %r84,%r74,0f00000000; @ %r84 bra $L6; .loc 1 52 0 fma.rn.f32 %r85,%r77,0f00000000,0f00000000; st.f32 [%r69],%r85; st.f32 [%r69+4],%r77; bra $L1; $L6: .loc 1 54 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r74; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r87,[%value_in]; } fma.rn.f32 %r88,%r77,0f00000000,%r87; .loc 1 55 0 st.f32 [%r69],%r88; st.f32 [%r69+4],%r77; bra $L1; $L2: .loc 1 59 0 setp.neu.f32 %r89,%r74,0f00000000; @ %r89 bra $L7; .loc 1 60 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r77; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } .loc 1 61 0 mul.f32 %r27,%r91,0f3f000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r27; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r93,[%value_in]; } .loc 1 62 0 setp.gt.f32 %r94,%r77,0f00000000; @ ! %r94 bra $L26; .loc 1 63 0 fma.rn.f32 %r47,%r93,0f00000000,%r93; mov.f32 %r48,%r93; bra $L10; $L26: .loc 1 65 0 neg.f32 %r96,%r93; fma.rn.f32 %r47,%r96,0f00000000,%r93; mov.f32 %r48,%r96; $L10: .loc 1 66 0 st.f32 [%r69],%r47; st.f32 [%r69+4],%r48; bra $L1; $L7: .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r74; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r100,[%value_in]; } setp.gt.f32 %r101,%r100,0f40800000; @ ! %r101 bra $L27; $L14: .loc 1 71 0 mul.f32 %r51,%r74,0f3e800000; .loc 1 72 0 mul.f32 %r52,%r77,0f3e800000; .loc 1 73 0 mov.f32 %r55,0f40000000; bra $L13; $L27: .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r77; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r103,[%value_in]; } setp.gt.f32 %r104,%r103,0f40800000; @ %r104 bra $L14; .loc 1 76 0 mul.f32 %r51,%r74,0f4c800000; .loc 1 77 0 mul.f32 %r52,%r77,0f4c800000; .loc 1 78 0 mov.f32 %r55,0f39000000; $L13: .loc 1 85 0 fma.rn.f32 %r110,%r52,0f00000000,%r51; .loc 1 86 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r110; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r52; call (%value_in),cabsf,(%out_arg1,%out_arg2); ld.param.f32 %r113,[%value_in]; } .loc 1 87 0 setp.gt.f32 %r114,%r51,0f00000000; @ ! %r114 bra $L28; .loc 1 88 0 mul.f32 %r116,%r51,0f3f000000; fma.rn.f32 %r117,%r113,0f3f000000,%r116; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r117; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r118,[%value_in]; } .loc 1 89 0 mul.f32 %r120,%r52,0f3f000000; div.rn.f32 %r121,%r120,%r118; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r121; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r122,[%value_in]; } mul.f32 %r53,%r122,%r55; .loc 1 90 0 mul.f32 %r54,%r55,%r118; bra $L17; $L28: .loc 1 92 0 mul.f32 %r124,%r51,0fbf000000; fma.rn.f32 %r40,%r113,0f3f000000,%r124; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),sqrtf,(%out_arg1); ld.param.f32 %r126,[%value_in]; } .loc 1 93 0 mul.f32 %r128,%r52,0f3f000000; div.rn.f32 %r129,%r128,%r126; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r129; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r130,[%value_in]; } mul.f32 %r54,%r130,%r55; .loc 1 94 0 mul.f32 %r53,%r55,%r126; $L17: mul.f32 %r68,%r53,0f00000000; .loc 1 97 0 setp.lt.f32 %r131,%r52,0f00000000; @ ! %r131 bra $L29; .loc 1 98 0 sub.f32 %r49,%r54,%r68; neg.f32 %r50,%r53; bra $L20; $L29: .loc 1 100 0 add.f32 %r49,%r54,%r68; mov.f32 %r50,%r53; $L20: .loc 1 101 0 st.f32 [%r69],%r49; st.f32 [%r69+4],%r50; $L1: .loc 1 102 0 ret; } lib_a-ctan.o/ 0 0 0 644 4375 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: ctan .visible .func ctan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ctan.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctans .extern .func (.param .f64 %value_out) _ctans (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 8 .u64 $LC0[2] = {9221120237041090560,9218868437227405312 }; // BEGIN GLOBAL FUNCTION DEF: ctan .visible .func ctan (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r50; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r55; .reg .pred %r56; .reg .f64 %r59; .reg .pred %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r65; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r71; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; mov.u64 %r39,%ar0; mov.f64 %r40,%ar1; mov.f64 %r41,%ar2; .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } add.f64 %r46,%r44,%r44; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r46; call (%value_in),cos,(%out_arg1); ld.param.f64 %r47,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } add.f64 %r52,%r50,%r50; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r53,[%value_in]; } add.f64 %r37,%r47,%r53; .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r55,[%value_in]; } setp.lt.f64 %r56,%r55,0d3fd0000000000000; @ ! %r56 bra $L2; .loc 1 81 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),_ctans,(%out_arg1,%out_arg2); ld.param.f64 %r59,[%value_in]; } mov.f64 %r37,%r59; $L2: .loc 1 83 0 setp.neu.f64 %r60,%r37,0d0000000000000000; @ %r60 bra $L4; .loc 1 86 0 ld.const.f64 %r61,[$LC0]; st.f64 [%r39],%r61; ld.const.f64 %r62,[$LC0+8]; st.f64 [%r39+8],%r62; bra $L1; $L4: .loc 1 89 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r65,[%value_in]; } add.f64 %r67,%r65,%r65; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r67; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r68,[%value_in]; } div.rn.f64 %r38,%r68,%r37; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r41; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r71,[%value_in]; } add.f64 %r73,%r71,%r71; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r74,[%value_in]; } div.rn.f64 %r75,%r74,%r37; fma.rn.f64 %r76,%r38,0d0000000000000000,%r75; .loc 1 90 0 st.f64 [%r39],%r76; st.f64 [%r39+8],%r38; $L1: .loc 1 91 0 ret; } lib_a-ctanf.o/ 0 0 0 644 4364 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: ctanf .visible .func ctanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ctanf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _ctansf .extern .func (.param .f32 %value_out) _ctansf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 4 .u32 $LC0[2] = {2143289344,2139095040 }; // BEGIN GLOBAL FUNCTION DEF: ctanf .visible .func ctanf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r50; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r55; .reg .pred %r56; .reg .f32 %r59; .reg .pred %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r71; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; mov.u64 %r39,%ar0; mov.f32 %r40,%ar1; mov.f32 %r41,%ar2; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } add.f32 %r46,%r44,%r44; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } add.f32 %r52,%r50,%r50; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r52; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r53,[%value_in]; } add.f32 %r37,%r47,%r53; .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r55,[%value_in]; } setp.lt.f32 %r56,%r55,0f3e800000; @ ! %r56 bra $L2; .loc 1 48 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),_ctansf,(%out_arg1,%out_arg2); ld.param.f32 %r59,[%value_in]; } mov.f32 %r37,%r59; $L2: .loc 1 50 0 setp.neu.f32 %r60,%r37,0f00000000; @ %r60 bra $L4; .loc 1 53 0 ld.const.f32 %r61,[$LC0]; st.f32 [%r39],%r61; ld.const.f32 %r62,[$LC0+4]; st.f32 [%r39+4],%r62; bra $L1; $L4: .loc 1 56 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r65,[%value_in]; } add.f32 %r67,%r65,%r65; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } div.rn.f32 %r38,%r68,%r37; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r71,[%value_in]; } add.f32 %r73,%r71,%r71; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r73; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r74,[%value_in]; } div.rn.f32 %r75,%r74,%r37; fma.rn.f32 %r76,%r38,0f00000000,%r75; .loc 1 57 0 st.f32 [%r39],%r76; st.f32 [%r39+4],%r38; $L1: .loc 1 58 0 ret; } lib_a-ctanh.o/ 0 0 0 644 2775 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ctanh .visible .func ctanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ctanh.c" // BEGIN GLOBAL FUNCTION DECL: creal .extern .func (.param .f64 %value_out) creal (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimag .extern .func (.param .f64 %value_out) cimag (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cosh .extern .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ctanh .visible .func ctanh (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r22; .reg .f64 %r24; .reg .f64 %r32; .reg .f64 %r33; .reg .u64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r48; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r52; mov.u64 %r34,%ar0; mov.f64 %r35,%ar1; mov.f64 %r36,%ar2; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),creal,(%out_arg1,%out_arg2); ld.param.f64 %r39,[%value_in]; } .loc 1 78 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r36; call (%value_in),cimag,(%out_arg1,%out_arg2); ld.param.f64 %r42,[%value_in]; } .loc 1 79 0 add.f64 %r22,%r39,%r39; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r22; call (%value_in),cosh,(%out_arg1); ld.param.f64 %r44,[%value_in]; } add.f64 %r24,%r42,%r42; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),cos,(%out_arg1); ld.param.f64 %r46,[%value_in]; } add.f64 %r32,%r44,%r46; .loc 1 80 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),sin,(%out_arg1); ld.param.f64 %r48,[%value_in]; } div.rn.f64 %r33,%r48,%r32; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r22; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r50,[%value_in]; } div.rn.f64 %r51,%r50,%r32; fma.rn.f64 %r52,%r33,0d0000000000000000,%r51; .loc 1 82 0 st.f64 [%r34],%r52; st.f64 [%r34+8],%r33; .loc 1 83 0 ret; } lib_a-ctanhf.o/ 0 0 0 644 2790 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ctanhf .visible .func ctanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/complex/ctanhf.c" // BEGIN GLOBAL FUNCTION DECL: crealf .extern .func (.param .f32 %value_out) crealf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: cimagf .extern .func (.param .f32 %value_out) cimagf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: coshf .extern .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinhf .extern .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ctanhf .visible .func ctanhf (.param .u64 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r22; .reg .f32 %r24; .reg .f32 %r32; .reg .f32 %r33; .reg .u64 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r39; .reg .f32 %r42; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r48; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; mov.u64 %r34,%ar0; mov.f32 %r35,%ar1; mov.f32 %r36,%ar2; .loc 1 44 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),crealf,(%out_arg1,%out_arg2); ld.param.f32 %r39,[%value_in]; } .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r36; call (%value_in),cimagf,(%out_arg1,%out_arg2); ld.param.f32 %r42,[%value_in]; } .loc 1 46 0 add.f32 %r22,%r39,%r39; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r22; call (%value_in),coshf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } add.f32 %r24,%r42,%r42; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r46,[%value_in]; } add.f32 %r32,%r44,%r46; .loc 1 47 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r48,[%value_in]; } div.rn.f32 %r33,%r48,%r32; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r22; call (%value_in),sinhf,(%out_arg1); ld.param.f32 %r50,[%value_in]; } div.rn.f32 %r51,%r50,%r32; fma.rn.f32 %r52,%r33,0f00000000,%r51; .loc 1 49 0 st.f32 [%r34],%r52; st.f32 [%r34+4],%r33; .loc 1 50 0 ret; } lib_a-e_acos.o/ 0 0 0 644 5562 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acos .visible .func (.param .f64 %value_out) __ieee754_acos (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_acos.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acos .visible .func (.param .f64 %value_out) __ieee754_acos (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r25; .reg .u32 %r58; .reg .u32 %r59; .reg .f64 %r60; .reg .f64 %r62; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r74; .reg .u64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .pred %r101; .reg .u32 %r102; .reg .u32 %r104; .reg .u32 %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .pred %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r123; .reg .f64 %r124; .reg .pred %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r144; .reg .u64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .f64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .f64 %r158; .reg .f64 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; mov.f64 %r98,%ar0; .loc 1 71 0 mov.b64 %r99,%r98; shr.u64 %r100,%r99,32; cvt.u32.u64 %r58,%r100; .loc 1 72 0 and.b32 %r59,%r58,2147483647; .loc 1 73 0 setp.le.s32 %r101,%r59,1072693247; @ %r101 bra $L2; .loc 1 76 0 add.u32 %r102,%r59,-1072693248; cvt.u32.u64 %r105,%r99; or.b32 %r104,%r102,%r105; setp.ne.u32 %r106,%r104,0; @ %r106 bra $L3; .loc 1 77 0 setp.gt.s32 %r107,%r58,0; .loc 1 78 0 selp.f64 %r97,0d0000000000000000,0d400921fb54442d18,%r107; bra $L1; $L3: .loc 1 80 0 sub.f64 %r25,%r98,%r98; div.rn.f64 %r97,%r25,%r25; bra $L1; $L2: .loc 1 82 0 setp.gt.s32 %r108,%r59,1071644671; @ %r108 bra $L5; .loc 1 83 0 setp.le.s32 %r109,%r59,1012924416; @ %r109 bra $L8; .loc 1 84 0 mul.f64 %r74,%r98,%r98; .loc 1 88 0 neg.f64 %r110,%r98; .loc 1 85 0 fma.rn.f64 %r111,%r74,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r112,%r111,%r74,0dbfa48228b5688f3b; fma.rn.f64 %r113,%r112,%r74,0d3fc9c1550e884455; fma.rn.f64 %r114,%r113,%r74,0dbfd4d61203eb6f7d; fma.rn.f64 %r115,%r114,%r74,0d3fc5555555555555; mul.f64 %r116,%r115,%r74; .loc 1 86 0 fma.rn.f64 %r117,%r74,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r118,%r117,%r74,0d40002ae59c598ac8; fma.rn.f64 %r119,%r118,%r74,0dc0033a271c8a2d4b; fma.rn.f64 %r120,%r119,%r74,0d3ff0000000000000; .loc 1 87 0 div.rn.f64 %r121,%r116,%r120; .loc 1 88 0 fma.rn.f64 %r122,%r110,%r121,0d3c91a62633145c07; sub.f64 %r123,%r98,%r122; mov.f64 %r124,0d3ff921fb54442d18; sub.f64 %r97,%r124,%r123; bra $L1; $L5: .loc 1 89 0 setp.ge.s32 %r125,%r58,0; @ %r125 bra $L6; .loc 1 90 0 add.f64 %r126,%r98,0d3ff0000000000000; mul.f64 %r68,%r126,0d3fe0000000000000; .loc 1 91 0 fma.rn.f64 %r127,%r68,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r128,%r127,%r68,0dbfa48228b5688f3b; fma.rn.f64 %r129,%r128,%r68,0d3fc9c1550e884455; fma.rn.f64 %r130,%r129,%r68,0dbfd4d61203eb6f7d; fma.rn.f64 %r131,%r130,%r68,0d3fc5555555555555; mul.f64 %r69,%r131,%r68; .loc 1 92 0 fma.rn.f64 %r132,%r68,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r133,%r132,%r68,0d40002ae59c598ac8; fma.rn.f64 %r134,%r133,%r68,0dc0033a271c8a2d4b; fma.rn.f64 %r70,%r134,%r68,0d3ff0000000000000; .loc 1 93 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r68; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r136,[%value_in]; } .loc 1 94 0 div.rn.f64 %r137,%r69,%r70; .loc 1 95 0 fma.rn.f64 %r138,%r136,%r137,0dbc91a62633145c07; .loc 1 96 0 add.f64 %r139,%r138,%r136; fma.rn.f64 %r97,%r139,0dc000000000000000,0d400921fb54442d18; bra $L1; $L6: .loc 1 98 0 mov.f64 %r142,0d3ff0000000000000; sub.f64 %r141,%r142,%r98; mul.f64 %r60,%r141,0d3fe0000000000000; .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r60; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r144,[%value_in]; } .loc 1 101 0 mov.b64 %r96,%r144; and.b64 %r145,%r96,-4294967296; mov.b64 %r62,%r145; .loc 1 102 0 neg.f64 %r146,%r62; fma.rn.f64 %r147,%r146,%r62,%r60; add.f64 %r148,%r144,%r62; div.rn.f64 %r149,%r147,%r148; .loc 1 103 0 fma.rn.f64 %r150,%r60,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r151,%r150,%r60,0dbfa48228b5688f3b; fma.rn.f64 %r152,%r151,%r60,0d3fc9c1550e884455; fma.rn.f64 %r153,%r152,%r60,0dbfd4d61203eb6f7d; fma.rn.f64 %r154,%r153,%r60,0d3fc5555555555555; mul.f64 %r155,%r154,%r60; .loc 1 104 0 fma.rn.f64 %r156,%r60,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r157,%r156,%r60,0d40002ae59c598ac8; fma.rn.f64 %r158,%r157,%r60,0dc0033a271c8a2d4b; fma.rn.f64 %r159,%r158,%r60,0d3ff0000000000000; .loc 1 105 0 div.rn.f64 %r160,%r155,%r159; .loc 1 106 0 fma.rn.f64 %r161,%r144,%r160,%r149; .loc 1 107 0 add.f64 %r162,%r161,%r62; add.f64 %r97,%r162,%r162; bra $L1; $L8: .loc 1 83 0 mov.f64 %r97,0d3ff921fb54442d18; $L1: .loc 1 109 0 mov.f64 %value,%r97; st.param.f64 [%value_out],%value; ret; } lib_a-e_acosh.o/0 0 0 644 3292 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosh .visible .func (.param .f64 %value_out) __ieee754_acosh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_acosh.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acosh .visible .func (.param .f64 %value_out) __ieee754_acosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r22; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r42; .reg .f64 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .f64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .pred %r56; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r73; .reg .f64 %r74; mov.f64 %r43,%ar0; .loc 1 51 0 mov.b64 %r44,%r43; shr.u64 %r45,%r44,32; cvt.u32.u64 %r36,%r45; .loc 1 52 0 setp.gt.s32 %r46,%r36,1072693247; @ %r46 bra $L2; .loc 1 53 0 sub.f64 %r22,%r43,%r43; div.rn.f64 %r42,%r22,%r22; bra $L1; $L2: .loc 1 54 0 setp.le.s32 %r47,%r36,1102053375; @ %r47 bra $L4; .loc 1 55 0 setp.le.s32 %r48,%r36,2146435071; @ %r48 bra $L5; .loc 1 56 0 add.f64 %r42,%r43,%r43; bra $L1; $L5: .loc 1 58 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r43; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r50,[%value_in]; } add.f64 %r42,%r50,0d3fe62e42fefa39ef; bra $L1; $L4: .loc 1 59 0 add.u32 %r51,%r36,-1072693248; cvt.u32.u64 %r54,%r44; or.b32 %r53,%r51,%r54; setp.eq.u32 %r55,%r53,0; @ %r55 bra $L7; .loc 1 61 0 setp.le.s32 %r56,%r36,1073741824; @ %r56 bra $L6; .loc 1 63 0 fma.rn.f64 %r58,%r43,%r43,0dbff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r58; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r59,[%value_in]; } add.f64 %r61,%r59,%r43; mov.f64 %r63,0d3ff0000000000000; div.rn.f64 %r62,%r63,%r61; neg.f64 %r64,%r62; fma.rn.f64 %r65,%r43,0d4000000000000000,%r64; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r66,[%value_in]; } mov.f64 %r42,%r66; bra $L1; $L6: .loc 1 65 0 mov.f64 %r67,0d3ff0000000000000; sub.f64 %r37,%r43,%r67; .loc 1 66 0 mul.f64 %r69,%r37,%r37; fma.rn.f64 %r70,%r37,0d4000000000000000,%r69; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r70; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r71,[%value_in]; } add.f64 %r73,%r71,%r37; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r74,[%value_in]; } mov.f64 %r42,%r74; bra $L1; $L7: .loc 1 60 0 mov.f64 %r42,0d0000000000000000; $L1: .loc 1 68 0 mov.f64 %value,%r42; st.param.f64 [%value_out],%value; ret; } lib_a-e_asin.o/ 0 0 0 644 5204 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_asin .visible .func (.param .f64 %value_out) __ieee754_asin (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_asin.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_asin .visible .func (.param .f64 %value_out) __ieee754_asin (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r26; .reg .f64 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .f64 %r54; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r63; .reg .f64 %r65; .reg .u64 %r84; .reg .f64 %r85; .reg .f64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .pred %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r93; .reg .pred %r94; .reg .f64 %r95; .reg .pred %r96; .reg .pred %r97; .reg .f64 %r98; .reg .pred %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r124; .reg .pred %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .u64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r135; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r141; .reg .f64 %r142; .reg .pred %r143; mov.f64 %r86,%ar0; .loc 1 80 0 mov.b64 %r87,%r86; shr.u64 %r88,%r87,32; cvt.u32.u64 %r52,%r88; .loc 1 81 0 and.b32 %r53,%r52,2147483647; .loc 1 82 0 setp.le.s32 %r89,%r53,1072693247; @ %r89 bra $L2; .loc 1 85 0 add.u32 %r90,%r53,-1072693248; cvt.u32.u64 %r93,%r87; or.b32 %r92,%r90,%r93; setp.ne.u32 %r94,%r92,0; @ %r94 bra $L3; .loc 1 87 0 mul.f64 %r95,%r86,0d3c91a62633145c07; fma.rn.f64 %r85,%r86,0d3ff921fb54442d18,%r95; bra $L1; $L3: .loc 1 88 0 sub.f64 %r26,%r86,%r86; div.rn.f64 %r85,%r26,%r26; bra $L1; $L2: .loc 1 89 0 setp.gt.s32 %r96,%r53,1071644671; @ %r96 bra $L5; .loc 1 90 0 setp.gt.s32 %r97,%r53,1044381695; @ %r97 bra $L6; .loc 1 91 0 add.f64 %r98,%r86,0d7e37e43c8800759c; setp.gt.f64 %r99,%r98,0d3ff0000000000000; @ %r99 bra $L9; bra $L5; $L6: .loc 1 93 0 mul.f64 %r54,%r86,%r86; .loc 1 94 0 fma.rn.f64 %r100,%r54,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r101,%r100,%r54,0dbfa48228b5688f3b; fma.rn.f64 %r102,%r101,%r54,0d3fc9c1550e884455; fma.rn.f64 %r103,%r102,%r54,0dbfd4d61203eb6f7d; fma.rn.f64 %r104,%r103,%r54,0d3fc5555555555555; mul.f64 %r105,%r104,%r54; .loc 1 95 0 fma.rn.f64 %r106,%r54,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r107,%r106,%r54,0d40002ae59c598ac8; fma.rn.f64 %r108,%r107,%r54,0dc0033a271c8a2d4b; fma.rn.f64 %r109,%r108,%r54,0d3ff0000000000000; .loc 1 96 0 div.rn.f64 %r110,%r105,%r109; .loc 1 97 0 fma.rn.f64 %r85,%r86,%r110,%r86; bra $L1; $L5: .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r112,[%value_in]; } mov.f64 %r114,0d3ff0000000000000; sub.f64 %r113,%r114,%r112; .loc 1 102 0 mul.f64 %r59,%r113,0d3fe0000000000000; .loc 1 103 0 fma.rn.f64 %r115,%r59,0d3f023de10dfdf709,0d3f49efe07501b288; fma.rn.f64 %r116,%r115,%r59,0dbfa48228b5688f3b; fma.rn.f64 %r117,%r116,%r59,0d3fc9c1550e884455; fma.rn.f64 %r118,%r117,%r59,0dbfd4d61203eb6f7d; fma.rn.f64 %r119,%r118,%r59,0d3fc5555555555555; mul.f64 %r60,%r119,%r59; .loc 1 104 0 fma.rn.f64 %r120,%r59,0d3fb3b8c5b12e9282,0dbfe6066c1b8d0159; fma.rn.f64 %r121,%r120,%r59,0d40002ae59c598ac8; fma.rn.f64 %r122,%r121,%r59,0dc0033a271c8a2d4b; fma.rn.f64 %r61,%r122,%r59,0d3ff0000000000000; .loc 1 105 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r124,[%value_in]; } .loc 1 106 0 setp.le.s32 %r125,%r53,1072640818; @ %r125 bra $L7; .loc 1 107 0 div.rn.f64 %r126,%r60,%r61; .loc 1 108 0 fma.rn.f64 %r127,%r124,%r126,%r124; fma.rn.f64 %r128,%r127,0d4000000000000000,0dbc91a62633145c07; mov.f64 %r129,0d3ff921fb54442d18; sub.f64 %r85,%r129,%r128; bra $L8; $L7: .loc 1 111 0 mov.b64 %r84,%r124; and.b64 %r130,%r84,-4294967296; mov.b64 %r63,%r130; .loc 1 113 0 div.rn.f64 %r65,%r60,%r61; .loc 1 114 0 add.f64 %r131,%r124,%r124; .loc 1 112 0 neg.f64 %r132,%r63; fma.rn.f64 %r133,%r132,%r63,%r59; add.f64 %r134,%r124,%r63; div.rn.f64 %r135,%r133,%r134; .loc 1 114 0 fma.rn.f64 %r137,%r135,0dc000000000000000,0d3c91a62633145c07; neg.f64 %r138,%r137; fma.rn.f64 %r139,%r131,%r65,%r138; .loc 1 115 0 fma.rn.f64 %r141,%r132,0d4000000000000000,0d3fe921fb54442d18; .loc 1 116 0 sub.f64 %r51,%r139,%r141; mov.f64 %r142,0d3fe921fb54442d18; sub.f64 %r85,%r142,%r51; $L8: .loc 1 118 0 setp.gt.s32 %r143,%r52,0; @ %r143 bra $L1; neg.f64 %r85,%r85; bra $L1; $L9: .loc 1 91 0 mov.f64 %r85,%r86; $L1: .loc 1 119 0 mov.f64 %value,%r85; st.param.f64 [%value_out],%value; ret; } lib_a-e_atan2.o/0 0 0 644 6209 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2 .visible .func (.param .f64 %value_out) __ieee754_atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_atan2.c" // BEGIN GLOBAL FUNCTION DECL: atan .extern .func (.param .f64 %value_out) atan (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atan2 .visible .func (.param .f64 %value_out) __ieee754_atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .f64 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .pred %r90; .reg .pred %r91; .reg .pred %r92; .reg .u32 %r93; .reg .pred %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .u32 %r106; .reg .pred %r107; .reg .u32 %r109; .reg .u32 %r111; .reg .u32 %r112; .reg .u16 %r114; .reg .u16 %r115; .reg .u16 %r116; .reg .u32 %r117; .reg .u16 %r118; .reg .pred %r119; .reg .f64 %r121; .reg .f64 %r122; .reg .f64 %r124; .reg .pred %r125; .reg .pred %r126; .reg .pred %r127; .reg .u64 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .f64 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; mov.f64 %r63,%ar0; mov.f64 %r64,%ar1; .loc 1 69 0 mov.b64 %r65,%r64; shr.u64 %r66,%r65,32; cvt.u32.u64 %r50,%r66; cvt.u32.u64 %r56,%r65; .loc 1 70 0 and.b32 %r51,%r50,2147483647; .loc 1 73 0 neg.s32 %r68,%r56; or.b32 %r69,%r68,%r56; shr.u32 %r70,%r69,31; or.b32 %r71,%r70,%r51; setp.gt.u32 %r72,%r71,2146435072; @ %r72 bra $L2; mov.b64 %r73,%r63; shr.u64 %r74,%r73,32; cvt.u32.u64 %r57,%r74; cvt.u32.u64 %r58,%r73; .loc 1 72 0 and.b32 %r53,%r57,2147483647; .loc 1 74 0 neg.s32 %r76,%r58; or.b32 %r77,%r76,%r58; shr.u32 %r78,%r77,31; or.b32 %r79,%r78,%r53; .loc 1 73 0 setp.le.u32 %r80,%r79,2146435072; @ %r80 bra $L3; $L2: .loc 1 75 0 add.f64 %r62,%r64,%r63; bra $L1; $L3: .loc 1 76 0 add.u32 %r81,%r50,-1072693248; or.b32 %r82,%r81,%r56; setp.ne.u32 %r83,%r82,0; @ %r83 bra $L5; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r63; call (%value_in),atan,(%out_arg1); ld.param.f64 %r85,[%value_in]; } mov.f64 %r62,%r85; bra $L1; $L5: .loc 1 77 0 shr.s32 %r86,%r50,30; and.b32 %r87,%r86,2; shr.u32 %r88,%r57,31; or.b32 %r54,%r87,%r88; .loc 1 80 0 or.b32 %r89,%r53,%r58; setp.ne.u32 %r90,%r89,0; @ %r90 bra $L6; .loc 1 81 0 setp.eq.u32 %r91,%r54,2; @ %r91 bra $L23; setp.eq.u32 %r92,%r54,3; .loc 1 83 0 selp.f64 %r62,0dc00921fb54442d18,%r63,%r92; bra $L1; $L6: .loc 1 89 0 or.b32 %r93,%r51,%r56; setp.ne.u32 %r94,%r93,0; @ %r94 bra $L9; setp.ge.s32 %r95,%r57,0; selp.f64 %r62,0d3ff921fb54442d18,0dbff921fb54442d18,%r95; bra $L1; $L9: .loc 1 92 0 setp.ne.u32 %r96,%r51,2146435072; @ %r96 bra $L10; .loc 1 93 0 setp.ne.u32 %r97,%r53,2146435072; @ %r97 bra $L11; .loc 1 94 0 setp.eq.u32 %r98,%r54,2; @ %r98 bra $L12; setp.eq.u32 %r99,%r54,3; @ %r99 bra $L13; setp.eq.u32 %r100,%r54,1; .loc 1 95 0 selp.f64 %r62,0dbfe921fb54442d18,0d3fe921fb54442d18,%r100; bra $L1; $L12: .loc 1 97 0 mov.f64 %r62,0d4002d97c7f3321d2; bra $L1; $L13: .loc 1 98 0 mov.f64 %r62,0dc002d97c7f3321d2; bra $L1; $L11: .loc 1 101 0 setp.eq.u32 %r101,%r54,2; @ %r101 bra $L26; setp.eq.u32 %r102,%r54,3; @ %r102 bra $L16; setp.eq.u32 %r103,%r54,1; .loc 1 102 0 selp.f64 %r62,0d8000000000000000,0d0000000000000000,%r103; bra $L1; $L16: .loc 1 85 0 mov.f64 %r62,0dc00921fb54442d18; bra $L1; $L10: .loc 1 110 0 setp.ne.u32 %r104,%r53,2146435072; @ %r104 bra $L18; setp.ge.s32 %r105,%r57,0; .loc 1 89 0 selp.f64 %r62,0d3ff921fb54442d18,0dbff921fb54442d18,%r105; bra $L1; $L18: .loc 1 113 0 sub.u32 %r106,%r53,%r51; shr.s32 %r60,%r106,20; .loc 1 114 0 setp.gt.s32 %r107,%r60,60; @ %r107 bra $L28; .loc 1 115 0 shr.u32 %r109,%r50,31; set.u32.lt.s32 %r111,%r60,-60; neg.s32 %r112,%r111; cvt.u16.u32 %r115,%r109; cvt.u16.u32 %r116,%r112; and.b16 %r114,%r115,%r116; cvt.u32.u16 %r117,%r114; cvt.u16.u8 %r118,%r117; setp.ne.u16 %r119,%r118,0; @ %r119 bra $L29; .loc 1 116 0 div.rn.f64 %r121,%r63,%r64; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r121; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r122,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r122; call (%value_in),atan,(%out_arg1); ld.param.f64 %r124,[%value_in]; } mov.f64 %r62,%r124; bra $L19; $L28: .loc 1 114 0 mov.f64 %r62,0d3ff921fb54442d18; bra $L19; $L29: .loc 1 115 0 mov.f64 %r62,0d0000000000000000; $L19: .loc 1 117 0 setp.eq.u32 %r125,%r54,1; @ %r125 bra $L21; setp.eq.u32 %r126,%r54,2; @ %r126 bra $L22; setp.eq.u32 %r127,%r54,0; @ ! %r127 bra $L33; bra $L1; $L21: .loc 1 122 0 mov.b64 %r61,%r62; shr.u64 %r129,%r61,32; cvt.u32.u64 %r131,%r129; add.u32 %r130,%r131,-2147483648; cvt.u64.u32 %r132,%r130; shl.b64 %r133,%r132,32; and.b64 %r134,%r61,4294967295; or.b64 %r135,%r134,%r133; mov.b64 %r62,%r135; .loc 1 124 0 bra $L1; $L22: .loc 1 125 0 mov.f64 %r137,0d3ca1a62633145c07; sub.f64 %r136,%r62,%r137; mov.f64 %r138,0d400921fb54442d18; sub.f64 %r62,%r138,%r136; bra $L1; $L33: .loc 1 127 0 mov.f64 %r140,0d3ca1a62633145c07; sub.f64 %r139,%r62,%r140; mov.f64 %r141,0d400921fb54442d18; sub.f64 %r62,%r139,%r141; bra $L1; $L23: .loc 1 84 0 mov.f64 %r62,0d400921fb54442d18; bra $L1; $L26: mov.f64 %r62,0d400921fb54442d18; $L1: .loc 1 129 0 mov.f64 %value,%r62; st.param.f64 [%value_out],%value; ret; } lib_a-e_atanh.o/0 0 0 644 3125 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanh .visible .func (.param .f64 %value_out) __ieee754_atanh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_atanh.c" // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atanh .visible .func (.param .f64 %value_out) __ieee754_atanh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r27; .reg .u32 %r38; .reg .u32 %r39; .reg .f64 %r40; .reg .f64 %r41; .reg .u32 %r43; .reg .f64 %r45; .reg .f64 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .pred %r77; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r81; .reg .u64 %r82; mov.f64 %r46,%ar0; .loc 1 59 0 mov.b64 %r47,%r46; shr.u64 %r48,%r47,32; cvt.u32.u64 %r38,%r48; cvt.u32.u64 %r43,%r47; .loc 1 60 0 and.b32 %r39,%r38,2147483647; .loc 1 61 0 neg.s32 %r50,%r43; or.b32 %r51,%r50,%r43; shr.u32 %r52,%r51,31; or.b32 %r53,%r52,%r39; setp.le.u32 %r54,%r53,1072693248; @ %r54 bra $L2; .loc 1 62 0 sub.f64 %r27,%r46,%r46; div.rn.f64 %r45,%r27,%r27; bra $L1; $L2: .loc 1 63 0 setp.ne.u32 %r55,%r39,1072693248; @ %r55 bra $L4; .loc 1 64 0 div.rn.f64 %r45,%r46,0d0000000000000000; bra $L1; $L4: .loc 1 65 0 setp.gt.s32 %r56,%r39,1043333119; @ %r56 bra $L5; add.f64 %r57,%r46,0d7e37e43c8800759c; setp.gt.f64 %r58,%r57,0d0000000000000000; @ %r58 bra $L10; bra $L11; $L5: .loc 1 66 0 cvt.u64.u32 %r59,%r39; shl.b64 %r60,%r59,32; and.b64 %r61,%r47,4294967295; or.b64 %r62,%r61,%r60; mov.b64 %r40,%r62; .loc 1 67 0 setp.gt.s32 %r63,%r39,1071644671; @ %r63 bra $L7; $L9: .loc 1 68 0 add.f64 %r41,%r40,%r40; .loc 1 69 0 mul.f64 %r65,%r41,%r40; mov.f64 %r67,0d3ff0000000000000; sub.f64 %r66,%r67,%r40; div.rn.f64 %r68,%r65,%r66; add.f64 %r69,%r68,%r41; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r69; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r70,[%value_in]; } mul.f64 %r45,%r70,0d3fe0000000000000; bra $L8; $L7: .loc 1 71 0 add.f64 %r72,%r40,%r40; mov.f64 %r74,0d3ff0000000000000; sub.f64 %r73,%r74,%r40; div.rn.f64 %r75,%r72,%r73; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r75; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r76,[%value_in]; } mul.f64 %r45,%r76,0d3fe0000000000000; $L8: .loc 1 72 0 setp.ge.s32 %r77,%r38,0; @ %r77 bra $L1; neg.f64 %r45,%r45; bra $L1; $L10: .loc 1 65 0 mov.f64 %r45,%r46; bra $L1; $L11: .loc 1 66 0 cvt.u64.u32 %r79,%r39; shl.b64 %r80,%r79,32; and.b64 %r81,%r47,4294967295; or.b64 %r82,%r81,%r80; mov.b64 %r40,%r82; bra $L9; $L1: .loc 1 73 0 mov.f64 %value,%r45; st.param.f64 [%value_out],%value; ret; } lib_a-e_cosh.o/ 0 0 0 644 4184 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_cosh .visible .func (.param .f64 %value_out) __ieee754_cosh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_cosh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_cosh .visible .func (.param .f64 %value_out) __ieee754_cosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r43; .reg .f64 %r44; .reg .u64 %r45; .reg .u64 %r46; .reg .pred %r47; .reg .pred %r48; .reg .f64 %r50; .reg .f64 %r52; .reg .pred %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .pred %r57; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .pred %r64; .reg .f64 %r66; .reg .f64 %r68; .reg .pred %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .u16 %r78; .reg .u16 %r79; .reg .u16 %r80; .reg .u32 %r81; .reg .u16 %r82; .reg .pred %r83; .reg .f64 %r85; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r90; mov.f64 %r44,%ar0; .loc 1 57 0 mov.b64 %r45,%r44; shr.u64 %r46,%r45,32; cvt.u32.u64 %r35,%r46; .loc 1 58 0 and.b32 %r36,%r35,2147483647; .loc 1 61 0 setp.le.s32 %r47,%r36,2146435071; @ %r47 bra $L2; mul.f64 %r43,%r44,%r44; bra $L1; $L2: .loc 1 64 0 setp.gt.s32 %r48,%r36,1071001154; @ %r48 bra $L4; .loc 1 65 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r50,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r50; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r52,[%value_in]; } .loc 1 66 0 add.f64 %r43,%r52,0d3ff0000000000000; .loc 1 67 0 setp.le.s32 %r53,%r36,1015021567; @ %r53 bra $L1; .loc 1 68 0 mul.f64 %r54,%r52,%r52; add.f64 %r55,%r43,%r43; div.rn.f64 %r56,%r54,%r55; add.f64 %r43,%r56,0d3ff0000000000000; bra $L1; $L4: .loc 1 72 0 setp.gt.s32 %r57,%r36,1077280767; @ %r57 bra $L5; .loc 1 73 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r59,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r61,[%value_in]; } .loc 1 74 0 mov.f64 %r63,0d3fe0000000000000; div.rn.f64 %r62,%r63,%r61; fma.rn.f64 %r43,%r61,0d3fe0000000000000,%r62; bra $L1; $L5: .loc 1 78 0 setp.gt.s32 %r64,%r36,1082535489; @ %r64 bra $L6; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r66,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r68,[%value_in]; } mul.f64 %r43,%r68,0d3fe0000000000000; bra $L1; $L6: .loc 1 82 0 setp.le.s32 %r69,%r36,1082536909; @ %r69 bra $L7; .loc 1 83 0 set.u32.eq.u32 %r71,%r36,1082536910; neg.s32 %r72,%r71; cvt.u32.u64 %r75,%r45; set.u32.le.u32 %r76,%r75,-1883637635; neg.s32 %r77,%r76; cvt.u16.u32 %r79,%r72; cvt.u16.u32 %r80,%r77; and.b16 %r78,%r79,%r80; .loc 1 82 0 cvt.u32.u16 %r81,%r78; cvt.u16.u8 %r82,%r81; setp.eq.u16 %r83,%r82,0; @ %r83 bra $L8; $L7: .loc 1 84 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r85,[%value_in]; } mul.f64 %r87,%r85,0d3fe0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r87; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r88,[%value_in]; } .loc 1 85 0 mul.f64 %r89,%r88,0d3fe0000000000000; .loc 1 86 0 mul.f64 %r43,%r89,%r88; bra $L1; $L8: .loc 1 90 0 mov.f64 %r90,0d7e37e43c8800759c; mul.f64 %r43,%r90,0d7e37e43c8800759c; $L1: .loc 1 91 0 mov.f64 %value,%r43; st.param.f64 [%value_out],%value; ret; } lib_a-e_exp.o/ 0 0 0 644 5569 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .visible .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_exp.c" // BEGIN VAR DEF: ln2LO .const .align 8 .u64 ln2LO[2] = {4461442080421002358,-4761929956433773450 }; // BEGIN VAR DEF: halF .const .align 8 .u64 halF[2] = {4602678819172646912,-4620693217682128896 }; // BEGIN VAR DEF: ln2HI .const .align 8 .u64 ln2HI[2] = {4604418534311723008,-4618953502543052800 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_exp .visible .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .u32 %r53; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r64; .reg .u32 %r65; .reg .f64 %r68; .reg .f64 %r69; .reg .u64 %r70; .reg .u64 %r71; .reg .pred %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .f64 %r81; .reg .pred %r82; .reg .pred %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .f64 %r89; .reg .u64 %r90; .reg .u64 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .pred %r103; .reg .f64 %r104; .reg .pred %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .pred %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .pred %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .u32 %r133; .reg .u32 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; mov.f64 %r69,%ar0; mov.b64 %r70,%r69; shr.u64 %r71,%r70,32; cvt.u32.u64 %r53,%r71; .loc 1 116 0 shr.u32 %r22,%r53,31; .loc 1 117 0 and.b32 %r52,%r53,2147483647; .loc 1 120 0 setp.le.u32 %r72,%r52,1082535489; @ %r72 bra $L2; .loc 1 121 0 setp.le.u32 %r73,%r52,2146435071; @ %r73 bra $L3; .loc 1 124 0 and.b32 %r74,%r53,1048575; cvt.u32.u64 %r77,%r70; or.b32 %r76,%r74,%r77; setp.eq.u32 %r78,%r76,0; @ %r78 bra $L4; .loc 1 125 0 add.f64 %r68,%r69,%r69; bra $L1; $L4: .loc 1 126 0 setp.ne.u32 %r79,%r22,0; selp.f64 %r68,0d0000000000000000,%r69,%r79; bra $L1; $L3: .loc 1 128 0 setp.gt.f64 %r80,%r69,0d40862e42fefa39ef; @ ! %r80 bra $L22; mov.f64 %r81,0d7e37e43c8800759c; mul.f64 %r68,%r81,0d7e37e43c8800759c; bra $L1; $L22: .loc 1 129 0 setp.lt.f64 %r82,%r69,0dc0874910d52d3051; @ ! %r82 bra $L10; bra $L17; $L2: .loc 1 133 0 setp.le.u32 %r83,%r52,1071001154; @ %r83 bra $L9; .loc 1 134 0 setp.gt.u32 %r84,%r52,1072734897; @ %r84 bra $L10; .loc 1 135 0 cvta.const.u64 %r85,ln2HI; cvt.s64.s32 %r86,%r22; shl.b64 %r87,%r86,3; add.u64 %r88,%r85,%r87; ld.f64 %r89,[%r88]; sub.f64 %r48,%r69,%r89; cvta.const.u64 %r90,ln2LO; add.u64 %r93,%r90,%r87; ld.f64 %r49,[%r93]; mov.u32 %r95,1; sub.u32 %r94,%r95,%r22; sub.u32 %r50,%r94,%r22; bra $L11; $L10: .loc 1 137 0 cvta.const.u64 %r96,halF; cvt.s64.s32 %r97,%r22; shl.b64 %r98,%r97,3; add.u64 %r99,%r96,%r98; ld.f64 %r101,[%r99]; fma.rn.f64 %r100,%r69,0d3ff71547652b82fe,%r101; cvt.rzi.s32.f64 %r50,%r100; .loc 1 138 0 cvt.rn.f64.s32 %r55,%r50; .loc 1 139 0 fma.rn.f64 %r48,%r55,0dbfe62e42fee00000,%r69; .loc 1 140 0 mul.f64 %r49,%r55,0d3dea39ef35793c76; $L11: .loc 1 142 0 sub.f64 %r69,%r48,%r49; bra $L12; $L9: .loc 1 144 0 setp.gt.u32 %r103,%r52,1043333119; @ %r103 bra $L18; .loc 1 145 0 add.f64 %r104,%r69,0d7e37e43c8800759c; setp.gt.f64 %r105,%r104,0d3ff0000000000000; @ ! %r105 bra $L23; add.f64 %r68,%r69,0d3ff0000000000000; bra $L1; $L18: .loc 1 112 0 mov.u32 %r50,0; bra $L12; $L23: mov.u32 %r50,0; $L12: .loc 1 149 0 mul.f64 %r56,%r69,%r69; .loc 1 150 0 fma.rn.f64 %r106,%r56,0d3e66376972bea4d0,0dbebbbd41c5d26bf1; fma.rn.f64 %r107,%r106,%r56,0d3f11566aaf25de2c; fma.rn.f64 %r108,%r107,%r56,0dbf66c16c16bebd93; fma.rn.f64 %r109,%r108,%r56,0d3fc555555555553e; neg.f64 %r110,%r109; fma.rn.f64 %r57,%r110,%r56,%r69; mul.f64 %r64,%r69,%r57; .loc 1 151 0 setp.ne.u32 %r111,%r50,0; @ %r111 bra $L14; mov.f64 %r113,0d4000000000000000; sub.f64 %r112,%r57,%r113; div.rn.f64 %r114,%r64,%r112; sub.f64 %r115,%r114,%r69; mov.f64 %r116,0d3ff0000000000000; sub.f64 %r68,%r116,%r115; bra $L1; $L14: .loc 1 152 0 mov.f64 %r118,0d4000000000000000; sub.f64 %r117,%r118,%r57; div.rn.f64 %r119,%r64,%r117; sub.f64 %r120,%r49,%r119; sub.f64 %r121,%r120,%r48; mov.f64 %r122,0d3ff0000000000000; sub.f64 %r58,%r122,%r121; mov.b64 %r123,%r58; shr.u64 %r124,%r123,32; cvt.u32.u64 %r65,%r124; .loc 1 153 0 setp.lt.s32 %r125,%r50,-1021; @ %r125 bra $L15; .loc 1 156 0 shl.b32 %r126,%r50,20; add.u32 %r127,%r126,%r65; cvt.u64.u32 %r128,%r127; shl.b64 %r129,%r128,32; and.b64 %r130,%r123,4294967295; or.b64 %r131,%r130,%r129; mov.b64 %r68,%r131; .loc 1 157 0 bra $L1; $L15: .loc 1 161 0 add.u32 %r132,%r50,1000; shl.b32 %r133,%r132,20; add.u32 %r134,%r133,%r65; cvt.u64.u32 %r135,%r134; shl.b64 %r136,%r135,32; and.b64 %r137,%r123,4294967295; or.b64 %r138,%r137,%r136; mov.b64 %r59,%r138; .loc 1 162 0 mul.f64 %r68,%r59,0d0170000000000000; bra $L1; $L17: .loc 1 126 0 mov.f64 %r68,0d0000000000000000; $L1: .loc 1 164 0 mov.f64 %value,%r68; st.param.f64 [%value_out],%value; ret; } lib_a-e_fmod.o/ 0 0 0 644 9873 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmod .visible .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_fmod.c" // BEGIN VAR DEF: Zero .const .align 8 .u64 Zero[2] = {0,-9223372036854775808 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_fmod .visible .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r45; .reg .u32 %r53; .reg .u32 %r61; .reg .u32 %r94; .reg .u32 %r101; .reg .u32 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r129; .reg .u32 %r131; .reg .u32 %r132; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r142; .reg .u64 %r143; .reg .u32 %r145; .reg .u32 %r147; .reg .u32 %r148; .reg .u32 %r150; .reg .u32 %r151; .reg .u16 %r152; .reg .u16 %r153; .reg .u16 %r154; .reg .u32 %r155; .reg .u16 %r156; .reg .pred %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .pred %r162; .reg .pred %r164; .reg .u32 %r166; .reg .u32 %r167; .reg .u32 %r169; .reg .u32 %r170; .reg .u16 %r171; .reg .u16 %r172; .reg .u16 %r173; .reg .u32 %r174; .reg .u16 %r175; .reg .pred %r176; .reg .pred %r177; .reg .u64 %r178; .reg .u32 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .pred %r183; .reg .pred %r184; .reg .pred %r185; .reg .pred %r187; .reg .pred %r189; .reg .u32 %r190; .reg .pred %r191; .reg .pred %r192; .reg .pred %r193; .reg .pred %r195; .reg .pred %r197; .reg .u32 %r198; .reg .pred %r199; .reg .u32 %r200; .reg .pred %r201; .reg .u32 %r202; .reg .u32 %r203; .reg .u32 %r204; .reg .u32 %r205; .reg .u32 %r206; .reg .u32 %r208; .reg .pred %r209; .reg .u32 %r210; .reg .u32 %r211; .reg .u32 %r212; .reg .u32 %r213; .reg .u32 %r214; .reg .pred %r215; .reg .pred %r216; .reg .u32 %r217; .reg .u32 %r218; .reg .u32 %r220; .reg .pred %r221; .reg .u64 %r222; .reg .u32 %r223; .reg .u64 %r224; .reg .u64 %r225; .reg .u64 %r226; .reg .u32 %r227; .reg .u32 %r228; .reg .pred %r230; .reg .pred %r231; .reg .pred %r232; .reg .u32 %r233; .reg .pred %r234; .reg .pred %r235; .reg .u64 %r236; .reg .u32 %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u32 %r241; .reg .u32 %r242; .reg .pred %r244; .reg .u32 %r246; .reg .u32 %r247; .reg .u32 %r248; .reg .u32 %r249; .reg .u32 %r250; .reg .u64 %r251; .reg .u64 %r255; .reg .u64 %r256; .reg .u64 %r257; .reg .u32 %r258; .reg .pred %r259; .reg .u32 %r260; .reg .u32 %r261; .reg .u32 %r262; .reg .pred %r263; .reg .u32 %r264; .reg .u32 %r265; .reg .u32 %r266; .reg .u32 %r267; .reg .u64 %r268; .reg .u64 %r272; .reg .u64 %r273; .reg .u64 %r274; .reg .pred %r276; mov.f64 %r138,%ar0; mov.f64 %r139,%ar1; .loc 1 40 0 mov.b64 %r140,%r138; shr.u64 %r141,%r140,32; cvt.u32.u64 %r114,%r141; .loc 1 41 0 mov.b64 %r142,%r139; shr.u64 %r143,%r142,32; cvt.u32.u64 %r115,%r143; cvt.u32.u64 %r113,%r142; .loc 1 43 0 and.b32 %r117,%r114,2147483647; .loc 1 44 0 and.b32 %r118,%r115,2147483647; .loc 1 47 0 or.b32 %r145,%r118,%r113; set.u32.eq.u32 %r147,%r145,0; neg.s32 %r148,%r147; set.u32.gt.s32 %r150,%r117,2146435071; neg.s32 %r151,%r150; cvt.u16.u32 %r153,%r148; cvt.u16.u32 %r154,%r151; or.b16 %r152,%r153,%r154; cvt.u32.u16 %r155,%r152; cvt.u16.u8 %r156,%r155; setp.ne.u16 %r157,%r156,0; @ %r157 bra $L2; .loc 1 48 0 neg.s32 %r158,%r113; or.b32 %r159,%r158,%r113; shr.u32 %r160,%r159,31; or.b32 %r161,%r160,%r118; .loc 1 47 0 setp.le.u32 %r162,%r161,2146435072; @ %r162 bra $L3; $L2: .loc 1 49 0 mul.f64 %r45,%r138,%r139; div.rn.f64 %r137,%r45,%r45; bra $L1; $L3: cvt.u32.u64 %r110,%r140; .loc 1 42 0 and.b32 %r116,%r114,-2147483648; .loc 1 50 0 setp.gt.s32 %r164,%r117,%r118; @ %r164 bra $L5; .loc 1 51 0 set.u32.lt.s32 %r166,%r117,%r118; neg.s32 %r167,%r166; set.u32.lt.u32 %r169,%r110,%r113; neg.s32 %r170,%r169; cvt.u16.u32 %r172,%r167; cvt.u16.u32 %r173,%r170; or.b16 %r171,%r172,%r173; cvt.u32.u16 %r174,%r171; cvt.u16.u8 %r175,%r174; setp.ne.u16 %r176,%r175,0; @ %r176 bra $L37; .loc 1 52 0 setp.ne.u32 %r177,%r110,%r113; @ %r177 bra $L5; .loc 1 53 0 cvta.const.u64 %r178,Zero; shr.u32 %r179,%r116,31; cvt.u64.u32 %r180,%r179; shl.b64 %r181,%r180,3; add.u64 %r182,%r178,%r181; ld.f64 %r137,[%r182]; bra $L1; $L5: .loc 1 57 0 setp.gt.s32 %r183,%r117,1048575; @ %r183 bra $L6; .loc 1 58 0 setp.ne.u32 %r184,%r117,0; @ %r184 bra $L7; .loc 1 59 0 mov.u32 %r121,%r110; setp.le.s32 %r185,%r110,0; @ %r185 bra $L38; mov.u32 %r119,-1043; $L9: add.u32 %r119,%r119,-1; add.u32 %r121,%r121,%r121; setp.gt.s32 %r187,%r121,0; @ %r187 bra $L9; bra $L8; $L7: .loc 1 61 0 shl.b32 %r120,%r117,11; mov.u32 %r119,-1022; $L10: add.u32 %r119,%r119,-1; add.u32 %r120,%r120,%r120; setp.gt.s32 %r189,%r120,0; @ %r189 bra $L10; bra $L8; $L6: .loc 1 63 0 shr.s32 %r190,%r117,20; add.u32 %r119,%r190,-1023; bra $L8; $L38: .loc 1 59 0 mov.u32 %r119,-1043; $L8: .loc 1 66 0 setp.gt.s32 %r191,%r118,1048575; @ %r191 bra $L11; .loc 1 67 0 setp.ne.u32 %r192,%r118,0; @ %r192 bra $L12; .loc 1 68 0 mov.u32 %r124,%r113; setp.le.s32 %r193,%r113,0; @ %r193 bra $L39; mov.u32 %r131,-1043; $L14: add.u32 %r131,%r131,-1; add.u32 %r124,%r124,%r124; setp.gt.s32 %r195,%r124,0; @ %r195 bra $L14; bra $L13; $L12: .loc 1 70 0 shl.b32 %r122,%r118,11; mov.u32 %r131,-1022; $L15: add.u32 %r131,%r131,-1; add.u32 %r122,%r122,%r122; setp.gt.s32 %r197,%r122,0; @ %r197 bra $L15; bra $L13; $L11: .loc 1 72 0 shr.s32 %r198,%r118,20; add.u32 %r131,%r198,-1023; bra $L13; $L39: .loc 1 68 0 mov.u32 %r131,-1043; $L13: .loc 1 75 0 setp.lt.s32 %r199,%r119,-1022; @ %r199 bra $L16; .loc 1 76 0 and.b32 %r53,%r114,1048575; or.b32 %r105,%r53,1048576; bra $L17; $L16: .loc 1 78 0 mov.u32 %r200,-1022; sub.u32 %r125,%r200,%r119; .loc 1 79 0 setp.gt.s32 %r201,%r125,31; @ %r201 bra $L18; .loc 1 80 0 add.u32 %r202,%r119,1054; shr.u32 %r203,%r110,%r202; shl.b32 %r204,%r117,%r125; or.b32 %r105,%r203,%r204; .loc 1 81 0 shl.b32 %r110,%r110,%r125; bra $L17; $L18: .loc 1 83 0 mov.u32 %r206,-1054; sub.u32 %r205,%r206,%r119; shl.b32 %r105,%r110,%r205; .loc 1 84 0 mov.u32 %r110,0; $L17: .loc 1 87 0 setp.lt.s32 %r276,%r131,-1022; @ %r276 bra $L19; .loc 1 88 0 and.b32 %r61,%r115,1048575; or.b32 %r106,%r61,1048576; bra $L20; $L19: .loc 1 90 0 mov.u32 %r208,-1022; sub.u32 %r126,%r208,%r131; .loc 1 91 0 setp.gt.s32 %r209,%r126,31; @ %r209 bra $L21; .loc 1 92 0 add.u32 %r210,%r131,1054; shr.u32 %r211,%r113,%r210; shl.b32 %r212,%r118,%r126; or.b32 %r106,%r211,%r212; .loc 1 93 0 shl.b32 %r113,%r113,%r126; bra $L20; $L21: .loc 1 95 0 mov.u32 %r214,-1054; sub.u32 %r213,%r214,%r131; shl.b32 %r106,%r113,%r213; .loc 1 96 0 mov.u32 %r113,0; $L20: .loc 1 101 0 sub.u32 %r132,%r119,%r131; .loc 1 102 0 bra $L22; $L27: .loc 1 103 0 setp.ge.u32 %r215,%r110,%r113; @ %r215 bra $L23; add.u32 %r107,%r107,-1; $L23: .loc 1 104 0 setp.ge.s32 %r216,%r107,0; @ %r216 bra $L24; add.u32 %r217,%r105,%r105; shr.u32 %r218,%r110,31; add.u32 %r105,%r217,%r218; add.u32 %r110,%r110,%r110; bra $L25; $L24: .loc 1 106 0 or.b32 %r220,%r107,%r111; setp.ne.u32 %r221,%r220,0; @ %r221 bra $L26; .loc 1 107 0 cvta.const.u64 %r222,Zero; shr.u32 %r223,%r116,31; cvt.u64.u32 %r224,%r223; shl.b64 %r225,%r224,3; add.u64 %r226,%r222,%r225; ld.f64 %r137,[%r226]; bra $L1; $L26: .loc 1 108 0 add.u32 %r227,%r107,%r107; shr.u32 %r228,%r111,31; add.u32 %r105,%r227,%r228; add.u32 %r110,%r111,%r111; $L25: add.u32 %r132,%r132,-1; $L22: sub.u32 %r107,%r105,%r106; sub.u32 %r111,%r110,%r113; .loc 1 102 0 setp.ne.u32 %r230,%r132,0; @ %r230 bra $L27; .loc 1 111 0 setp.ge.u32 %r231,%r110,%r113; @ %r231 bra $L28; add.u32 %r107,%r107,-1; $L28: .loc 1 112 0 setp.ge.s32 %r232,%r107,0; selp.u32 %r111,%r111,%r110,%r232; selp.u32 %r107,%r107,%r105,%r232; .loc 1 115 0 or.b32 %r233,%r107,%r111; setp.eq.u32 %r234,%r233,0; @ %r234 bra $L30; .loc 1 117 0 setp.le.s32 %r235,%r107,1048575; @ %r235 bra $L31; bra $L32; $L30: .loc 1 116 0 cvta.const.u64 %r236,Zero; shr.u32 %r237,%r116,31; cvt.u64.u32 %r238,%r237; shl.b64 %r239,%r238,3; add.u64 %r240,%r236,%r239; ld.f64 %r137,[%r240]; bra $L1; $L31: .loc 1 118 0 add.u32 %r241,%r107,%r107; shr.u32 %r242,%r111,31; add.u32 %r107,%r241,%r242; add.u32 %r111,%r111,%r111; .loc 1 119 0 add.u32 %r131,%r131,-1; .loc 1 117 0 setp.le.s32 %r244,%r107,1048575; @ %r244 bra $L31; setp.lt.s32 %r276,%r131,-1022; $L32: .loc 1 121 0 @ %r276 bra $L33; .loc 1 122 0 add.u32 %r246,%r131,1023; shl.b32 %r247,%r246,20; add.u32 %r248,%r107,-1048576; .loc 1 123 0 or.b32 %r249,%r248,%r116; or.b32 %r250,%r247,%r249; cvt.u64.u32 %r251,%r250; cvt.u64.u32 %r255,%r111; shl.b64 %r256,%r251,32; or.b64 %r257,%r256,%r255; mov.b64 %r137,%r257; bra $L1; $L33: .loc 1 125 0 mov.u32 %r258,-1022; sub.u32 %r129,%r258,%r131; .loc 1 126 0 setp.gt.s32 %r259,%r129,20; @ %r259 bra $L34; .loc 1 127 0 shr.u32 %r94,%r111,%r129; add.u32 %r260,%r131,1054; shl.b32 %r261,%r107,%r260; or.b32 %r112,%r261,%r94; .loc 1 128 0 shr.s32 %r262,%r107,%r129; or.b32 %r116,%r116,%r262; bra $L35; $L34: .loc 1 129 0 setp.gt.s32 %r263,%r129,31; @ %r263 bra $L36; .loc 1 130 0 shr.u32 %r101,%r111,%r129; add.u32 %r264,%r131,1054; shl.b32 %r265,%r107,%r264; or.b32 %r112,%r265,%r101; bra $L35; $L36: .loc 1 132 0 mov.u32 %r267,-1054; sub.u32 %r266,%r267,%r131; shr.s32 %r112,%r107,%r266; $L35: .loc 1 134 0 cvt.u64.u32 %r268,%r116; cvt.u64.u32 %r272,%r112; shl.b64 %r273,%r268,32; or.b64 %r274,%r273,%r272; mov.b64 %r137,%r274; bra $L1; $L37: .loc 1 51 0 mov.f64 %r137,%r138; $L1: .loc 1 138 0 mov.f64 %value,%r137; st.param.f64 [%value_out],%value; ret; } lib_a-e_hypot.o/0 0 0 644 6489 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypot .visible .func (.param .f64 %value_out) __ieee754_hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_hypot.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_hypot .visible .func (.param .f64 %value_out) __ieee754_hypot (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r49; .reg .f64 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .f64 %r62; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r67; .reg .f64 %r70; .reg .f64 %r72; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r83; .reg .u64 %r84; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .u32 %r92; .reg .f64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .pred %r98; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .pred %r109; .reg .pred %r110; .reg .u32 %r111; .reg .u32 %r113; .reg .u32 %r114; .reg .pred %r115; .reg .u32 %r116; .reg .u32 %r118; .reg .u32 %r119; .reg .pred %r120; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .u32 %r133; .reg .pred %r134; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r142; .reg .pred %r143; .reg .u64 %r145; .reg .f64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .u64 %r159; .reg .u32 %r162; .reg .u64 %r163; .reg .u64 %r164; .reg .f64 %r167; .reg .f64 %r168; .reg .f64 %r169; .reg .f64 %r170; .reg .f64 %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .f64 %r174; .reg .f64 %r175; .reg .f64 %r177; .reg .pred %r178; .reg .u32 %r179; .reg .u32 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .u64 %r186; .reg .u64 %r187; mov.f64 %r90,%ar0; mov.f64 %r91,%ar1; .loc 1 60 0 mov.b64 %r94,%r90; shr.u64 %r95,%r94,32; cvt.u32.u64 %r57,%r95; .loc 1 61 0 and.b32 %r55,%r57,2147483647; .loc 1 62 0 mov.b64 %r96,%r91; shr.u64 %r97,%r96,32; cvt.u32.u64 %r58,%r97; .loc 1 63 0 and.b32 %r56,%r58,2147483647; .loc 1 64 0 setp.ge.s32 %r98,%r55,%r56; @ %r98 bra $L2; mov.u32 %r92,%r55; mov.u32 %r55,%r56; mov.u32 %r56,%r92; mov.f64 %r93,%r90; mov.f64 %r90,%r91; mov.f64 %r91,%r93; $L2: .loc 1 65 0 mov.b64 %r78,%r90; cvt.u64.u32 %r186,%r55; shl.b64 %r100,%r186,32; and.b64 %r101,%r78,4294967295; or.b64 %r102,%r101,%r100; mov.b64 %r89,%r102; .loc 1 66 0 mov.b64 %r79,%r91; cvt.u64.u32 %r187,%r56; shl.b64 %r104,%r187,32; and.b64 %r105,%r79,4294967295; or.b64 %r106,%r105,%r104; mov.b64 %r53,%r106; .loc 1 67 0 sub.u32 %r107,%r55,%r56; setp.le.s32 %r108,%r107,62914560; @ %r108 bra $L3; add.f64 %r89,%r89,%r53; bra $L1; $L3: .loc 1 69 0 setp.le.s32 %r109,%r55,1596981248; @ %r109 bra $L13; .loc 1 70 0 setp.le.s32 %r110,%r55,2146435071; @ %r110 bra $L6; .loc 1 74 0 and.b32 %r111,%r55,1048575; cvt.u32.u64 %r114,%r102; or.b32 %r113,%r111,%r114; setp.eq.u32 %r115,%r113,0; @ %r115 bra $L7; .loc 1 72 0 add.f64 %r89,%r89,%r53; $L7: .loc 1 76 0 xor.b32 %r116,%r56,2146435072; cvt.u32.u64 %r119,%r106; or.b32 %r118,%r116,%r119; setp.ne.u32 %r120,%r118,0; selp.f64 %r89,%r89,%r53,%r120; bra $L1; $L6: .loc 1 80 0 add.u32 %r55,%r55,-629145600; add.u32 %r56,%r56,-629145600; .loc 1 81 0 cvt.u64.u32 %r186,%r55; shl.b64 %r122,%r186,32; and.b64 %r123,%r102,4294967295; or.b64 %r124,%r123,%r122; mov.b64 %r89,%r124; .loc 1 82 0 cvt.u64.u32 %r187,%r56; shl.b64 %r126,%r187,32; and.b64 %r127,%r106,4294967295; or.b64 %r128,%r127,%r126; mov.b64 %r53,%r128; .loc 1 80 0 mov.u32 %r54,600; bra $L5; $L13: .loc 1 68 0 mov.u32 %r54,0; $L5: .loc 1 84 0 setp.gt.s32 %r129,%r56,548405247; @ %r129 bra $L8; .loc 1 85 0 setp.gt.s32 %r130,%r56,1048575; @ %r130 bra $L9; .loc 1 88 0 mov.b64 %r131,%r53; cvt.u32.u64 %r133,%r131; or.b32 %r132,%r56,%r133; setp.eq.u32 %r134,%r132,0; @ %r134 bra $L1; .loc 1 90 0 mov.f64 %r62,0d7fd0000000000000; .loc 1 91 0 mul.f64 %r53,%r53,%r62; .loc 1 92 0 mul.f64 %r89,%r89,%r62; .loc 1 93 0 add.u32 %r54,%r54,-1022; bra $L8; $L9: .loc 1 95 0 add.u32 %r55,%r55,629145600; .loc 1 96 0 add.u32 %r56,%r56,629145600; .loc 1 97 0 add.u32 %r54,%r54,-600; .loc 1 98 0 mov.b64 %r83,%r89; cvt.u64.u32 %r186,%r55; shl.b64 %r136,%r186,32; and.b64 %r137,%r83,4294967295; or.b64 %r138,%r137,%r136; mov.b64 %r89,%r138; .loc 1 99 0 mov.b64 %r84,%r53; cvt.u64.u32 %r187,%r56; shl.b64 %r140,%r187,32; and.b64 %r141,%r84,4294967295; or.b64 %r142,%r141,%r140; mov.b64 %r53,%r142; $L8: .loc 1 103 0 sub.f64 %r64,%r89,%r53; .loc 1 104 0 setp.lt.f64 %r143,%r53,%r64; @ ! %r143 bra $L24; .loc 1 106 0 shl.b64 %r145,%r186,32; mov.b64 %r70,%r145; .loc 1 108 0 neg.f64 %r149,%r53; add.f64 %r150,%r89,%r70; .loc 1 107 0 sub.f64 %r151,%r89,%r70; .loc 1 108 0 mul.f64 %r152,%r150,%r151; neg.f64 %r153,%r152; fma.rn.f64 %r154,%r149,%r53,%r153; neg.f64 %r155,%r154; fma.rn.f64 %r156,%r70,%r70,%r155; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r156; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r157,[%value_in]; } mov.f64 %r89,%r157; bra $L12; $L24: .loc 1 112 0 shl.b64 %r159,%r187,32; mov.b64 %r65,%r159; .loc 1 115 0 add.u32 %r162,%r55,1048576; cvt.u64.u32 %r163,%r162; shl.b64 %r164,%r163,32; mov.b64 %r67,%r164; .loc 1 117 0 neg.f64 %r167,%r64; .loc 1 113 0 sub.f64 %r168,%r53,%r65; .loc 1 116 0 neg.f64 %r169,%r67; fma.rn.f64 %r170,%r89,0d4000000000000000,%r169; .loc 1 117 0 mul.f64 %r171,%r170,%r53; fma.rn.f64 %r172,%r168,%r67,%r171; neg.f64 %r173,%r172; fma.rn.f64 %r174,%r167,%r64,%r173; neg.f64 %r175,%r174; fma.rn.f64 %r49,%r65,%r67,%r175; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r177,[%value_in]; } mov.f64 %r89,%r177; $L12: .loc 1 119 0 setp.eq.u32 %r178,%r54,0; @ %r178 bra $L1; .loc 1 123 0 shl.b32 %r179,%r54,20; add.u32 %r180,%r179,1072693248; cvt.u64.u32 %r181,%r180; shl.b64 %r182,%r181,32; mov.b64 %r72,%r182; .loc 1 124 0 mul.f64 %r89,%r89,%r72; $L1: .loc 1 126 0 mov.f64 %value,%r89; st.param.f64 [%value_out],%value; ret; } lib_a-e_j0.o/ 0 0 0 644 17027 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: pzero .func (.param .f64 %value_out) pzero (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_j0.c" // BEGIN FUNCTION DECL: qzero .func (.param .f64 %value_out) qzero (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0 .visible .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0 .visible .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN FUNCTION DEF: pzero .func (.param .f64 %value_out) pzero (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; mov.f64 %r50,%ar0; .loc 1 339 0 mov.b64 %r51,%r50; shr.u64 %r52,%r51,32; cvt.u32.u64 %r35,%r52; .loc 1 340 0 and.b32 %r36,%r35,2147483647; .loc 1 341 0 setp.gt.s32 %r53,%r36,1075838975; @ %r53 bra $L3; .loc 1 342 0 setp.gt.s32 %r54,%r36,1074933386; @ %r54 bra $L4; .loc 1 343 0 setp.gt.s32 %r55,%r36,1074191212; selp.f64 %r48,0d4065b296fc379081,0d402d50b344391809,%r55; selp.f64 %r47,0d40919ffcb8c39b7e,0d40633c033ab6faff,%r55; selp.f64 %r46,0d4092a66e6d1061d6,0d4070e78642ea079b,%r55; selp.f64 %r45,0d40769839464a7c0e,0d4061069e0ee8878f,%r55; selp.f64 %r44,0dc03f72aca892d80f,0dc009de81af8fe70f,%r55; selp.f64 %r43,0dc04d0a22420a1a45,0dc02662e6c5246303,%r55; selp.f64 %r42,0dc035f74a4cb94e14,0dc01e8af3edafa7f3,%r55; selp.f64 %r41,0dc00345b2aea48074,0dbff736398a24a843,%r55; selp.f64 %r40,0dbfb1fff6f7c0e24b,0dbfb1ff62495e1e42,%r55; selp.f64 %r28,0d4041ed9284077dd3,0d40363865908b5959,%r55; selp.f64 %r23,0dbe25e1036fe1aa86,0dbe77d316e927026d,%r55; bra $L2; $L3: mov.f64 %r48,0d40e741774f2c49dc; mov.f64 %r47,0d40fc810f8f9fa9bd; mov.f64 %r46,0d40e3d2bb6eb6b05f; mov.f64 %r45,0d40adf37d50596938; mov.f64 %r44,0dc0b4850b36cc643d; mov.f64 %r43,0dc0a36a6ecd4dcafc; mov.f64 %r42,0dc07011027b19e863; mov.f64 %r41,0dc02029d0b44fa779; mov.f64 %r40,0dbfb1fffffffffd32; .loc 1 341 0 mov.f64 %r28,0d405d223307a96751; mov.f64 %r23,0d0000000000000000; bra $L2; $L4: mov.f64 %r48,0d40a2cc1dc70be864; mov.f64 %r47,0d40c2ccb8fa76fa38; mov.f64 %r46,0d40b75af88fbe1d60; mov.f64 %r45,0d40906d025c7e2864; mov.f64 %r44,0dc075a6ef28a38bd7; mov.f64 %r43,0dc074b3b36742cc63; mov.f64 %r42,0dc050eb2f5a7d1783; mov.f64 %r41,0dc010a370f90c6bbf; mov.f64 %r40,0dbfb1ffffe69afbc6; .loc 1 342 0 mov.f64 %r28,0d404e60810c98c5de; mov.f64 %r23,0dbda918b147e495cc; $L2: .loc 1 345 0 mul.f64 %r56,%r50,%r50; mov.f64 %r57,0d3ff0000000000000; div.rn.f64 %r37,%r57,%r56; .loc 1 346 0 fma.rn.f64 %r59,%r37,%r44,%r43; fma.rn.f64 %r60,%r59,%r37,%r42; fma.rn.f64 %r61,%r60,%r37,%r41; fma.rn.f64 %r62,%r61,%r37,%r40; fma.rn.f64 %r63,%r62,%r37,%r23; .loc 1 347 0 fma.rn.f64 %r64,%r37,%r48,%r47; fma.rn.f64 %r65,%r64,%r37,%r46; fma.rn.f64 %r66,%r65,%r37,%r45; fma.rn.f64 %r67,%r66,%r37,%r28; fma.rn.f64 %r68,%r67,%r37,0d3ff0000000000000; .loc 1 348 0 div.rn.f64 %r69,%r63,%r68; add.f64 %value,%r69,0d3ff0000000000000; .loc 1 349 0 st.param.f64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qzero .func (.param .f64 %value_out) qzero (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .pred %r56; .reg .pred %r57; .reg .pred %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; mov.f64 %r53,%ar0; .loc 1 475 0 mov.b64 %r54,%r53; shr.u64 %r55,%r54,32; cvt.u32.u64 %r37,%r55; .loc 1 476 0 and.b32 %r38,%r37,2147483647; .loc 1 477 0 setp.gt.s32 %r56,%r38,1075838975; @ %r56 bra $L8; .loc 1 478 0 setp.gt.s32 %r57,%r38,1074933386; @ %r57 bra $L9; .loc 1 479 0 setp.gt.s32 %r58,%r38,1074191212; selp.f64 %r51,0dc062a7eb201cf40f,0dc0153e6af8b32931,%r58; selp.f64 %r50,0d40a3a8aad94fb1c0,0d406a95530e001365,%r58; selp.f64 %r49,0d40b93c6cd7c76a28,0d408b977c9c5cc214,%r58; selp.f64 %r48,0d40acf04be44dfc63,0d408a664522b3bf22,%r58; selp.f64 %r47,0d40862d8386544eb3,0d4070d591e4d14b40,%r58; selp.f64 %r46,0d4064d77c81fa21e0,0d403040b171814bb4,%r58; selp.f64 %r45,0d406559dbe25efd1f,0d403faa8e29fbdc4a,%r58; selp.f64 %r44,0d40454f98962daedd,0d402cfdbfaaf96fe5,%r58; selp.f64 %r43,0d400ac0fc61149cf5,0d3ffff897e727779c,%r58; selp.f64 %r42,0d3fb2bfee0e8d0842,0d3fb2bec53e883e34,%r58; selp.f64 %r28,0d40486122bfe343a6,0d403e5d96f7c07aed,%r58; selp.f64 %r23,0d3e32cd036adecb82,0d3e84313b54f76bdb,%r58; bra $L7; $L8: mov.f64 %r51,0dc114fd6d2c9530c5; mov.f64 %r50,0d4129a66b28de0b3d; mov.f64 %r49,0d412883da83a52b43; mov.f64 %r48,0d4101665254d38c3f; mov.f64 %r47,0d40bfa2584e6b0563; mov.f64 %r46,0d40e212d40e901566; mov.f64 %r45,0d40c14d993e18f46d; mov.f64 %r44,0d40816d6315301825; mov.f64 %r43,0d402789525bb334d6; mov.f64 %r42,0d3fb2bffffffffe2c; .loc 1 477 0 mov.f64 %r28,0d406478d5365b39bc; mov.f64 %r23,0d0000000000000000; bra $L7; $L9: mov.f64 %r51,0dc0b4ea57bedbc609; mov.f64 %r50,0d40e191181f7a54a0; mov.f64 %r49,0d40ebb5e397e02372; mov.f64 %r48,0d40d267d27b591e6d; mov.f64 %r47,0d40a03ba0da21c0ce; mov.f64 %r46,0d409f17e953c6e3a6; mov.f64 %r45,0d40900cf99dc8c481; mov.f64 %r44,0d4060e3920a8788e9; mov.f64 %r43,0d401757b0b9953dd3; mov.f64 %r42,0d3fb2bfffd172b04c; .loc 1 478 0 mov.f64 %r28,0d4054b1b3fb5e1543; mov.f64 %r23,0d3db43d8f29cc8cd9; $L7: .loc 1 481 0 mul.f64 %r59,%r53,%r53; mov.f64 %r60,0d3ff0000000000000; div.rn.f64 %r39,%r60,%r59; .loc 1 482 0 fma.rn.f64 %r62,%r39,%r46,%r45; fma.rn.f64 %r63,%r62,%r39,%r44; fma.rn.f64 %r64,%r63,%r39,%r43; fma.rn.f64 %r65,%r64,%r39,%r42; fma.rn.f64 %r66,%r65,%r39,%r23; .loc 1 483 0 fma.rn.f64 %r67,%r39,%r51,%r50; fma.rn.f64 %r68,%r67,%r39,%r49; fma.rn.f64 %r69,%r68,%r39,%r48; fma.rn.f64 %r70,%r69,%r39,%r47; fma.rn.f64 %r71,%r70,%r39,%r28; fma.rn.f64 %r72,%r71,%r39,0d3ff0000000000000; .loc 1 484 0 div.rn.f64 %r73,%r66,%r72; mov.f64 %r75,0d3fc0000000000000; sub.f64 %r74,%r73,%r75; div.rn.f64 %value,%r74,%r53; .loc 1 485 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j0 .visible .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r44; .reg .f64 %r45; .reg .u32 %r47; .reg .f64 %r49; .reg .f64 %r54; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .pred %r73; .reg .f64 %r75; .reg .f64 %r77; .reg .pred %r78; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r82; .reg .pred %r83; .reg .pred %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r89; .reg .f64 %r91; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .pred %r98; .reg .f64 %r99; .reg .pred %r100; .reg .pred %r101; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .pred %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r118; mov.f64 %r64,%ar0; .loc 1 104 0 mov.b64 %r65,%r64; shr.u64 %r66,%r65,32; .loc 1 105 0 cvt.u32.u64 %r67,%r66; and.b32 %r47,%r67,2147483647; .loc 1 106 0 setp.le.s32 %r68,%r47,2146435071; @ %r68 bra $L12; mul.f64 %r69,%r64,%r64; mov.f64 %r70,0d3ff0000000000000; div.rn.f64 %r63,%r70,%r69; bra $L11; $L12: .loc 1 107 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r64; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r72,[%value_in]; } .loc 1 108 0 setp.le.s32 %r73,%r47,1073741823; @ %r73 bra $L14; .loc 1 109 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),sin,(%out_arg1); ld.param.f64 %r75,[%value_in]; } .loc 1 110 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),cos,(%out_arg1); ld.param.f64 %r77,[%value_in]; } .loc 1 111 0 sub.f64 %r44,%r75,%r77; .loc 1 112 0 add.f64 %r45,%r75,%r77; .loc 1 113 0 setp.gt.s32 %r78,%r47,2145386495; @ %r78 bra $L15; .loc 1 114 0 add.f64 %r80,%r72,%r72; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r80; call (%value_in),cos,(%out_arg1); ld.param.f64 %r81,[%value_in]; } neg.f64 %r54,%r81; .loc 1 115 0 mul.f64 %r82,%r75,%r77; setp.lt.f64 %r83,%r82,0d0000000000000000; @ ! %r83 bra $L25; div.rn.f64 %r45,%r54,%r44; bra $L15; $L25: .loc 1 116 0 div.rn.f64 %r44,%r54,%r45; $L15: .loc 1 122 0 setp.le.s32 %r84,%r47,1207959552; @ %r84 bra $L18; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r86,[%value_in]; } mul.f64 %r87,%r45,0d3fe20dd750429b6d; div.rn.f64 %r63,%r87,%r86; bra $L11; $L18: .loc 1 124 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),pzero,(%out_arg1); ld.param.f64 %r89,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),qzero,(%out_arg1); ld.param.f64 %r91,[%value_in]; } .loc 1 125 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r93,[%value_in]; } mul.f64 %r94,%r44,%r91; neg.f64 %r95,%r94; fma.rn.f64 %r96,%r45,%r89,%r95; mul.f64 %r97,%r96,0d3fe20dd750429b6d; div.rn.f64 %r63,%r97,%r93; bra $L11; $L14: .loc 1 129 0 setp.gt.s32 %r98,%r47,1059061759; @ %r98 bra $L19; .loc 1 130 0 add.f64 %r99,%r72,0d7e37e43c8800759c; setp.gt.f64 %r100,%r99,0d3ff0000000000000; @ ! %r100 bra $L19; .loc 1 131 0 setp.le.s32 %r101,%r47,1044381695; @ %r101 bra $L22; .loc 1 132 0 mul.f64 %r103,%r72,0dbfd0000000000000; fma.rn.f64 %r63,%r103,%r72,0d3ff0000000000000; bra $L11; $L19: .loc 1 135 0 mul.f64 %r49,%r72,%r72; .loc 1 136 0 fma.rn.f64 %r104,%r49,0dbe33d5e773d63fce,0d3ebeb1d10c503919; fma.rn.f64 %r105,%r104,%r49,0dbf28e6a5b61ac6e9; fma.rn.f64 %r106,%r105,%r49,0d3f8ffffffffffffd; mul.f64 %r107,%r106,%r49; .loc 1 137 0 fma.rn.f64 %r108,%r49,0d3e1408bcf4745d8f,0d3ea13b54ce84d5a9; fma.rn.f64 %r109,%r108,%r49,0d3f1ea6d2dd57dbf4; fma.rn.f64 %r110,%r109,%r49,0d3f8ffce882c8c2a4; fma.rn.f64 %r111,%r110,%r49,0d3ff0000000000000; div.rn.f64 %r62,%r107,%r111; .loc 1 138 0 setp.gt.s32 %r112,%r47,1072693247; @ %r112 bra $L21; .loc 1 139 0 mov.f64 %r114,0d3fd0000000000000; sub.f64 %r113,%r62,%r114; fma.rn.f64 %r63,%r113,%r49,0d3ff0000000000000; bra $L11; $L21: .loc 1 142 0 fma.rn.f64 %r115,%r72,0d3fe0000000000000,0d3ff0000000000000; mul.f64 %r116,%r49,%r62; fma.rn.f64 %r118,%r72,0dbfe0000000000000,0d3ff0000000000000; fma.rn.f64 %r63,%r115,%r118,%r116; bra $L11; $L22: .loc 1 131 0 mov.f64 %r63,0d3ff0000000000000; $L11: .loc 1 144 0 mov.f64 %value,%r63; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y0 .visible .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r42; .reg .f64 %r46; .reg .f64 %r47; .reg .u32 %r48; .reg .u32 %r50; .reg .f64 %r51; .reg .f64 %r56; .reg .f64 %r65; .reg .f64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .u32 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .f64 %r76; .reg .pred %r77; .reg .f64 %r78; .reg .pred %r79; .reg .f64 %r81; .reg .f64 %r83; .reg .pred %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .pred %r89; .reg .pred %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r95; .reg .f64 %r97; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .pred %r103; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r117; .reg .f64 %r119; .reg .f64 %r120; mov.f64 %r66,%ar0; .loc 1 173 0 mov.b64 %r67,%r66; shr.u64 %r68,%r67,32; cvt.u32.u64 %r48,%r68; .loc 1 174 0 and.b32 %r50,%r48,2147483647; .loc 1 176 0 setp.le.s32 %r69,%r50,2146435071; @ %r69 bra $L27; fma.rn.f64 %r70,%r66,%r66,%r66; mov.f64 %r71,0d3ff0000000000000; div.rn.f64 %r65,%r71,%r70; bra $L26; $L27: .loc 1 177 0 cvt.u32.u64 %r74,%r67; or.b32 %r73,%r50,%r74; setp.ne.u32 %r75,%r73,0; @ %r75 bra $L29; mov.f64 %r76,0dbff0000000000000; div.rn.f64 %r65,%r76,0d0000000000000000; bra $L26; $L29: .loc 1 178 0 setp.ge.s32 %r77,%r48,0; @ %r77 bra $L30; mov.f64 %r78,0d0000000000000000; div.rn.f64 %r65,%r78,0d0000000000000000; bra $L26; $L30: .loc 1 179 0 setp.le.s32 %r79,%r50,1073741823; @ %r79 bra $L31; .loc 1 191 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),sin,(%out_arg1); ld.param.f64 %r81,[%value_in]; } .loc 1 192 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),cos,(%out_arg1); ld.param.f64 %r83,[%value_in]; } .loc 1 193 0 sub.f64 %r46,%r81,%r83; .loc 1 194 0 add.f64 %r47,%r81,%r83; .loc 1 199 0 setp.gt.s32 %r84,%r50,2145386495; @ %r84 bra $L32; .loc 1 200 0 add.f64 %r86,%r66,%r66; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; call (%value_in),cos,(%out_arg1); ld.param.f64 %r87,[%value_in]; } neg.f64 %r56,%r87; .loc 1 201 0 mul.f64 %r88,%r81,%r83; setp.lt.f64 %r89,%r88,0d0000000000000000; @ ! %r89 bra $L38; div.rn.f64 %r47,%r56,%r46; bra $L32; $L38: .loc 1 202 0 div.rn.f64 %r46,%r56,%r47; $L32: .loc 1 204 0 setp.le.s32 %r90,%r50,1207959552; @ %r90 bra $L35; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r92,[%value_in]; } mul.f64 %r93,%r46,0d3fe20dd750429b6d; div.rn.f64 %r65,%r93,%r92; bra $L26; $L35: .loc 1 206 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),pzero,(%out_arg1); ld.param.f64 %r95,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),qzero,(%out_arg1); ld.param.f64 %r97,[%value_in]; } .loc 1 207 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r99,[%value_in]; } mul.f64 %r100,%r47,%r97; fma.rn.f64 %r101,%r46,%r95,%r100; mul.f64 %r102,%r101,0d3fe20dd750429b6d; div.rn.f64 %r65,%r102,%r99; bra $L26; $L31: .loc 1 211 0 setp.gt.s32 %r103,%r50,1044381696; @ %r103 bra $L36; .loc 1 212 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r105,[%value_in]; } fma.rn.f64 %r65,%r105,0d3fe45f306dc9c883,0dbfb2e4d699cbd01f; bra $L26; $L36: .loc 1 214 0 mul.f64 %r51,%r66,%r66; .loc 1 215 0 fma.rn.f64 %r106,%r51,0dbdc5e43d693fb3c8,0d3e5500573b4eabd4; fma.rn.f64 %r107,%r106,%r51,0dbecffea773d25cad; fma.rn.f64 %r108,%r107,%r51,0d3f36c54d20b29b6b; fma.rn.f64 %r109,%r108,%r51,0dbf8c4ce8b16cfa97; fma.rn.f64 %r110,%r109,%r51,0d3fc69d019de9e3fc; fma.rn.f64 %r111,%r110,%r51,0dbfb2e4d699cbd01f; .loc 1 216 0 fma.rn.f64 %r112,%r51,0d3dfe50183bd6d9ef,0d3e91642d7ff202fd; fma.rn.f64 %r113,%r112,%r51,0d3f13ecbbf578c6c1; fma.rn.f64 %r114,%r113,%r51,0d3f8a127091c9c71a; fma.rn.f64 %r115,%r114,%r51,0d3ff0000000000000; .loc 1 217 0 div.rn.f64 %r42,%r111,%r115; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r117,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r119,[%value_in]; } mul.f64 %r120,%r117,%r119; fma.rn.f64 %r65,%r120,0d3fe45f306dc9c883,%r42; $L26: .loc 1 218 0 mov.f64 %value,%r65; st.param.f64 [%value_out],%value; ret; } lib_a-e_j1.o/ 0 0 0 644 16410 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: pone .func (.param .f64 %value_out) pone (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_j1.c" // BEGIN FUNCTION DECL: qone .func (.param .f64 %value_out) qone (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1 .visible .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1 .visible .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN FUNCTION DEF: pone .func (.param .f64 %value_out) pone (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; mov.f64 %r50,%ar0; .loc 1 337 0 mov.b64 %r51,%r50; shr.u64 %r52,%r51,32; cvt.u32.u64 %r35,%r52; .loc 1 338 0 and.b32 %r36,%r35,2147483647; .loc 1 339 0 setp.gt.s32 %r53,%r36,1075838975; @ %r53 bra $L3; .loc 1 340 0 setp.gt.s32 %r54,%r36,1074933386; @ %r54 bra $L4; .loc 1 341 0 setp.gt.s32 %r55,%r36,1074191212; selp.f64 %r48,0d4059f26d7c2eed53,0d4020bab1f44e5192,%r55; selp.f64 %r47,0d408bd67da32e31e9,0d405d6b7ada1884a9,%r55; selp.f64 %r46,0d40905b7c5037d523,0d406d08d8d5a2dbd9,%r55; selp.f64 %r45,0d40750c3307f1a75f,0d405f529314f92cd5,%r55; selp.f64 %r44,0d4048478f8ea83ee5,0d40144b49a574c1fe,%r55; selp.f64 %r43,0d4056c3854d2c1837,0d4031b1a8177f8ee2,%r55; selp.f64 %r42,0d40418f489da6d129,0d40287c377f71a964,%r55; selp.f64 %r41,0d400f76bce85ead8a,0d4002f2b7f98faec0,%r55; selp.f64 %r40,0d3fbdfff55b21d17b,0d3fbdff42be760d83,%r55; selp.f64 %r28,0d40416549a134069c,0d40356fbd8ad5ecdc,%r55; selp.f64 %r23,0d3e29fc21a7ad9edd,0d3e7ce9d4f65544f4,%r55; bra $L2; $L3: mov.f64 %r48,0d40de1511697a0b2d; mov.f64 %r47,0d40f7d42cb28f17bb; mov.f64 %r46,0d40e20b8697c5bb7f; mov.f64 %r45,0d40ac85dc964d274f; mov.f64 %r44,0d40beea7ac32782dd; mov.f64 %r43,0d40ae457da3a532cc; mov.f64 %r42,0d4079c0d4652ea590; mov.f64 %r41,0d402a7a9d357f7fce; mov.f64 %r40,0d3fbdfffffffffcce; .loc 1 339 0 mov.f64 %r28,0d405c8d458e656cac; mov.f64 %r23,0d0000000000000000; bra $L2; $L4: mov.f64 %r48,0d40978030036f5e51; mov.f64 %r47,0d40bea4b0b8a5bb15; mov.f64 %r46,0d40b4e9445706b6fb; mov.f64 %r45,0d408efb361b066701; mov.f64 %r44,0d408085b8bb7e0cb7; mov.f64 %r43,0d40802d16d052d649; mov.f64 %r42,0d405b13b9452602ed; mov.f64 %r41,0d401b36046e6315e3; mov.f64 %r40,0d3fbdffffe2c10043; .loc 1 340 0 mov.f64 %r28,0d404da3eaa8af633d; mov.f64 %r23,0d3dad0667dae1ca7d; $L2: .loc 1 343 0 mul.f64 %r56,%r50,%r50; mov.f64 %r57,0d3ff0000000000000; div.rn.f64 %r37,%r57,%r56; .loc 1 344 0 fma.rn.f64 %r59,%r37,%r44,%r43; fma.rn.f64 %r60,%r59,%r37,%r42; fma.rn.f64 %r61,%r60,%r37,%r41; fma.rn.f64 %r62,%r61,%r37,%r40; fma.rn.f64 %r63,%r62,%r37,%r23; .loc 1 345 0 fma.rn.f64 %r64,%r37,%r48,%r47; fma.rn.f64 %r65,%r64,%r37,%r46; fma.rn.f64 %r66,%r65,%r37,%r45; fma.rn.f64 %r67,%r66,%r37,%r28; fma.rn.f64 %r68,%r67,%r37,0d3ff0000000000000; .loc 1 346 0 div.rn.f64 %r69,%r63,%r68; add.f64 %value,%r69,0d3ff0000000000000; .loc 1 347 0 st.param.f64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qone .func (.param .f64 %value_out) qone (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r28; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .pred %r56; .reg .pred %r57; .reg .pred %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; mov.f64 %r53,%ar0; .loc 1 474 0 mov.b64 %r54,%r53; shr.u64 %r55,%r54,32; cvt.u32.u64 %r37,%r55; .loc 1 475 0 and.b32 %r38,%r37,2147483647; .loc 1 476 0 setp.gt.s32 %r56,%r38,1075838975; @ %r56 bra $L8; .loc 1 477 0 setp.gt.s32 %r57,%r38,1074933386; @ %r57 bra $L9; .loc 1 478 0 setp.gt.s32 %r58,%r38,1074191212; selp.f64 %r51,0dc060e670290a311f,0dc013d686e71be86b,%r58; selp.f64 %r50,0d409dbc7a0dd4df4b,0d40637e5e3c3ed8d4,%r58; selp.f64 %r49,0d40b5abbaa61d54a6,0d40871b2548d4c029,%r58; selp.f64 %r48,0d40aa684e448e7c9a,0d4087ac05ce49a0f7,%r58; selp.f64 %r47,0d40850eebc031ee3e,0d406f9f68db821cba,%r58; selp.f64 %r46,0dc06b66b95f5c1bf6,0dc0355f3639cf6e52,%r58; selp.f64 %r45,0dc06c87d34718d55f,0dc04529a3de104aaa,%r58; selp.f64 %r44,0dc04cec71c25d16da,0dc033a9e2c168907f,%r58; selp.f64 %r43,0dc01270c23302d9ff,0dc006048469bb4eda,%r58; selp.f64 %r42,0dbfba3feb51aeed54,0dbfba3e8e9148b010,%r58; selp.f64 %r28,0d4047d523ccd367e4,0d403d888a78ae64ff,%r58; selp.f64 %r23,0dbe35cfa9d38fc84f,0dbe87f12644c626d2,%r58; bra $L7; $L8: mov.f64 %r51,0dc111f9690ea5aa18; mov.f64 %r50,0d412457d27719ad5c; mov.f64 %r49,0d4125f65372869c19; mov.f64 %r48,0d4100579ab0b75e98; mov.f64 %r47,0d40be9162d0d88419; mov.f64 %r46,0dc0e7a6d065d09c6a; mov.f64 %r45,0dc0c724e740f87415; mov.f64 %r44,0dc087bcd053e4b576; mov.f64 %r43,0dc0304591a26779f7; mov.f64 %r42,0dbfba3ffffffffdf3; .loc 1 476 0 mov.f64 %r28,0d40642ca6de5bcde5; mov.f64 %r23,0d0000000000000000; bra $L7; $L9: mov.f64 %r51,0dc0b26f2efcffa004; mov.f64 %r50,0d40db4b04cf7c364b; mov.f64 %r49,0d40e8576daabad197; mov.f64 %r48,0d40d10f1f0d64ce29; mov.f64 %r47,0d409f1f31e77bf839; mov.f64 %r46,0dc0a468e388fda79d; mov.f64 %r45,0dc09574c66931734f; mov.f64 %r44,0dc066f56d6ca7b9b0; mov.f64 %r43,0dc0201ce6ca03ad4b; mov.f64 %r42,0dbfba3fffcb597fef; .loc 1 477 0 mov.f64 %r28,0d405451b2ff5a11b2; mov.f64 %r23,0dbdb6fa431aa1a098; $L7: .loc 1 480 0 mul.f64 %r59,%r53,%r53; mov.f64 %r60,0d3ff0000000000000; div.rn.f64 %r39,%r60,%r59; .loc 1 481 0 fma.rn.f64 %r62,%r39,%r46,%r45; fma.rn.f64 %r63,%r62,%r39,%r44; fma.rn.f64 %r64,%r63,%r39,%r43; fma.rn.f64 %r65,%r64,%r39,%r42; fma.rn.f64 %r66,%r65,%r39,%r23; .loc 1 482 0 fma.rn.f64 %r67,%r39,%r51,%r50; fma.rn.f64 %r68,%r67,%r39,%r49; fma.rn.f64 %r69,%r68,%r39,%r48; fma.rn.f64 %r70,%r69,%r39,%r47; fma.rn.f64 %r71,%r70,%r39,%r28; fma.rn.f64 %r72,%r71,%r39,0d3ff0000000000000; .loc 1 483 0 div.rn.f64 %r73,%r66,%r72; add.f64 %r74,%r73,0d3fd8000000000000; div.rn.f64 %value,%r74,%r53; .loc 1 484 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j1 .visible .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r40; .reg .f64 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .f64 %r45; .reg .f64 %r46; .reg .f64 %r58; .reg .f64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .pred %r62; .reg .f64 %r63; .reg .f64 %r65; .reg .pred %r66; .reg .f64 %r68; .reg .f64 %r70; .reg .f64 %r71; .reg .pred %r72; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .pred %r77; .reg .pred %r78; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r83; .reg .f64 %r85; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .pred %r92; .reg .pred %r93; .reg .f64 %r94; .reg .pred %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; mov.f64 %r59,%ar0; .loc 1 105 0 mov.b64 %r60,%r59; shr.u64 %r61,%r60,32; cvt.u32.u64 %r42,%r61; .loc 1 106 0 and.b32 %r43,%r42,2147483647; .loc 1 107 0 setp.le.s32 %r62,%r43,2146435071; @ %r62 bra $L12; mov.f64 %r63,0d3ff0000000000000; div.rn.f64 %r58,%r63,%r59; bra $L11; $L12: .loc 1 108 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r65,[%value_in]; } .loc 1 109 0 setp.le.s32 %r66,%r43,1073741823; @ %r66 bra $L14; .loc 1 110 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),sin,(%out_arg1); ld.param.f64 %r68,[%value_in]; } .loc 1 111 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),cos,(%out_arg1); ld.param.f64 %r70,[%value_in]; } .loc 1 112 0 neg.f64 %r71,%r68; sub.f64 %r40,%r71,%r70; .loc 1 113 0 sub.f64 %r41,%r68,%r70; .loc 1 114 0 setp.gt.s32 %r72,%r43,2145386495; @ %r72 bra $L15; .loc 1 115 0 add.f64 %r74,%r65,%r65; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),cos,(%out_arg1); ld.param.f64 %r75,[%value_in]; } .loc 1 116 0 mul.f64 %r76,%r68,%r70; setp.gt.f64 %r77,%r76,0d0000000000000000; @ ! %r77 bra $L22; div.rn.f64 %r41,%r75,%r40; bra $L15; $L22: .loc 1 117 0 div.rn.f64 %r40,%r75,%r41; $L15: .loc 1 123 0 setp.le.s32 %r78,%r43,1207959552; @ %r78 bra $L18; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r80,[%value_in]; } mul.f64 %r81,%r41,0d3fe20dd750429b6d; div.rn.f64 %r58,%r81,%r80; bra $L19; $L18: .loc 1 125 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),pone,(%out_arg1); ld.param.f64 %r83,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),qone,(%out_arg1); ld.param.f64 %r85,[%value_in]; } .loc 1 126 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r87,[%value_in]; } mul.f64 %r88,%r40,%r85; neg.f64 %r89,%r88; fma.rn.f64 %r90,%r41,%r83,%r89; mul.f64 %r91,%r90,0d3fe20dd750429b6d; div.rn.f64 %r58,%r91,%r87; $L19: .loc 1 128 0 setp.ge.s32 %r92,%r42,0; @ %r92 bra $L11; neg.f64 %r58,%r58; bra $L11; $L14: mul.f64 %r58,%r59,0d3fe0000000000000; .loc 1 131 0 setp.gt.s32 %r93,%r43,1044381695; @ %r93 bra $L20; .loc 1 132 0 add.f64 %r94,%r59,0d7e37e43c8800759c; setp.gt.f64 %r95,%r94,0d3ff0000000000000; @ %r95 bra $L11; $L20: .loc 1 134 0 mul.f64 %r45,%r59,%r59; .loc 1 135 0 fma.rn.f64 %r96,%r45,0d3e6aaafa46ca0bd9,0dbef0c5c6ba169668; fma.rn.f64 %r97,%r96,%r45,0d3f570d9f98472c61; fma.rn.f64 %r98,%r97,%r45,0dbfb0000000000000; mul.f64 %r46,%r98,%r45; .loc 1 137 0 mul.f64 %r99,%r59,%r46; .loc 1 136 0 fma.rn.f64 %r100,%r45,0d3dab2acfcfb97ed8,0d3e35ac88c97dff2c; fma.rn.f64 %r101,%r100,%r45,0d3eb3bff8333f8498; fma.rn.f64 %r102,%r101,%r45,0d3f285f56b9cdf664; fma.rn.f64 %r103,%r102,%r45,0d3f939d0b12637e53; fma.rn.f64 %r104,%r103,%r45,0d3ff0000000000000; .loc 1 138 0 div.rn.f64 %r105,%r99,%r104; add.f64 %r58,%r58,%r105; $L11: .loc 1 139 0 mov.f64 %value,%r58; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y1 .visible .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r42; .reg .f64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .f64 %r53; .reg .f64 %r64; .reg .f64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .f64 %r75; .reg .pred %r76; .reg .f64 %r77; .reg .pred %r78; .reg .f64 %r80; .reg .f64 %r82; .reg .f64 %r83; .reg .pred %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .pred %r89; .reg .pred %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r95; .reg .f64 %r97; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .pred %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r115; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; mov.f64 %r65,%ar0; .loc 1 174 0 mov.b64 %r66,%r65; shr.u64 %r67,%r66,32; cvt.u32.u64 %r50,%r67; .loc 1 175 0 and.b32 %r52,%r50,2147483647; .loc 1 177 0 setp.le.s32 %r68,%r52,2146435071; @ %r68 bra $L24; fma.rn.f64 %r69,%r65,%r65,%r65; mov.f64 %r70,0d3ff0000000000000; div.rn.f64 %r64,%r70,%r69; bra $L23; $L24: .loc 1 178 0 cvt.u32.u64 %r73,%r66; or.b32 %r72,%r52,%r73; setp.ne.u32 %r74,%r72,0; @ %r74 bra $L26; mov.f64 %r75,0dbff0000000000000; div.rn.f64 %r64,%r75,0d0000000000000000; bra $L23; $L26: .loc 1 179 0 setp.ge.s32 %r76,%r50,0; @ %r76 bra $L27; mov.f64 %r77,0d0000000000000000; div.rn.f64 %r64,%r77,0d0000000000000000; bra $L23; $L27: .loc 1 180 0 setp.le.s32 %r78,%r52,1073741823; @ %r78 bra $L28; .loc 1 181 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),sin,(%out_arg1); ld.param.f64 %r80,[%value_in]; } .loc 1 182 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),cos,(%out_arg1); ld.param.f64 %r82,[%value_in]; } .loc 1 183 0 neg.f64 %r83,%r80; sub.f64 %r48,%r83,%r82; .loc 1 184 0 sub.f64 %r49,%r80,%r82; .loc 1 185 0 setp.gt.s32 %r84,%r52,2145386495; @ %r84 bra $L29; .loc 1 186 0 add.f64 %r86,%r65,%r65; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; call (%value_in),cos,(%out_arg1); ld.param.f64 %r87,[%value_in]; } .loc 1 187 0 mul.f64 %r88,%r80,%r82; setp.gt.f64 %r89,%r88,0d0000000000000000; @ ! %r89 bra $L35; div.rn.f64 %r49,%r87,%r48; bra $L29; $L35: .loc 1 188 0 div.rn.f64 %r48,%r87,%r49; $L29: .loc 1 201 0 setp.le.s32 %r90,%r52,1207959552; @ %r90 bra $L32; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r92,[%value_in]; } mul.f64 %r93,%r48,0d3fe20dd750429b6d; div.rn.f64 %r64,%r93,%r92; bra $L23; $L32: .loc 1 203 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),pone,(%out_arg1); ld.param.f64 %r95,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),qone,(%out_arg1); ld.param.f64 %r97,[%value_in]; } .loc 1 204 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r99,[%value_in]; } mul.f64 %r100,%r49,%r97; fma.rn.f64 %r101,%r48,%r95,%r100; mul.f64 %r102,%r101,0d3fe20dd750429b6d; div.rn.f64 %r64,%r102,%r99; bra $L23; $L28: .loc 1 208 0 setp.gt.s32 %r103,%r52,1016070144; @ %r103 bra $L33; .loc 1 209 0 mov.f64 %r104,0dbfe45f306dc9c883; div.rn.f64 %r64,%r104,%r65; bra $L23; $L33: .loc 1 211 0 mul.f64 %r53,%r65,%r65; .loc 1 212 0 fma.rn.f64 %r105,%r53,0dbe78ac00569105b8,0d3ef8ab038fa6b88e; fma.rn.f64 %r106,%r105,%r53,0dbf5f55e54844f50f; fma.rn.f64 %r107,%r106,%r53,0d3fa9d3c776292cd1; fma.rn.f64 %r108,%r107,%r53,0dbfc91866143cbc8a; .loc 1 213 0 fma.rn.f64 %r109,%r53,0d3db25039daca772a,0d3e3abf1d5ba69a86; fma.rn.f64 %r110,%r109,%r53,0d3eb6c05a894e8ca6; fma.rn.f64 %r111,%r110,%r53,0d3f2a8c896c257764; fma.rn.f64 %r112,%r111,%r53,0d3f94650d3f4da9f0; fma.rn.f64 %r113,%r112,%r53,0d3ff0000000000000; .loc 1 214 0 div.rn.f64 %r42,%r108,%r113; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r115,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r65; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r117,[%value_in]; } mov.f64 %r119,0d3ff0000000000000; div.rn.f64 %r118,%r119,%r65; neg.f64 %r120,%r118; fma.rn.f64 %r121,%r115,%r117,%r120; mul.f64 %r122,%r121,0d3fe45f306dc9c883; fma.rn.f64 %r64,%r42,%r65,%r122; $L23: .loc 1 215 0 mov.f64 %value,%r64; st.param.f64 [%value_out],%value; ret; } lib_a-e_jn.o/ 0 0 0 644 18007 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_jn .visible .func (.param .f64 %value_out) __ieee754_jn (.param .u32 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_jn.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_yn .visible .func (.param .f64 %value_out) __ieee754_yn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0 .extern .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1 .extern .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0 .extern .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1 .extern .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_jn .visible .func (.param .f64 %value_out) __ieee754_jn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r55; .reg .f64 %r71; .reg .u32 %r73; .reg .f64 %r75; .reg .f64 %r76; .reg .u32 %r77; .reg .f64 %r80; .reg .f64 %r84; .reg .f64 %r85; .reg .u32 %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .u32 %r94; .reg .f64 %r95; .reg .f64 %r97; .reg .f64 %r98; .reg .u32 %r99; .reg .u32 %r100; .reg .u32 %r101; .reg .u32 %r102; .reg .f64 %r104; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .f64 %r115; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .u32 %r120; .reg .f64 %r121; .reg .u32 %r122; .reg .f64 %r127; .reg .f64 %r128; .reg .u32 %r129; .reg .f64 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u32 %r134; .reg .u32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .pred %r139; .reg .pred %r140; .reg .f64 %r142; .reg .pred %r143; .reg .f64 %r145; .reg .u32 %r147; .reg .f64 %r149; .reg .u32 %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r155; .reg .u32 %r156; .reg .u16 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u32 %r160; .reg .u16 %r161; .reg .pred %r162; .reg .pred %r163; .reg .pred %r164; .reg .u32 %r165; .reg .pred %r166; .reg .pred %r167; .reg .pred %r168; .reg .f64 %r170; .reg .f64 %r172; .reg .f64 %r174; .reg .f64 %r176; .reg .f64 %r178; .reg .f64 %r180; .reg .f64 %r181; .reg .f64 %r183; .reg .f64 %r185; .reg .f64 %r187; .reg .f64 %r188; .reg .f64 %r190; .reg .f64 %r192; .reg .u32 %r193; .reg .f64 %r194; .reg .f64 %r195; .reg .f64 %r196; .reg .pred %r197; .reg .pred %r198; .reg .pred %r199; .reg .f64 %r200; .reg .pred %r201; .reg .f64 %r203; .reg .f64 %r204; .reg .pred %r205; .reg .f64 %r206; .reg .pred %r207; .reg .pred %r209; .reg .f64 %r210; .reg .f64 %r211; .reg .f64 %r212; .reg .pred %r213; .reg .f64 %r215; .reg .f64 %r216; .reg .f64 %r218; .reg .f64 %r219; .reg .pred %r220; .reg .f64 %r221; .reg .f64 %r222; .reg .pred %r223; .reg .f64 %r224; .reg .f64 %r225; .reg .pred %r226; .reg .pred %r227; .reg .f64 %r229; .reg .f64 %r230; .reg .pred %r231; .reg .f64 %r233; mov.u32 %r129,%ar0; mov.f64 %r130,%ar1; mov.b64 %r131,%r130; shr.u64 %r132,%r131,32; .loc 1 73 0 cvt.u32.u64 %r99,%r132; cvt.u32.u64 %r100,%r131; .loc 1 74 0 and.b32 %r101,%r99,2147483647; .loc 1 76 0 neg.s32 %r134,%r100; or.b32 %r135,%r134,%r100; shr.u32 %r136,%r135,31; or.b32 %r137,%r136,%r101; setp.le.u32 %r138,%r137,2146435072; @ %r138 bra $L2; add.f64 %r128,%r130,%r130; bra $L1; $L2: .loc 1 77 0 setp.ge.s32 %r139,%r129,0; @ %r139 bra $L4; .loc 1 78 0 neg.s32 %r129,%r129; .loc 1 79 0 neg.f64 %r130,%r130; .loc 1 80 0 add.u32 %r99,%r99,-2147483648; bra $L5; $L4: .loc 1 82 0 setp.ne.u32 %r140,%r129,0; @ %r140 bra $L5; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r130; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r142,[%value_in]; } mov.f64 %r128,%r142; bra $L1; $L5: .loc 1 83 0 setp.ne.u32 %r143,%r129,1; @ %r143 bra $L6; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r130; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r145,[%value_in]; } mov.f64 %r128,%r145; bra $L1; $L6: .loc 1 84 0 shr.u32 %r147,%r99,31; and.b32 %r102,%r147,%r129; .loc 1 85 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r130; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r149,[%value_in]; } .loc 1 86 0 or.b32 %r150,%r100,%r101; set.u32.eq.u32 %r152,%r150,0; neg.s32 %r153,%r152; set.u32.gt.s32 %r155,%r101,2146435071; neg.s32 %r156,%r155; cvt.u16.u32 %r158,%r153; cvt.u16.u32 %r159,%r156; or.b16 %r157,%r158,%r159; cvt.u32.u16 %r160,%r157; cvt.u16.u8 %r161,%r160; setp.ne.u16 %r162,%r161,0; @ %r162 bra $L31; .loc 1 88 0 cvt.rn.f64.s32 %r55,%r129; setp.le.f64 %r163,%r55,%r149; @ ! %r163 bra $L46; .loc 1 90 0 setp.le.s32 %r164,%r101,1389363199; @ %r164 bra $L10; .loc 1 104 0 and.b32 %r165,%r129,3; setp.eq.u32 %r166,%r165,2; @ %r166 bra $L12; setp.eq.u32 %r167,%r165,3; @ %r167 bra $L13; setp.eq.u32 %r168,%r165,1; @ %r168 bra $L14; .loc 1 105 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r170,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r172,[%value_in]; } add.f64 %r95,%r170,%r172; bra $L15; $L14: .loc 1 106 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r174,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r176,[%value_in]; } sub.f64 %r95,%r174,%r176; bra $L15; $L12: .loc 1 107 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r178,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r180,[%value_in]; } neg.f64 %r181,%r178; sub.f64 %r95,%r181,%r180; bra $L15; $L13: .loc 1 108 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),cos,(%out_arg1); ld.param.f64 %r183,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),sin,(%out_arg1); ld.param.f64 %r185,[%value_in]; } sub.f64 %r95,%r183,%r185; $L15: .loc 1 110 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r187,[%value_in]; } mul.f64 %r188,%r95,0d3fe20dd750429b6d; div.rn.f64 %r128,%r188,%r187; bra $L7; $L10: .loc 1 112 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r190,[%value_in]; } mov.f64 %r76,%r190; .loc 1 113 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r192,[%value_in]; } mov.f64 %r121,%r192; .loc 1 114 0 mov.u32 %r122,1; bra $L16; $L32: .loc 1 116 0 mov.f64 %r121,%r128; $L16: add.u32 %r193,%r122,%r122; cvt.rn.f64.s32 %r194,%r193; div.rn.f64 %r195,%r194,%r149; neg.f64 %r196,%r76; fma.rn.f64 %r128,%r195,%r121,%r196; .loc 1 114 0 add.u32 %r122,%r122,1; mov.f64 %r76,%r121; setp.lt.s32 %r197,%r122,%r129; @ %r197 bra $L32; bra $L7; $L46: .loc 1 121 0 setp.gt.s32 %r198,%r101,1041235967; @ %r198 bra $L17; .loc 1 125 0 setp.gt.s32 %r199,%r129,33; @ %r199 bra $L33; .loc 1 128 0 mul.f64 %r117,%r149,0d3fe0000000000000; mov.f64 %r119,%r117; .loc 1 129 0 mov.f64 %r118,0d3ff0000000000000; mov.u32 %r120,2; $L18: .loc 1 130 0 cvt.rn.f64.s32 %r200,%r120; mul.f64 %r118,%r118,%r200; .loc 1 131 0 mul.f64 %r119,%r119,%r117; .loc 1 129 0 add.u32 %r120,%r120,1; setp.le.s32 %r201,%r120,%r129; @ %r201 bra $L18; .loc 1 133 0 div.rn.f64 %r128,%r119,%r118; bra $L7; $L17: .loc 1 167 0 add.u32 %r73,%r129,%r129; cvt.rn.f64.s32 %r203,%r73; div.rn.f64 %r75,%r203,%r149; mov.f64 %r204,0d4000000000000000; div.rn.f64 %r104,%r204,%r149; .loc 1 168 0 add.f64 %r115,%r75,%r104; fma.rn.f64 %r71,%r75,%r115,0dbff0000000000000; .loc 1 169 0 setp.lt.f64 %r205,%r71,0d41cdcd6500000000; @ ! %r205 bra $L47; .loc 1 168 0 mov.u32 %r94,1; $L21: .loc 1 170 0 add.u32 %r94,%r94,1; add.f64 %r115,%r115,%r104; .loc 1 171 0 neg.f64 %r206,%r75; mov.f64 %r75,%r71; .loc 1 173 0 fma.rn.f64 %r71,%r71,%r115,%r206; .loc 1 169 0 setp.lt.f64 %r207,%r71,0d41cdcd6500000000; @ %r207 bra $L21; bra $L19; $L47: .loc 1 168 0 mov.u32 %r94,1; $L19: .loc 1 176 0 add.u32 %r77,%r94,%r129; add.u32 %r114,%r77,%r77; setp.lt.s32 %r209,%r77,%r129; @ %r209 bra $L35; mov.f64 %r98,0d0000000000000000; mov.f64 %r212,0d3ff0000000000000; $L23: cvt.rn.f64.s32 %r210,%r114; div.rn.f64 %r211,%r210,%r149; sub.f64 %r80,%r211,%r98; div.rn.f64 %r98,%r212,%r80; add.u32 %r114,%r114,-2; setp.le.s32 %r213,%r73,%r114; @ %r213 bra $L23; bra $L22; $L35: mov.f64 %r98,0d0000000000000000; $L22: .loc 1 189 0 mul.f64 %r215,%r55,%r104; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r215; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r216,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r216; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r218,[%value_in]; } add.u32 %r113,%r129,-1; add.u32 %r90,%r73,-2; mul.f64 %r219,%r55,%r218; .loc 1 190 0 setp.lt.f64 %r220,%r219,0d40862e42fefa39ef; @ ! %r220 bra $L48; .loc 1 191 0 cvt.rn.f64.s32 %r112,%r90; mov.f64 %r97,%r98; .loc 1 178 0 mov.f64 %r127,0d3ff0000000000000; .loc 1 196 0 mov.f64 %r222,0d4000000000000000; bra $L26; $L36: .loc 1 194 0 mov.f64 %r127,%r93; $L26: .loc 1 193 0 mul.f64 %r221,%r127,%r112; .loc 1 194 0 div.rn.f64 %r84,%r221,%r149; sub.f64 %r93,%r84,%r97; .loc 1 196 0 sub.f64 %r112,%r112,%r222; .loc 1 191 0 add.u32 %r113,%r113,-1; mov.f64 %r97,%r127; setp.ne.u32 %r223,%r113,0; @ %r223 bra $L36; bra $L27; $L48: .loc 1 199 0 cvt.rn.f64.s32 %r110,%r90; mov.f64 %r92,%r98; .loc 1 178 0 mov.f64 %r93,0d3ff0000000000000; .loc 1 204 0 mov.f64 %r225,0d4000000000000000; .loc 1 209 0 mov.f64 %r233,%r93; $L30: .loc 1 201 0 mul.f64 %r224,%r93,%r110; .loc 1 202 0 div.rn.f64 %r85,%r224,%r149; sub.f64 %r109,%r85,%r92; .loc 1 204 0 sub.f64 %r110,%r110,%r225; .loc 1 206 0 setp.gt.f64 %r226,%r109,0d54b249ad2594c37d; @ ! %r226 bra $L49; .loc 1 207 0 div.rn.f64 %r92,%r93,%r109; .loc 1 208 0 div.rn.f64 %r98,%r98,%r109; .loc 1 209 0 mov.f64 %r93,%r233; bra $L28; $L49: mov.f64 %r92,%r93; .loc 1 202 0 mov.f64 %r93,%r109; $L28: .loc 1 199 0 add.u32 %r113,%r113,-1; setp.ne.u32 %r227,%r113,0; @ %r227 bra $L30; $L27: .loc 1 213 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r149; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r229,[%value_in]; } mul.f64 %r230,%r229,%r98; div.rn.f64 %r128,%r230,%r93; bra $L7; $L31: .loc 1 87 0 mov.f64 %r128,0d0000000000000000; bra $L7; $L33: mov.f64 %r128,0d0000000000000000; $L7: .loc 1 216 0 setp.ne.u32 %r231,%r102,1; @ %r231 bra $L1; neg.f64 %r128,%r128; $L1: .loc 1 217 0 mov.f64 %value,%r128; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_yn .visible .func (.param .f64 %value_out) __ieee754_yn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .f64 %r61; .reg .u32 %r62; .reg .f64 %r67; .reg .f64 %r71; .reg .u32 %r72; .reg .f64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .pred %r81; .reg .u32 %r82; .reg .pred %r83; .reg .f64 %r84; .reg .pred %r85; .reg .f64 %r86; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .f64 %r93; .reg .pred %r94; .reg .f64 %r96; .reg .f64 %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .f64 %r105; .reg .f64 %r107; .reg .f64 %r109; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r114; .reg .f64 %r116; .reg .f64 %r118; .reg .f64 %r120; .reg .f64 %r122; .reg .f64 %r123; .reg .f64 %r125; .reg .f64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u32 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r135; .reg .u32 %r137; .reg .u32 %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .u16 %r145; .reg .u16 %r146; .reg .u16 %r147; .reg .u32 %r148; .reg .u16 %r149; .reg .pred %r150; .reg .pred %r151; mov.u32 %r72,%ar0; mov.f64 %r73,%ar1; .loc 1 230 0 mov.b64 %r74,%r73; shr.u64 %r75,%r74,32; cvt.u32.u64 %r57,%r75; cvt.u32.u64 %r58,%r74; .loc 1 231 0 and.b32 %r59,%r57,2147483647; .loc 1 233 0 neg.s32 %r77,%r58; or.b32 %r78,%r77,%r58; shr.u32 %r79,%r78,31; or.b32 %r80,%r79,%r59; setp.le.u32 %r81,%r80,2146435072; @ %r81 bra $L51; add.f64 %r71,%r73,%r73; bra $L50; $L51: .loc 1 234 0 or.b32 %r82,%r58,%r59; setp.ne.u32 %r83,%r82,0; @ %r83 bra $L53; mov.f64 %r84,0dbff0000000000000; div.rn.f64 %r71,%r84,0d0000000000000000; bra $L50; $L53: .loc 1 235 0 setp.ge.s32 %r85,%r57,0; @ %r85 bra $L54; mov.f64 %r86,0d0000000000000000; div.rn.f64 %r71,%r86,0d0000000000000000; bra $L50; $L54: .loc 1 237 0 setp.ge.s32 %r87,%r72,0; @ %r87 bra $L55; .loc 1 238 0 neg.s32 %r72,%r72; .loc 1 239 0 add.u32 %r88,%r72,%r72; and.b32 %r89,%r88,2; mov.u32 %r90,1; sub.u32 %r60,%r90,%r89; bra $L56; $L55: .loc 1 241 0 setp.ne.u32 %r91,%r72,0; @ %r91 bra $L66; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y0,(%out_arg1); ld.param.f64 %r93,[%value_in]; } mov.f64 %r71,%r93; bra $L50; $L66: .loc 1 236 0 mov.u32 %r60,1; $L56: .loc 1 242 0 setp.ne.u32 %r94,%r72,1; @ %r94 bra $L57; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y1,(%out_arg1); ld.param.f64 %r96,[%value_in]; } cvt.rn.f64.s32 %r97,%r60; mul.f64 %r71,%r97,%r96; bra $L50; $L57: .loc 1 243 0 setp.eq.u32 %r98,%r59,2146435072; @ %r98 bra $L67; .loc 1 244 0 setp.le.s32 %r99,%r59,1389363199; @ %r99 bra $L58; .loc 1 258 0 and.b32 %r100,%r72,3; setp.eq.u32 %r101,%r100,2; @ %r101 bra $L60; setp.eq.u32 %r102,%r100,3; @ %r102 bra $L61; setp.eq.u32 %r103,%r100,1; @ %r103 bra $L62; .loc 1 259 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r105,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r107,[%value_in]; } sub.f64 %r56,%r105,%r107; bra $L63; $L62: .loc 1 260 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r109,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r111,[%value_in]; } neg.f64 %r112,%r109; sub.f64 %r56,%r112,%r111; bra $L63; $L60: .loc 1 261 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r114,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r116,[%value_in]; } sub.f64 %r56,%r114,%r116; bra $L63; $L61: .loc 1 262 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),sin,(%out_arg1); ld.param.f64 %r118,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),cos,(%out_arg1); ld.param.f64 %r120,[%value_in]; } add.f64 %r56,%r118,%r120; $L63: .loc 1 264 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r122,[%value_in]; } mul.f64 %r123,%r56,0d3fe20dd750429b6d; div.rn.f64 %r71,%r123,%r122; bra $L64; $L58: .loc 1 267 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y0,(%out_arg1); ld.param.f64 %r125,[%value_in]; } mov.f64 %r67,%r125; .loc 1 268 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_y1,(%out_arg1); ld.param.f64 %r127,[%value_in]; } mov.f64 %r61,%r127; .loc 1 271 0 mov.b64 %r128,%r61; shr.u64 %r129,%r128,32; cvt.u32.u64 %r130,%r129; setp.eq.u32 %r131,%r130,-1048576; @ %r131 bra $L68; mov.u32 %r62,1; bra $L65; $L69: .loc 1 273 0 mov.f64 %r61,%r71; $L65: add.u32 %r132,%r62,%r62; cvt.rn.f64.s32 %r133,%r132; div.rn.f64 %r134,%r133,%r73; neg.f64 %r135,%r67; fma.rn.f64 %r71,%r134,%r61,%r135; .loc 1 271 0 add.u32 %r62,%r62,1; mov.f64 %r67,%r61; set.u32.lt.s32 %r137,%r62,%r72; neg.s32 %r138,%r137; mov.b64 %r139,%r71; shr.u64 %r140,%r139,32; cvt.u32.u64 %r142,%r140; set.u32.ne.u32 %r143,%r142,-1048576; neg.s32 %r144,%r143; cvt.u16.u32 %r146,%r138; cvt.u16.u32 %r147,%r144; and.b16 %r145,%r146,%r147; cvt.u32.u16 %r148,%r145; cvt.u16.u8 %r149,%r148; setp.ne.u16 %r150,%r149,0; @ %r150 bra $L69; bra $L64; $L68: .loc 1 268 0 mov.f64 %r71,%r127; $L64: .loc 1 278 0 setp.eq.u32 %r151,%r60,1; @ %r151 bra $L50; neg.f64 %r71,%r71; bra $L50; $L67: .loc 1 243 0 mov.f64 %r71,0d0000000000000000; $L50: .loc 1 279 0 mov.f64 %value,%r71; st.param.f64 [%value_out],%value; ret; } lib_a-e_log.o/ 0 0 0 644 5663 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .visible .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_log.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_log .visible .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .f64 %r63; .reg .u32 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .u32 %r69; .reg .f64 %r70; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .u32 %r79; .reg .f64 %r82; .reg .f64 %r85; .reg .u64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .pred %r96; .reg .f64 %r97; .reg .pred %r98; .reg .f64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u32 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u32 %r112; .reg .f64 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .f64 %r119; .reg .f64 %r121; .reg .f64 %r122; .reg .pred %r123; .reg .f64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .u32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .pred %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .pred %r148; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; mov.f64 %r88,%ar0; mov.b64 %r89,%r88; shr.u64 %r90,%r89,32; cvt.u32.u64 %r79,%r90; .loc 1 102 0 cvt.u32.u64 %r58,%r90; .loc 1 105 0 setp.gt.s32 %r91,%r79,1048575; @ %r91 bra $L13; .loc 1 106 0 and.b32 %r92,%r79,2147483647; cvt.u32.u64 %r95,%r89; or.b32 %r94,%r92,%r95; setp.ne.u32 %r96,%r94,0; @ %r96 bra $L3; .loc 1 107 0 mov.f64 %r97,0dc350000000000000; div.rn.f64 %r87,%r97,0d0000000000000000; bra $L1; $L3: .loc 1 108 0 setp.ge.s32 %r98,%r79,0; @ %r98 bra $L5; sub.f64 %r99,%r88,%r88; div.rn.f64 %r87,%r99,0d0000000000000000; bra $L1; $L5: .loc 1 109 0 mul.f64 %r88,%r88,0d4350000000000000; .loc 1 110 0 mov.b64 %r100,%r88; shr.u64 %r101,%r100,32; cvt.u32.u64 %r58,%r101; .loc 1 109 0 mov.u32 %r57,-54; bra $L2; $L13: .loc 1 104 0 mov.u32 %r57,0; $L2: .loc 1 112 0 setp.le.s32 %r102,%r58,2146435071; @ %r102 bra $L6; add.f64 %r87,%r88,%r88; bra $L1; $L6: .loc 1 113 0 shr.s32 %r103,%r58,20; add.u32 %r104,%r103,-1023; add.u32 %r60,%r104,%r57; .loc 1 114 0 and.b32 %r61,%r58,1048575; .loc 1 115 0 add.u32 %r105,%r61,614244; and.b32 %r62,%r105,1048576; .loc 1 116 0 mov.b64 %r86,%r88; xor.b32 %r106,%r62,1072693248; or.b32 %r107,%r106,%r61; cvt.u64.u32 %r108,%r107; shl.b64 %r109,%r108,32; and.b64 %r110,%r86,4294967295; or.b64 %r111,%r110,%r109; mov.b64 %r63,%r111; .loc 1 117 0 shr.s32 %r112,%r62,20; add.u32 %r64,%r112,%r60; .loc 1 118 0 mov.f64 %r113,0d3ff0000000000000; sub.f64 %r65,%r63,%r113; .loc 1 119 0 add.u32 %r114,%r61,2; and.b32 %r115,%r114,1048575; setp.gt.s32 %r116,%r115,2; @ %r116 bra $L7; .loc 1 120 0 setp.neu.f64 %r117,%r65,0d0000000000000000; @ %r117 bra $L8; setp.eq.u32 %r118,%r64,0; @ %r118 bra $L14; cvt.rn.f64.s32 %r78,%r64; .loc 1 121 0 mul.f64 %r119,%r78,0d3dea39ef35793c76; fma.rn.f64 %r87,%r78,0d3fe62e42fee00000,%r119; bra $L1; $L8: .loc 1 122 0 fma.rn.f64 %r121,%r65,0dbfd5555555555555,0d3fe0000000000000; mul.f64 %r122,%r65,%r65; mul.f64 %r76,%r121,%r122; .loc 1 123 0 setp.ne.u32 %r123,%r64,0; @ %r123 bra $L9; sub.f64 %r87,%r65,%r76; bra $L1; $L9: cvt.rn.f64.s32 %r77,%r64; .loc 1 124 0 fma.rn.f64 %r125,%r77,0dbdea39ef35793c76,%r76; sub.f64 %r126,%r125,%r65; neg.f64 %r127,%r126; fma.rn.f64 %r87,%r77,0d3fe62e42fee00000,%r127; bra $L1; $L7: .loc 1 126 0 add.f64 %r128,%r65,0d4000000000000000; div.rn.f64 %r66,%r65,%r128; .loc 1 127 0 cvt.rn.f64.s32 %r67,%r64; .loc 1 128 0 mul.f64 %r68,%r66,%r66; .loc 1 129 0 add.u32 %r69,%r61,-398458; .loc 1 130 0 mul.f64 %r70,%r68,%r68; .loc 1 132 0 fma.rn.f64 %r129,%r70,0d3fc39a09d078c69f,0d3fcc71c51d8e78af; fma.rn.f64 %r130,%r129,%r70,0d3fd999999997fa04; .loc 1 133 0 fma.rn.f64 %r131,%r70,0d3fc2f112df3e5244,0d3fc7466496cb03de; fma.rn.f64 %r132,%r131,%r70,0d3fd2492494229359; fma.rn.f64 %r133,%r132,%r70,0d3fe5555555555593; mul.f64 %r134,%r133,%r68; .loc 1 135 0 fma.rn.f64 %r74,%r130,%r70,%r134; .loc 1 131 0 mov.u32 %r136,440401; sub.u32 %r135,%r136,%r61; .loc 1 134 0 or.b32 %r137,%r135,%r69; .loc 1 136 0 setp.le.s32 %r138,%r137,0; @ %r138 bra $L10; .loc 1 137 0 mul.f64 %r139,%r65,0d3fe0000000000000; mul.f64 %r75,%r139,%r65; add.f64 %r140,%r74,%r75; mul.f64 %r82,%r140,%r66; .loc 1 138 0 setp.ne.u32 %r141,%r64,0; @ %r141 bra $L11; sub.f64 %r142,%r75,%r82; sub.f64 %r87,%r65,%r142; bra $L1; $L11: .loc 1 139 0 fma.rn.f64 %r143,%r67,0d3dea39ef35793c76,%r82; sub.f64 %r144,%r75,%r143; sub.f64 %r145,%r144,%r65; neg.f64 %r146,%r145; fma.rn.f64 %r87,%r67,0d3fe62e42fee00000,%r146; bra $L1; $L10: sub.f64 %r147,%r65,%r74; mul.f64 %r85,%r147,%r66; .loc 1 141 0 setp.ne.u32 %r148,%r64,0; @ %r148 bra $L12; sub.f64 %r87,%r65,%r85; bra $L1; $L12: .loc 1 142 0 fma.rn.f64 %r150,%r67,0dbdea39ef35793c76,%r85; sub.f64 %r151,%r150,%r65; neg.f64 %r152,%r151; fma.rn.f64 %r87,%r67,0d3fe62e42fee00000,%r152; bra $L1; $L14: .loc 1 120 0 mov.f64 %r87,0d0000000000000000; $L1: .loc 1 144 0 mov.f64 %value,%r87; st.param.f64 [%value_out],%value; ret; } lib_a-e_log10.o/0 0 0 644 2889 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10 .visible .func (.param .f64 %value_out) __ieee754_log10 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_log10.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_log10 .visible .func (.param .f64 %value_out) __ieee754_log10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .f64 %r41; .reg .f64 %r42; .reg .u32 %r44; .reg .u64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .f64 %r58; .reg .pred %r59; .reg .f64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; mov.f64 %r49,%ar0; mov.b64 %r50,%r49; shr.u64 %r51,%r50,32; cvt.u32.u64 %r44,%r51; .loc 1 78 0 cvt.u32.u64 %r37,%r51; .loc 1 81 0 setp.gt.s32 %r52,%r44,1048575; @ %r52 bra $L7; .loc 1 82 0 and.b32 %r53,%r44,2147483647; cvt.u32.u64 %r56,%r50; or.b32 %r55,%r53,%r56; setp.ne.u32 %r57,%r55,0; @ %r57 bra $L3; .loc 1 83 0 mov.f64 %r58,0dc350000000000000; div.rn.f64 %r48,%r58,0d0000000000000000; bra $L1; $L3: .loc 1 84 0 setp.ge.s32 %r59,%r44,0; @ %r59 bra $L5; sub.f64 %r60,%r49,%r49; div.rn.f64 %r48,%r60,0d0000000000000000; bra $L1; $L5: .loc 1 85 0 mul.f64 %r49,%r49,0d4350000000000000; .loc 1 86 0 mov.b64 %r61,%r49; shr.u64 %r62,%r61,32; cvt.u32.u64 %r37,%r62; .loc 1 85 0 mov.u32 %r36,-54; bra $L2; $L7: .loc 1 80 0 mov.u32 %r36,0; $L2: .loc 1 88 0 setp.le.s32 %r63,%r37,2146435071; @ %r63 bra $L6; add.f64 %r48,%r49,%r49; bra $L1; $L6: .loc 1 89 0 shr.s32 %r64,%r37,20; add.u32 %r65,%r64,-1023; add.u32 %r38,%r65,%r36; .loc 1 90 0 shr.u32 %r39,%r38,31; .loc 1 91 0 and.b32 %r29,%r37,1048575; .loc 1 92 0 add.u32 %r66,%r38,%r39; cvt.rn.f64.s32 %r41,%r66; .loc 1 93 0 mov.b64 %r47,%r49; .loc 1 91 0 mov.u32 %r68,1023; sub.u32 %r67,%r68,%r39; shl.b32 %r69,%r67,20; or.b32 %r70,%r69,%r29; .loc 1 93 0 cvt.u64.u32 %r71,%r70; shl.b64 %r72,%r71,32; and.b64 %r73,%r47,4294967295; or.b64 %r74,%r73,%r72; mov.b64 %r42,%r74; .loc 1 94 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r76,[%value_in]; } mul.f64 %r77,%r76,0d3fdbcb7b1526e50e; fma.rn.f64 %r78,%r41,0d3d59fef311f12b36,%r77; .loc 1 95 0 fma.rn.f64 %r48,%r41,0d3fd34413509f6000,%r78; $L1: .loc 1 96 0 mov.f64 %value,%r48; st.param.f64 [%value_out],%value; ret; } lib_a-e_pow.o/ 0 0 0 644 20880 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __ieee754_pow .visible .func (.param .f64 %value_out) __ieee754_pow (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_pow.c" // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_pow .visible .func (.param .f64 %value_out) __ieee754_pow (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %r34; .reg .u32 %r39; .reg .f64 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .f64 %r54; .reg .u32 %r119; .reg .f64 %r133; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .u32 %r146; .reg .u32 %r147; .reg .u32 %r149; .reg .u32 %r150; .reg .u32 %r151; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .u32 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .f64 %r163; .reg .f64 %r164; .reg .f64 %r165; .reg .f64 %r167; .reg .f64 %r168; .reg .f64 %r169; .reg .f64 %r171; .reg .f64 %r173; .reg .f64 %r175; .reg .f64 %r177; .reg .f64 %r178; .reg .u32 %r180; .reg .u32 %r181; .reg .f64 %r183; .reg .f64 %r185; .reg .f64 %r187; .reg .f64 %r188; .reg .u32 %r190; .reg .u32 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .f64 %r195; .reg .f64 %r197; .reg .f64 %r198; .reg .f64 %r199; .reg .f64 %r200; .reg .f64 %r201; .reg .f64 %r202; .reg .f64 %r204; .reg .u32 %r205; .reg .u32 %r206; .reg .f64 %r211; .reg .f64 %r214; .reg .f64 %r216; .reg .u32 %r217; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .u64 %r238; .reg .f64 %r240; .reg .f64 %r241; .reg .f64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u32 %r246; .reg .pred %r247; .reg .u64 %r248; .reg .u64 %r249; .reg .pred %r251; .reg .u32 %r253; .reg .u32 %r254; .reg .u32 %r256; .reg .u32 %r257; .reg .u16 %r258; .reg .u16 %r259; .reg .u16 %r260; .reg .u32 %r261; .reg .u16 %r262; .reg .pred %r263; .reg .pred %r264; .reg .u32 %r266; .reg .u32 %r267; .reg .u32 %r269; .reg .u32 %r270; .reg .u16 %r271; .reg .u16 %r272; .reg .u16 %r273; .reg .u32 %r274; .reg .u16 %r275; .reg .pred %r276; .reg .u32 %r277; .reg .u32 %r278; .reg .pred %r279; .reg .u64 %r280; .reg .f64 %r281; .reg .pred %r282; .reg .pred %r283; .reg .pred %r284; .reg .u32 %r285; .reg .pred %r286; .reg .u32 %r287; .reg .u32 %r288; .reg .pred %r289; .reg .u32 %r290; .reg .u32 %r291; .reg .pred %r292; .reg .u32 %r293; .reg .u32 %r294; .reg .pred %r295; .reg .u32 %r296; .reg .u32 %r297; .reg .pred %r298; .reg .pred %r299; .reg .u32 %r300; .reg .u32 %r301; .reg .pred %r302; .reg .pred %r303; .reg .pred %r304; .reg .pred %r305; .reg .pred %r306; .reg .pred %r307; .reg .f64 %r308; .reg .pred %r309; .reg .u32 %r311; .reg .u32 %r312; .reg .u32 %r314; .reg .u32 %r315; .reg .u16 %r317; .reg .u16 %r318; .reg .u16 %r319; .reg .u32 %r320; .reg .u16 %r321; .reg .pred %r322; .reg .f64 %r324; .reg .f64 %r326; .reg .pred %r327; .reg .u32 %r328; .reg .u32 %r330; .reg .u32 %r331; .reg .u32 %r333; .reg .u32 %r334; .reg .u16 %r335; .reg .u16 %r336; .reg .u16 %r337; .reg .u32 %r338; .reg .u16 %r339; .reg .pred %r340; .reg .pred %r341; .reg .f64 %r342; .reg .pred %r343; .reg .u32 %r344; .reg .u32 %r345; .reg .pred %r346; .reg .pred %r347; .reg .u32 %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .pred %r353; .reg .pred %r354; .reg .f64 %r355; .reg .pred %r356; .reg .pred %r357; .reg .pred %r358; .reg .pred %r359; .reg .pred %r360; .reg .f64 %r361; .reg .f64 %r362; .reg .f64 %r363; .reg .f64 %r364; .reg .f64 %r365; .reg .f64 %r366; .reg .f64 %r367; .reg .f64 %r369; .reg .f64 %r370; .reg .u64 %r371; .reg .f64 %r373; .reg .pred %r374; .reg .u64 %r375; .reg .u64 %r376; .reg .u32 %r377; .reg .u32 %r378; .reg .pred %r379; .reg .pred %r380; .reg .u64 %r381; .reg .u64 %r382; .reg .u64 %r383; .reg .u64 %r384; .reg .f64 %r385; .reg .f64 %r386; .reg .u64 %r387; .reg .u32 %r388; .reg .u32 %r389; .reg .u32 %r390; .reg .u32 %r391; .reg .u64 %r392; .reg .u64 %r393; .reg .f64 %r396; .reg .f64 %r398; .reg .f64 %r399; .reg .f64 %r400; .reg .f64 %r401; .reg .f64 %r402; .reg .f64 %r403; .reg .f64 %r404; .reg .f64 %r405; .reg .f64 %r406; .reg .f64 %r407; .reg .f64 %r408; .reg .f64 %r409; .reg .f64 %r410; .reg .f64 %r411; .reg .u64 %r412; .reg .f64 %r414; .reg .f64 %r415; .reg .f64 %r416; .reg .f64 %r417; .reg .f64 %r418; .reg .f64 %r419; .reg .u64 %r420; .reg .f64 %r422; .reg .f64 %r423; .reg .f64 %r424; .reg .f64 %r425; .reg .f64 %r426; .reg .f64 %r427; .reg .f64 %r428; .reg .u64 %r429; .reg .f64 %r431; .reg .f64 %r432; .reg .f64 %r433; .reg .u32 %r434; .reg .u32 %r435; .reg .pred %r436; .reg .u64 %r437; .reg .f64 %r438; .reg .f64 %r439; .reg .u64 %r440; .reg .u64 %r441; .reg .pred %r443; .reg .u32 %r444; .reg .u32 %r445; .reg .pred %r446; .reg .f64 %r447; .reg .f64 %r448; .reg .f64 %r449; .reg .pred %r450; .reg .f64 %r451; .reg .u32 %r452; .reg .pred %r453; .reg .u32 %r454; .reg .u32 %r455; .reg .pred %r456; .reg .f64 %r457; .reg .f64 %r458; .reg .pred %r459; .reg .f64 %r460; .reg .pred %r461; .reg .u32 %r462; .reg .u32 %r463; .reg .u32 %r464; .reg .u32 %r465; .reg .u32 %r466; .reg .u32 %r467; .reg .u32 %r468; .reg .u32 %r469; .reg .u32 %r470; .reg .u32 %r471; .reg .u64 %r472; .reg .u64 %r473; .reg .u32 %r476; .reg .u32 %r477; .reg .u32 %r478; .reg .pred %r479; .reg .u64 %r481; .reg .f64 %r482; .reg .f64 %r483; .reg .f64 %r484; .reg .f64 %r486; .reg .f64 %r487; .reg .f64 %r488; .reg .f64 %r489; .reg .f64 %r490; .reg .f64 %r491; .reg .f64 %r492; .reg .f64 %r493; .reg .f64 %r494; .reg .f64 %r495; .reg .f64 %r496; .reg .f64 %r497; .reg .f64 %r498; .reg .u64 %r499; .reg .u64 %r500; .reg .u32 %r501; .reg .pred %r503; .reg .f64 %r506; .reg .u64 %r507; .reg .u64 %r508; .reg .u64 %r509; .reg .u64 %r510; .reg .f64 %r512; mov.f64 %r241,%ar0; mov.f64 %r242,%ar1; .loc 1 115 0 mov.b64 %r243,%r242; shr.u64 %r244,%r243,32; cvt.u32.u64 %r150,%r244; cvt.u32.u64 %r49,%r243; .loc 1 116 0 and.b32 %r151,%r150,2147483647; .loc 1 119 0 or.b32 %r246,%r151,%r49; setp.eq.u32 %r247,%r246,0; @ %r247 bra $L39; mov.b64 %r248,%r241; shr.u64 %r249,%r248,32; cvt.u32.u64 %r155,%r249; .loc 1 114 0 cvt.u32.u64 %r149,%r249; cvt.u32.u64 %r156,%r248; .loc 1 116 0 and.b32 %r146,%r155,2147483647; .loc 1 122 0 setp.gt.s32 %r251,%r146,2146435072; @ %r251 bra $L3; set.u32.eq.u32 %r253,%r146,2146435072; neg.s32 %r254,%r253; set.u32.ne.u32 %r256,%r156,0; neg.s32 %r257,%r256; cvt.u16.u32 %r259,%r254; cvt.u16.u32 %r260,%r257; and.b16 %r258,%r259,%r260; cvt.u32.u16 %r261,%r258; cvt.u16.u8 %r262,%r261; setp.ne.u16 %r263,%r262,0; @ %r263 bra $L4; setp.gt.s32 %r264,%r151,2146435072; @ %r264 bra $L3; .loc 1 123 0 set.u32.eq.u32 %r266,%r151,2146435072; neg.s32 %r267,%r266; set.u32.ne.u32 %r269,%r49,0; neg.s32 %r270,%r269; cvt.u16.u32 %r272,%r267; cvt.u16.u32 %r273,%r270; and.b16 %r271,%r272,%r273; cvt.u32.u16 %r274,%r271; cvt.u16.u8 %r275,%r274; setp.eq.u16 %r276,%r275,0; @ %r276 bra $L5; $L3: .loc 1 124 0 add.u32 %r277,%r146,-1072693248; or.b32 %r278,%r277,%r156; setp.eq.u32 %r279,%r278,0; @ %r279 bra $L40; $L4: .loc 1 125 0 cvta.const.u64 %r280,$LC0; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r280; call (%value_in),nan,(%out_arg1); ld.param.f64 %r281,[%value_in]; } mov.f64 %r240,%r281; bra $L1; $L5: .loc 1 134 0 setp.ge.s32 %r282,%r155,0; @ %r282 bra $L41; .loc 1 135 0 setp.gt.s32 %r283,%r151,1128267775; @ %r283 bra $L42; .loc 1 136 0 setp.le.s32 %r284,%r151,1072693247; @ %r284 bra $L43; .loc 1 137 0 shr.s32 %r285,%r151,20; add.u32 %r152,%r285,-1023; .loc 1 138 0 setp.le.s32 %r286,%r152,20; @ %r286 bra $L7; .loc 1 139 0 mov.u32 %r287,52; sub.u32 %r34,%r287,%r152; shr.u32 %r154,%r49,%r34; .loc 1 140 0 shl.b32 %r288,%r154,%r34; setp.ne.u32 %r289,%r288,%r49; @ %r289 bra $L44; and.b32 %r290,%r154,1; mov.u32 %r291,2; sub.u32 %r142,%r291,%r290; bra $L6; $L7: .loc 1 141 0 setp.ne.u32 %r292,%r49,0; @ %r292 bra $L45; .loc 1 142 0 mov.u32 %r293,20; sub.u32 %r39,%r293,%r152; shr.s32 %r153,%r151,%r39; .loc 1 143 0 shl.b32 %r294,%r153,%r39; setp.ne.u32 %r295,%r294,%r151; @ %r295 bra $L46; and.b32 %r296,%r153,1; mov.u32 %r297,2; sub.u32 %r142,%r297,%r296; bra $L10; $L41: .loc 1 133 0 mov.u32 %r142,0; bra $L6; $L42: .loc 1 135 0 mov.u32 %r142,2; bra $L6; $L43: .loc 1 133 0 mov.u32 %r142,0; bra $L6; $L44: mov.u32 %r142,0; $L6: .loc 1 149 0 setp.ne.u32 %r298,%r49,0; @ %r298 bra $L8; .loc 1 150 0 setp.ne.u32 %r299,%r151,2146435072; @ %r299 bra $L10; .loc 1 151 0 add.u32 %r300,%r146,-1072693248; or.b32 %r301,%r300,%r156; setp.eq.u32 %r302,%r301,0; @ %r302 bra $L47; .loc 1 153 0 setp.le.s32 %r303,%r146,1072693247; @ %r303 bra $L11; .loc 1 154 0 setp.ge.s32 %r304,%r150,0; @ %r304 bra $L48; $L12: mov.f64 %r240,0d0000000000000000; bra $L1; $L11: .loc 1 156 0 setp.ge.s32 %r305,%r150,0; @ %r305 bra $L12; neg.f64 %r240,%r242; bra $L1; $L10: .loc 1 158 0 setp.ne.u32 %r306,%r151,1072693248; @ %r306 bra $L13; .loc 1 159 0 setp.ge.s32 %r307,%r150,0; @ %r307 bra $L49; mov.f64 %r308,0d3ff0000000000000; div.rn.f64 %r240,%r308,%r241; bra $L1; $L13: .loc 1 161 0 setp.ne.u32 %r309,%r150,1073741824; @ %r309 bra $L14; mul.f64 %r240,%r241,%r241; bra $L1; $L14: .loc 1 162 0 set.u32.eq.u32 %r311,%r150,1071644672; neg.s32 %r312,%r311; .loc 1 163 0 not.b32 %r314,%r149; shr.u32 %r315,%r314,31; cvt.u16.u32 %r318,%r312; cvt.u16.u32 %r319,%r315; and.b16 %r317,%r318,%r319; cvt.u32.u16 %r320,%r317; cvt.u16.u8 %r321,%r320; setp.eq.u16 %r322,%r321,0; @ %r322 bra $L8; .loc 1 164 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r241; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r324,[%value_in]; } mov.f64 %r240,%r324; bra $L1; $L45: .loc 1 133 0 mov.u32 %r142,0; $L8: .loc 1 168 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r241; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r326,[%value_in]; } mov.f64 %r240,%r326; .loc 1 170 0 setp.ne.u32 %r327,%r156,0; @ %r327 bra $L15; .loc 1 171 0 and.b32 %r328,%r149,1073741823; set.u32.eq.u32 %r330,%r328,1072693248; neg.s32 %r331,%r330; set.u32.eq.u32 %r333,%r146,0; neg.s32 %r334,%r333; cvt.u16.u32 %r336,%r331; cvt.u16.u32 %r337,%r334; or.b16 %r335,%r336,%r337; cvt.u32.u16 %r338,%r335; cvt.u16.u8 %r339,%r338; setp.eq.u16 %r340,%r339,0; @ %r340 bra $L15; .loc 1 173 0 setp.ge.s32 %r341,%r150,0; @ %r341 bra $L16; mov.f64 %r342,0d3ff0000000000000; div.rn.f64 %r240,%r342,%r240; $L16: .loc 1 174 0 setp.ge.s32 %r343,%r149,0; @ %r343 bra $L1; .loc 1 175 0 add.u32 %r344,%r146,-1072693248; or.b32 %r345,%r344,%r142; setp.ne.u32 %r346,%r345,0; @ %r346 bra $L17; .loc 1 176 0 sub.f64 %r48,%r240,%r240; div.rn.f64 %r240,%r48,%r48; bra $L1; $L17: .loc 1 177 0 setp.ne.u32 %r347,%r142,1; @ %r347 bra $L1; .loc 1 178 0 neg.f64 %r240,%r240; bra $L1; $L15: .loc 1 189 0 set.u32.ge.s32 %r51,%r155,0; or.b32 %r349,%r142,%r51; setp.ne.u32 %r350,%r349,0; @ %r350 bra $L18; sub.f64 %r54,%r241,%r241; div.rn.f64 %r240,%r54,%r54; bra $L1; $L18: .loc 1 192 0 setp.le.s32 %r351,%r151,1105199104; @ %r351 bra $L19; .loc 1 193 0 setp.le.s32 %r352,%r151,1139802112; @ %r352 bra $L20; .loc 1 194 0 setp.gt.s32 %r353,%r146,1072693247; @ %r353 bra $L21; setp.ge.s32 %r354,%r150,0; @ %r354 bra $L12; $L22: mov.f64 %r355,0d7e37e43c8800759c; mul.f64 %r240,%r355,0d7e37e43c8800759c; bra $L1; $L21: .loc 1 195 0 setp.gt.s32 %r356,%r150,0; @ %r356 bra $L22; bra $L12; $L20: .loc 1 198 0 setp.gt.s32 %r357,%r146,1072693246; @ %r357 bra $L23; setp.lt.s32 %r358,%r150,0; @ ! %r358 bra $L12; bra $L22; $L23: .loc 1 199 0 setp.le.s32 %r359,%r146,1072693248; @ %r359 bra $L24; setp.gt.s32 %r360,%r150,0; @ %r360 bra $L22; bra $L12; $L24: .loc 1 202 0 mov.f64 %r361,0d3ff0000000000000; sub.f64 %r183,%r326,%r361; .loc 1 203 0 neg.f64 %r362,%r183; fma.rn.f64 %r363,%r362,0d3fd0000000000000,0d3fd5555555555555; neg.f64 %r364,%r363; fma.rn.f64 %r365,%r364,%r183,0d3fe0000000000000; mul.f64 %r366,%r183,%r183; mul.f64 %r367,%r365,%r366; .loc 1 205 0 mul.f64 %r369,%r367,0dbff71547652b82fe; fma.rn.f64 %r185,%r183,0d3e54ae0bf85ddf44,%r369; .loc 1 206 0 fma.rn.f64 %r370,%r183,0d3ff7154760000000,%r185; .loc 1 207 0 mov.b64 %r229,%r370; and.b64 %r371,%r229,-4294967296; mov.b64 %r139,%r371; .loc 1 208 0 fma.rn.f64 %r373,%r362,0d3ff7154760000000,%r139; sub.f64 %r140,%r185,%r373; bra $L25; $L19: .loc 1 213 0 setp.gt.s32 %r374,%r146,1048575; @ %r374 bra $L50; .loc 1 214 0 mul.f64 %r240,%r326,0d4340000000000000; mov.b64 %r375,%r240; shr.u64 %r376,%r375,32; cvt.u32.u64 %r146,%r376; mov.u32 %r143,-53; bra $L26; $L50: .loc 1 211 0 mov.u32 %r143,0; $L26: .loc 1 215 0 shr.s32 %r377,%r146,20; add.u32 %r378,%r377,-1023; add.u32 %r144,%r378,%r143; .loc 1 216 0 and.b32 %r159,%r146,1048575; .loc 1 218 0 or.b32 %r147,%r159,1072693248; .loc 1 219 0 setp.le.s32 %r379,%r159,235662; @ %r379 bra $L51; .loc 1 220 0 setp.le.s32 %r380,%r159,767609; @ %r380 bra $L52; .loc 1 221 0 add.u32 %r144,%r144,1; add.u32 %r147,%r147,-1048576; mov.f64 %r211,0d0000000000000000; mov.f64 %r216,%r211; mov.u32 %r217,0; mov.f64 %r214,0d3ff0000000000000; bra $L27; $L51: mov.f64 %r211,0d0000000000000000; mov.f64 %r216,%r211; mov.u32 %r217,0; mov.f64 %r214,0d3ff0000000000000; bra $L27; $L52: mov.f64 %r211,0d3fe2b80340000000; mov.f64 %r216,0d3e4cfdeb43cfd006; mov.u32 %r217,262144; mov.f64 %r214,0d3ff8000000000000; $L27: .loc 1 222 0 mov.b64 %r230,%r240; cvt.u64.u32 %r381,%r147; shl.b64 %r382,%r381,32; and.b64 %r383,%r230,4294967295; or.b64 %r384,%r383,%r382; mov.b64 %r160,%r384; .loc 1 225 0 sub.f64 %r161,%r160,%r214; .loc 1 226 0 add.f64 %r385,%r160,%r214; mov.f64 %r386,0d3ff0000000000000; div.rn.f64 %r162,%r386,%r385; .loc 1 227 0 mul.f64 %r163,%r161,%r162; .loc 1 229 0 mov.b64 %r231,%r163; and.b64 %r387,%r231,-4294967296; mov.b64 %r164,%r387; .loc 1 232 0 shr.s32 %r388,%r147,1; or.b32 %r389,%r388,536870912; add.u32 %r390,%r389,524288; add.u32 %r391,%r390,%r217; cvt.u64.u32 %r392,%r391; shl.b64 %r393,%r392,32; mov.b64 %r165,%r393; .loc 1 234 0 neg.f64 %r396,%r164; fma.rn.f64 %r398,%r396,%r165,%r161; .loc 1 233 0 sub.f64 %r399,%r165,%r214; sub.f64 %r400,%r160,%r399; .loc 1 234 0 fma.rn.f64 %r401,%r396,%r400,%r398; mul.f64 %r167,%r401,%r162; .loc 1 236 0 mul.f64 %r168,%r163,%r163; .loc 1 237 0 mul.f64 %r402,%r168,%r168; .loc 1 238 0 add.f64 %r403,%r163,%r164; mul.f64 %r404,%r403,%r167; .loc 1 237 0 fma.rn.f64 %r405,%r168,0d3fca7e284a454eef,0d3fcd864a93c9db65; fma.rn.f64 %r406,%r405,%r168,0d3fd17460a91d4101; fma.rn.f64 %r407,%r406,%r168,0d3fd55555518f264d; fma.rn.f64 %r408,%r407,%r168,0d3fdb6db6db6fabff; fma.rn.f64 %r409,%r408,%r168,0d3fe3333333333303; .loc 1 238 0 fma.rn.f64 %r169,%r402,%r409,%r404; .loc 1 240 0 fma.rn.f64 %r410,%r164,%r164,0d4008000000000000; add.f64 %r411,%r410,%r169; .loc 1 241 0 mov.b64 %r233,%r411; and.b64 %r412,%r233,-4294967296; mov.b64 %r171,%r412; .loc 1 242 0 mov.f64 %r415,0d4008000000000000; sub.f64 %r414,%r171,%r415; fma.rn.f64 %r416,%r396,%r164,%r414; sub.f64 %r417,%r169,%r416; .loc 1 245 0 mul.f64 %r418,%r417,%r163; fma.rn.f64 %r173,%r167,%r171,%r418; .loc 1 247 0 fma.rn.f64 %r419,%r164,%r171,%r173; .loc 1 248 0 mov.b64 %r234,%r419; and.b64 %r420,%r234,-4294967296; mov.b64 %r175,%r420; .loc 1 249 0 fma.rn.f64 %r422,%r396,%r171,%r175; sub.f64 %r423,%r173,%r422; .loc 1 251 0 mul.f64 %r424,%r423,0d3feec709dc3a03fd; fma.rn.f64 %r425,%r175,0dbe3e2fe0145b01f5,%r424; add.f64 %r177,%r425,%r216; .loc 1 253 0 cvt.rn.f64.s32 %r178,%r144; .loc 1 254 0 fma.rn.f64 %r426,%r175,0d3feec709e0000000,%r177; add.f64 %r427,%r426,%r211; add.f64 %r428,%r427,%r178; .loc 1 255 0 mov.b64 %r235,%r428; and.b64 %r429,%r235,-4294967296; mov.b64 %r139,%r429; .loc 1 256 0 sub.f64 %r431,%r139,%r178; sub.f64 %r432,%r431,%r211; fma.rn.f64 %r433,%r175,0dbfeec709e0000000,%r432; sub.f64 %r140,%r177,%r433; $L25: .loc 1 260 0 add.u32 %r434,%r142,-1; or.b32 %r435,%r434,%r51; setp.eq.u32 %r436,%r435,0; .loc 1 259 0 selp.f64 %r141,0dbff0000000000000,0d3ff0000000000000,%r436; .loc 1 265 0 mov.b64 %r236,%r242; and.b64 %r437,%r236,-4294967296; mov.b64 %r187,%r437; .loc 1 266 0 sub.f64 %r438,%r242,%r187; mul.f64 %r439,%r140,%r242; fma.rn.f64 %r188,%r438,%r139,%r439; .loc 1 267 0 mul.f64 %r138,%r139,%r187; .loc 1 268 0 add.f64 %r512,%r188,%r138; mov.b64 %r440,%r512; shr.u64 %r441,%r440,32; cvt.u32.u64 %r180,%r441; .loc 1 269 0 cvt.u32.u64 %r190,%r441; cvt.u32.u64 %r181,%r440; .loc 1 270 0 setp.le.s32 %r443,%r180,1083179007; @ %r443 bra $L29; .loc 1 271 0 add.u32 %r444,%r180,-1083179008; or.b32 %r445,%r444,%r181; setp.eq.u32 %r446,%r445,0; @ %r446 bra $L30; .loc 1 272 0 mul.f64 %r447,%r141,0d7e37e43c8800759c; mul.f64 %r240,%r447,0d7e37e43c8800759c; bra $L1; $L30: .loc 1 274 0 add.f64 %r448,%r188,0d3c971547652b82fe; sub.f64 %r449,%r512,%r138; setp.gt.f64 %r450,%r448,%r449; @ ! %r450 bra $L31; mul.f64 %r451,%r141,0d7e37e43c8800759c; mul.f64 %r240,%r451,0d7e37e43c8800759c; bra $L1; $L29: .loc 1 276 0 and.b32 %r452,%r180,2147483647; setp.le.s32 %r453,%r452,1083231231; @ %r453 bra $L31; .loc 1 277 0 add.u32 %r454,%r180,1064252416; or.b32 %r455,%r454,%r181; setp.eq.u32 %r456,%r455,0; @ %r456 bra $L33; .loc 1 278 0 mul.f64 %r457,%r141,0d01a56e1fc2f8f359; mul.f64 %r240,%r457,0d01a56e1fc2f8f359; bra $L1; $L33: .loc 1 280 0 sub.f64 %r458,%r512,%r138; setp.ge.f64 %r459,%r458,%r188; @ ! %r459 bra $L31; mul.f64 %r460,%r141,0d01a56e1fc2f8f359; mul.f64 %r240,%r460,0d01a56e1fc2f8f359; bra $L1; $L31: .loc 1 286 0 and.b32 %r192,%r190,2147483647; .loc 1 289 0 setp.le.s32 %r461,%r192,1071644672; @ %r461 bra $L54; .loc 1 287 0 shr.s32 %r462,%r192,20; .loc 1 290 0 add.u32 %r463,%r462,-1022; mov.u32 %r465,1048576; shr.s32 %r464,%r465,%r463; add.u32 %r193,%r464,%r190; .loc 1 291 0 shr.s32 %r466,%r193,20; and.b32 %r467,%r466,2047; add.u32 %r194,%r467,-1023; .loc 1 293 0 mov.u32 %r469,1048575; shr.s32 %r468,%r469,%r194; not.b32 %r470,%r468; and.b32 %r471,%r470,%r193; cvt.u64.u32 %r472,%r471; shl.b64 %r473,%r472,32; mov.b64 %r195,%r473; .loc 1 294 0 and.b32 %r476,%r193,1048575; or.b32 %r119,%r476,1048576; mov.u32 %r478,20; sub.u32 %r477,%r478,%r194; shr.s32 %r145,%r119,%r477; .loc 1 295 0 setp.ge.s32 %r479,%r190,0; @ %r479 bra $L36; neg.s32 %r145,%r145; $L36: .loc 1 296 0 sub.f64 %r138,%r138,%r195; add.f64 %r512,%r188,%r138; bra $L35; $L54: .loc 1 288 0 mov.u32 %r145,0; $L35: .loc 1 299 0 mov.b64 %r238,%r512; and.b64 %r481,%r238,-4294967296; mov.b64 %r197,%r481; .loc 1 301 0 sub.f64 %r482,%r197,%r138; sub.f64 %r483,%r188,%r482; mul.f64 %r484,%r197,0dbe205c610ca86c39; fma.rn.f64 %r198,%r483,0d3fe62e42fefa39ef,%r484; .loc 1 302 0 fma.rn.f64 %r199,%r197,0d3fe62e4300000000,%r198; .loc 1 303 0 fma.rn.f64 %r486,%r197,0dbfe62e4300000000,%r199; sub.f64 %r200,%r198,%r486; .loc 1 304 0 mul.f64 %r201,%r199,%r199; .loc 1 305 0 fma.rn.f64 %r487,%r201,0d3e66376972bea4d0,0dbebbbd41c5d26bf1; fma.rn.f64 %r488,%r487,%r201,0d3f11566aaf25de2c; fma.rn.f64 %r489,%r488,%r201,0dbf66c16c16bebd93; fma.rn.f64 %r490,%r489,%r201,0d3fc555555555553e; neg.f64 %r491,%r490; fma.rn.f64 %r202,%r491,%r201,%r199; .loc 1 306 0 mul.f64 %r492,%r199,%r202; mov.f64 %r494,0d4000000000000000; sub.f64 %r493,%r202,%r494; div.rn.f64 %r495,%r492,%r493; fma.rn.f64 %r496,%r199,%r200,%r200; sub.f64 %r497,%r495,%r496; .loc 1 307 0 sub.f64 %r133,%r497,%r199; mov.f64 %r498,0d3ff0000000000000; sub.f64 %r204,%r498,%r133; .loc 1 308 0 mov.b64 %r499,%r204; shr.u64 %r500,%r499,32; cvt.u32.u64 %r205,%r500; .loc 1 309 0 shl.b32 %r501,%r145,20; add.u32 %r206,%r501,%r205; .loc 1 310 0 setp.gt.s32 %r503,%r206,1048575; @ %r503 bra $L37; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r204; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r145; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r506,[%value_in]; } mov.f64 %r137,%r506; bra $L38; $L37: .loc 1 311 0 cvt.u64.u32 %r507,%r206; shl.b64 %r508,%r507,32; and.b64 %r509,%r499,4294967295; or.b64 %r510,%r509,%r508; mov.b64 %r137,%r510; $L38: .loc 1 312 0 mul.f64 %r240,%r137,%r141; bra $L1; $L39: .loc 1 119 0 mov.f64 %r240,0d3ff0000000000000; bra $L1; $L40: mov.f64 %r240,0d3ff0000000000000; bra $L1; $L47: mov.f64 %r240,0d3ff0000000000000; bra $L1; $L48: .loc 1 154 0 mov.f64 %r240,%r242; bra $L1; $L49: .loc 1 159 0 mov.f64 %r240,%r241; bra $L1; $L46: .loc 1 133 0 mov.u32 %r142,0; bra $L10; $L1: .loc 1 313 0 mov.f64 %value,%r240; st.param.f64 [%value_out],%value; ret; } /62 0 0 0 644 10120 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .visible .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2 .extern .func (.param .u32 %value_out) __kernel_rem_pio2 (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: npio2_hw .const .align 4 .u32 npio2_hw[32] = {1073291771,1074340347,1074977148,1075388923,1075800698,1076025724,1076231611,1076437499,1076643386,1076849274,1076971356,1077074300,1077177244,1077280187,1077383131,1077486075,1077589019,1077691962,1077794906,1077897850,1077968460,1078019932,1078071404,1078122876,1078174348,1078225820,1078277292,1078328763,1078380235,1078431707,1078483179,1078534651 }; // BEGIN VAR DEF: two_over_pi .const .align 4 .u32 two_over_pi[66] = {10680707,7228996,1387004,2578385,16069853,12639074,9804092,4427841,16666979,11263675,12935607,2387514,4345298,14681673,3074569,13734428,16653803,1880361,10960616,8533493,3062596,8710556,7349940,6258241,3772886,3769171,3798172,8675211,12450088,3874808,9961438,366607,15675153,9132554,7151469,3571407,2607881,12013382,4155038,6285869,7677882,13102053,15825725,473591,9065106,15363067,6271263,9264392,5636912,4652155,7056368,13614112,10155062,1944035,9527646,15080200,6658437,6231200,6832269,16767104,5075751,3212806,1398474,7579849,6349435,12618859 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_rem_pio2 .visible .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,24; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r22; .reg .f64 %r25; .reg .f64 %r28; .reg .u32 %r30; .reg .f64 %r32; .reg .u32 %r41; .reg .f64 %r54; .reg .f64 %r59; .reg .f64 %r64; .reg .f64 %r72; .reg .f64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .f64 %r78; .reg .f64 %r81; .reg .f64 %r84; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .u32 %r101; .reg .f64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .pred %r106; .reg .f64 %r107; .reg .pred %r108; .reg .pred %r109; .reg .f64 %r110; .reg .pred %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .f64 %r119; .reg .pred %r121; .reg .f64 %r122; .reg .f64 %r123; .reg .f64 %r124; .reg .f64 %r125; .reg .pred %r126; .reg .f64 %r128; .reg .f64 %r129; .reg .pred %r131; .reg .u64 %r132; .reg .u32 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .pred %r145; .reg .f64 %r148; .reg .f64 %r149; .reg .f64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .pred %r157; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .f64 %r163; .reg .pred %r164; .reg .f64 %r165; .reg .f64 %r166; .reg .pred %r167; .reg .u32 %r170; .reg .u32 %r173; .reg .u32 %r174; .reg .u32 %r175; .reg .u64 %r176; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r179; .reg .u32 %r180; .reg .u32 %r181; .reg .pred %r182; .reg .pred %r183; .reg .u32 %r188; .reg .u64 %r189; .reg .u32 %r190; .reg .pred %r191; .reg .f64 %r192; .reg .f64 %r193; .reg .f64 %r194; .reg .f64 %r195; .reg .f64 %r197; mov.f64 %r102,%ar0; mov.u64 %r103,%ar1; .loc 1 98 0 mov.b64 %r104,%r102; shr.u64 %r105,%r104,32; cvt.u32.u64 %r74,%r105; .loc 1 99 0 and.b32 %r75,%r74,2147483647; .loc 1 100 0 setp.gt.s32 %r106,%r75,1072243195; @ %r106 bra $L2; .loc 1 101 0 st.f64 [%r103],%r102; mov.f64 %r107,0d0000000000000000; st.f64 [%r103+8],%r107; mov.u32 %r101,0; bra $L1; $L2: .loc 1 102 0 setp.gt.s32 %r108,%r75,1073928571; @ %r108 bra $L4; .loc 1 103 0 setp.le.s32 %r109,%r74,0; @ %r109 bra $L5; .loc 1 104 0 mov.f64 %r110,0d3ff921fb54400000; sub.f64 %r88,%r102,%r110; .loc 1 105 0 setp.eq.u32 %r111,%r75,1073291771; @ %r111 bra $L6; .loc 1 106 0 mov.f64 %r112,0d3dd0b4611a626331; sub.f64 %r22,%r88,%r112; st.f64 [%r103],%r22; .loc 1 107 0 sub.f64 %r113,%r88,%r22; sub.f64 %r114,%r113,%r112; st.f64 [%r103+8],%r114; .loc 1 113 0 mov.u32 %r101,1; bra $L1; $L6: .loc 1 109 0 mov.f64 %r116,0d3dd0b4611a600000; sub.f64 %r89,%r88,%r116; .loc 1 110 0 mov.f64 %r117,0d3ba3198a2e037073; sub.f64 %r25,%r89,%r117; st.f64 [%r103],%r25; .loc 1 111 0 sub.f64 %r118,%r89,%r25; sub.f64 %r119,%r118,%r117; st.f64 [%r103+8],%r119; .loc 1 113 0 mov.u32 %r101,1; bra $L1; $L5: .loc 1 115 0 add.f64 %r86,%r102,0d3ff921fb54400000; .loc 1 116 0 setp.eq.u32 %r121,%r75,1073291771; @ %r121 bra $L7; .loc 1 117 0 add.f64 %r28,%r86,0d3dd0b4611a626331; st.f64 [%r103],%r28; .loc 1 118 0 sub.f64 %r122,%r86,%r28; add.f64 %r123,%r122,0d3dd0b4611a626331; st.f64 [%r103+8],%r123; .loc 1 124 0 mov.u32 %r101,-1; bra $L1; $L7: .loc 1 120 0 add.f64 %r87,%r86,0d3dd0b4611a600000; .loc 1 121 0 add.f64 %r32,%r87,0d3ba3198a2e037073; st.f64 [%r103],%r32; .loc 1 122 0 sub.f64 %r124,%r87,%r32; add.f64 %r125,%r124,0d3ba3198a2e037073; st.f64 [%r103+8],%r125; .loc 1 124 0 mov.u32 %r101,-1; bra $L1; $L4: .loc 1 127 0 setp.gt.s32 %r126,%r75,1094263291; @ %r126 bra $L8; .loc 1 128 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r102; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r128,[%value_in]; } .loc 1 129 0 fma.rn.f64 %r129,%r128,0d3fe45f306dc9c883,0d3fe0000000000000; cvt.rzi.s32.f64 %r101,%r129; .loc 1 130 0 cvt.rn.f64.s32 %r81,%r101; .loc 1 131 0 neg.f64 %r197,%r81; fma.rn.f64 %r73,%r197,0d3ff921fb54400000,%r128; .loc 1 132 0 mul.f64 %r72,%r81,0d3dd0b4611a626331; .loc 1 133 0 setp.gt.s32 %r131,%r101,31; @ %r131 bra $L9; sub.f64 %r64,%r73,%r72; cvta.const.u64 %r132,npio2_hw; add.u32 %r133,%r101,-1; cvt.s64.s32 %r134,%r133; shl.b64 %r135,%r134,2; add.u64 %r136,%r132,%r135; ld.u32 %r137,[%r136]; setp.eq.u32 %r138,%r137,%r75; @ %r138 bra $L10; .loc 1 134 0 st.f64 [%r103],%r64; bra $L11; $L9: sub.f64 %r64,%r73,%r72; $L10: .loc 1 137 0 shr.s32 %r41,%r75,20; .loc 1 140 0 mov.b64 %r139,%r64; shr.u64 %r140,%r139,32; cvt.u32.u64 %r142,%r140; shr.u32 %r141,%r142,20; and.b32 %r143,%r141,2047; sub.u32 %r144,%r41,%r143; .loc 1 141 0 setp.gt.s32 %r145,%r144,16; @ %r145 bra $L12; .loc 1 138 0 st.f64 [%r103],%r64; bra $L11; $L12: .loc 1 144 0 fma.rn.f64 %r84,%r197,0d3dd0b4611a600000,%r73; .loc 1 145 0 sub.f64 %r148,%r73,%r84; fma.rn.f64 %r149,%r197,0d3dd0b4611a600000,%r148; neg.f64 %r150,%r149; fma.rn.f64 %r72,%r81,0d3ba3198a2e037073,%r150; .loc 1 146 0 sub.f64 %r64,%r84,%r72; .loc 1 148 0 mov.b64 %r151,%r64; shr.u64 %r152,%r151,32; cvt.u32.u64 %r154,%r152; shr.u32 %r153,%r154,20; and.b32 %r155,%r153,2047; sub.u32 %r156,%r41,%r155; .loc 1 149 0 setp.gt.s32 %r157,%r156,49; @ %r157 bra $L13; .loc 1 146 0 st.f64 [%r103],%r64; .loc 1 144 0 mov.f64 %r73,%r84; bra $L11; $L13: .loc 1 152 0 fma.rn.f64 %r73,%r197,0d3ba3198a2e000000,%r84; .loc 1 153 0 sub.f64 %r160,%r84,%r73; fma.rn.f64 %r161,%r197,0d3ba3198a2e000000,%r160; neg.f64 %r162,%r161; fma.rn.f64 %r72,%r81,0d397b839a252049c1,%r162; .loc 1 154 0 sub.f64 %r64,%r73,%r72; st.f64 [%r103],%r64; $L11: .loc 1 158 0 sub.f64 %r163,%r73,%r64; sub.f64 %r54,%r163,%r72; st.f64 [%r103+8],%r54; .loc 1 159 0 setp.ge.s32 %r164,%r74,0; @ %r164 bra $L1; neg.f64 %r165,%r64; st.f64 [%r103],%r165; neg.f64 %r166,%r54; st.f64 [%r103+8],%r166; neg.s32 %r101,%r101; bra $L1; $L8: .loc 1 165 0 setp.le.s32 %r167,%r75,2146435071; @ %r167 bra $L14; .loc 1 166 0 sub.f64 %r59,%r102,%r102; st.f64 [%r103+8],%r59; st.f64 [%r103],%r59; mov.u32 %r101,0; bra $L1; $L14: .loc 1 170 0 cvt.u32.u64 %r170,%r104; .loc 1 171 0 shr.s32 %r173,%r75,20; add.u32 %r77,%r173,-1046; .loc 1 172 0 shl.b32 %r174,%r77,20; sub.u32 %r175,%r75,%r174; cvt.u64.u32 %r176,%r175; shl.b64 %r177,%r176,32; cvt.u64.u32 %r178,%r170; or.b64 %r179,%r178,%r177; mov.b64 %r78,%r179; .loc 1 174 0 cvt.rzi.s32.f64 %r180,%r78; cvt.rn.f64.s32 %r92,%r180; st.f64 [%frame],%r92; .loc 1 175 0 sub.f64 %r93,%r78,%r92; mul.f64 %r94,%r93,0d4170000000000000; .loc 1 174 0 cvt.rzi.s32.f64 %r181,%r94; cvt.rn.f64.s32 %r96,%r181; st.f64 [%frame+8],%r96; .loc 1 175 0 sub.f64 %r97,%r94,%r96; mul.f64 %r98,%r97,0d4170000000000000; .loc 1 177 0 st.f64 [%frame+16],%r98; .loc 1 179 0 setp.neu.f64 %r182,%r98,0d0000000000000000; @ %r182 bra $L16; setp.eq.f64 %r183,%r96,0d0000000000000000; selp.u32 %r30,1,2,%r183; bra $L15; $L16: .loc 1 178 0 mov.u32 %r30,3; $L15: .loc 1 180 0 cvta.const.u64 %r189,two_over_pi; mov.u32 %r188,2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r103; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r77; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r30; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r188; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r189; call (%value_in),__kernel_rem_pio2,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u32 %r190,[%value_in]; } mov.u32 %r101,%r190; .loc 1 181 0 setp.ge.s32 %r191,%r74,0; @ %r191 bra $L1; ld.f64 %r193,[%r103]; neg.f64 %r192,%r193; st.f64 [%r103],%r192; ld.f64 %r195,[%r103+8]; neg.f64 %r194,%r195; st.f64 [%r103+8],%r194; neg.s32 %r101,%r101; $L1: .loc 1 183 0 mov.u32 %value,%r101; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } /82 0 0 0 644 4203 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainder .visible .func (.param .f64 %value_out) __ieee754_remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_remainder.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmod .extern .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_remainder .visible .func (.param .f64 %value_out) __ieee754_remainder (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .f64 %r28; .reg .f64 %r37; .reg .f64 %r38; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .f64 %r45; .reg .u32 %r46; .reg .u32 %r49; .reg .u64 %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .pred %r66; .reg .pred %r67; .reg .f64 %r70; .reg .f64 %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .f64 %r79; .reg .f64 %r81; .reg .pred %r82; .reg .f64 %r83; .reg .pred %r84; .reg .f64 %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .u32 %r89; .reg .u64 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; mov.f64 %r53,%ar0; mov.f64 %r54,%ar1; .loc 1 46 0 mov.b64 %r55,%r54; shr.u64 %r56,%r55,32; cvt.u32.u64 %r40,%r56; cvt.u32.u64 %r49,%r55; .loc 1 48 0 and.b32 %r42,%r40,2147483647; .loc 1 52 0 or.b32 %r58,%r42,%r49; setp.ne.u32 %r59,%r58,0; @ %r59 bra $L2; mul.f64 %r24,%r53,%r54; div.rn.f64 %r52,%r24,%r24; bra $L1; $L2: mov.b64 %r60,%r53; shr.u64 %r61,%r60,32; cvt.u32.u64 %r46,%r61; .loc 1 49 0 and.b32 %r43,%r46,2147483647; .loc 1 53 0 setp.gt.s32 %r62,%r43,2146435071; @ %r62 bra $L4; setp.le.s32 %r63,%r42,2146435071; @ %r63 bra $L5; .loc 1 55 0 add.u32 %r64,%r42,-2146435072; or.b32 %r65,%r64,%r49; .loc 1 54 0 setp.eq.u32 %r66,%r65,0; @ %r66 bra $L14; $L4: .loc 1 56 0 mul.f64 %r28,%r53,%r54; div.rn.f64 %r52,%r28,%r28; bra $L1; $L5: .loc 1 59 0 setp.gt.s32 %r67,%r42,2145386495; @ %r67 bra $L15; add.f64 %r70,%r54,%r54; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r53; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r70; call (%value_in),__ieee754_fmod,(%out_arg1,%out_arg2); ld.param.f64 %r71,[%value_in]; } mov.f64 %r37,%r71; bra $L6; $L14: mov.f64 %r37,%r53; bra $L6; $L15: mov.f64 %r37,%r53; $L6: .loc 1 60 0 sub.u32 %r72,%r43,%r42; mov.b64 %r73,%r53; cvt.u32.u64 %r75,%r73; sub.u32 %r74,%r75,%r49; or.b32 %r76,%r72,%r74; setp.ne.u32 %r77,%r76,0; @ %r77 bra $L7; mul.f64 %r52,%r37,0d0000000000000000; bra $L1; $L7: .loc 1 61 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r79,[%value_in]; } mov.f64 %r38,%r79; .loc 1 62 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r54; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r81,[%value_in]; } .loc 1 63 0 setp.gt.s32 %r82,%r42,2097151; @ %r82 bra $L8; .loc 1 64 0 add.f64 %r83,%r38,%r38; setp.gt.f64 %r84,%r83,%r81; @ ! %r84 bra $L9; .loc 1 65 0 sub.f64 %r38,%r38,%r81; .loc 1 66 0 add.f64 %r85,%r38,%r38; setp.ge.f64 %r86,%r85,%r81; @ ! %r86 bra $L9; sub.f64 %r38,%r38,%r81; bra $L9; $L8: .loc 1 69 0 mul.f64 %r45,%r81,0d3fe0000000000000; .loc 1 70 0 setp.gt.f64 %r87,%r38,%r45; @ ! %r87 bra $L9; .loc 1 71 0 sub.f64 %r38,%r38,%r81; .loc 1 72 0 setp.le.f64 %r88,%r45,%r38; @ ! %r88 bra $L9; sub.f64 %r38,%r38,%r81; $L9: .loc 1 76 0 mov.b64 %r51,%r38; .loc 1 47 0 and.b32 %r89,%r46,-2147483648; .loc 1 76 0 shr.u64 %r91,%r51,32; cvt.u32.u64 %r93,%r91; xor.b32 %r92,%r89,%r93; cvt.u64.u32 %r94,%r92; shl.b64 %r95,%r94,32; and.b64 %r96,%r51,4294967295; or.b64 %r97,%r96,%r95; mov.b64 %r52,%r97; $L1: .loc 1 78 0 mov.f64 %value,%r52; st.param.f64 [%value_out],%value; ret; } lib_a-e_scalb.o/0 0 0 644 3489 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalb .visible .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/e_scalb.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: __ieee754_scalb .visible .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r27; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r31; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f64 %r42; .reg .f64 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u32 %r48; .reg .f64 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .f64 %r53; .reg .u32 %r56; .reg .f64 %r57; mov.f64 %r30,%ar0; mov.f64 %r31,%ar1; .loc 1 43 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r33,[%value_in]; } setp.ne.u32 %r34,%r33,0; @ ! %r34 bra $L3; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r36,[%value_in]; } setp.eq.u32 %r37,%r36,0; @ ! %r37 bra $L18; $L3: mul.f64 %r29,%r30,%r31; bra $L1; $L18: .loc 1 44 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),finite,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.ne.u32 %r40,%r39,0; @ %r40 bra $L7; .loc 1 45 0 setp.gt.f64 %r41,%r31,0d0000000000000000; @ %r41 bra $L3; .loc 1 46 0 neg.f64 %r42,%r31; div.rn.f64 %r29,%r30,%r42; bra $L1; $L7: .loc 1 48 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r31; call (%value_in),rint,(%out_arg1); ld.param.f64 %r44,[%value_in]; } setp.eq.f64 %r45,%r44,%r31; @ %r45 bra $L8; sub.f64 %r27,%r31,%r31; div.rn.f64 %r29,%r27,%r27; bra $L1; $L8: .loc 1 49 0 setp.gt.f64 %r46,%r31,0d40efbd0000000000; @ ! %r46 bra $L19; mov.u32 %r48,65000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r49,[%value_in]; } mov.f64 %r29,%r49; bra $L1; $L19: .loc 1 50 0 setp.lt.f64 %r50,%r31,0dc0efbd0000000000; @ ! %r50 bra $L20; mov.u32 %r52,-65000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r52; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r53,[%value_in]; } mov.f64 %r29,%r53; bra $L1; $L20: .loc 1 51 0 cvt.rzi.s32.f64 %r56,%r31; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r56; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r57,[%value_in]; } mov.f64 %r29,%r57; $L1: .loc 1 53 0 mov.f64 %value,%r29; st.param.f64 [%value_out],%value; ret; } lib_a-e_sinh.o/ 0 0 0 644 4556 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinh .visible .func (.param .f64 %value_out) __ieee754_sinh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_sinh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_sinh .visible .func (.param .f64 %value_out) __ieee754_sinh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .f64 %r56; .reg .pred %r57; .reg .f64 %r59; .reg .f64 %r61; .reg .pred %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .pred %r71; .reg .f64 %r73; .reg .f64 %r75; .reg .pred %r76; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u32 %r88; .reg .u16 %r89; .reg .pred %r90; .reg .f64 %r92; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r99; .reg .f64 %r101; mov.f64 %r49,%ar0; .loc 1 54 0 mov.b64 %r50,%r49; shr.u64 %r51,%r50,32; cvt.u32.u64 %r39,%r51; .loc 1 55 0 and.b32 %r40,%r39,2147483647; .loc 1 58 0 setp.le.s32 %r52,%r40,2146435071; @ %r52 bra $L2; add.f64 %r48,%r49,%r49; bra $L1; $L2: .loc 1 61 0 setp.ge.s32 %r53,%r39,0; selp.f64 %r38,0d3fe0000000000000,0dbfe0000000000000,%r53; .loc 1 63 0 setp.gt.s32 %r54,%r40,1077280767; @ %r54 bra $L5; .loc 1 64 0 setp.gt.s32 %r55,%r40,1043333119; @ %r55 bra $L6; .loc 1 65 0 add.f64 %r56,%r49,0d7fac7b1f3cac7433; setp.gt.f64 %r57,%r56,0d3ff0000000000000; @ %r57 bra $L14; bra $L15; $L6: .loc 1 66 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r59,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r61,[%value_in]; } mov.f64 %r47,%r61; .loc 1 67 0 setp.gt.s32 %r62,%r40,1072693247; @ %r62 bra $L8; $L12: mul.f64 %r63,%r47,%r47; add.f64 %r64,%r47,0d3ff0000000000000; div.rn.f64 %r65,%r63,%r64; neg.f64 %r66,%r65; fma.rn.f64 %r67,%r47,0d4000000000000000,%r66; mul.f64 %r48,%r67,%r38; bra $L1; $L8: .loc 1 68 0 add.f64 %r68,%r61,0d3ff0000000000000; div.rn.f64 %r69,%r61,%r68; add.f64 %r70,%r69,%r61; mul.f64 %r48,%r70,%r38; bra $L1; $L5: .loc 1 72 0 setp.gt.s32 %r71,%r40,1082535489; @ %r71 bra $L9; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r73,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r73; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r75,[%value_in]; } mul.f64 %r48,%r75,%r38; bra $L1; $L9: .loc 1 76 0 setp.le.s32 %r76,%r40,1082536909; @ %r76 bra $L10; set.u32.eq.u32 %r78,%r40,1082536910; neg.s32 %r79,%r78; cvt.u32.u64 %r82,%r50; set.u32.le.u32 %r83,%r82,-1883637635; neg.s32 %r84,%r83; cvt.u16.u32 %r86,%r79; cvt.u16.u32 %r87,%r84; and.b16 %r85,%r86,%r87; cvt.u32.u16 %r88,%r85; cvt.u16.u8 %r89,%r88; setp.eq.u16 %r90,%r89,0; @ %r90 bra $L11; $L10: .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r92,[%value_in]; } mul.f64 %r94,%r92,0d3fe0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r94; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r95,[%value_in]; } .loc 1 78 0 mul.f64 %r96,%r38,%r95; .loc 1 79 0 mul.f64 %r48,%r96,%r95; bra $L1; $L11: .loc 1 83 0 mul.f64 %r48,%r49,0d7fac7b1f3cac7433; bra $L1; $L14: .loc 1 65 0 mov.f64 %r48,%r49; bra $L1; $L15: .loc 1 66 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r99,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r99; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r101,[%value_in]; } mov.f64 %r47,%r101; bra $L12; $L1: .loc 1 84 0 mov.f64 %value,%r48; st.param.f64 [%value_out],%value; ret; } lib_a-e_sqrt.o/ 0 0 0 644 6400 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .visible .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/e_sqrt.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_sqrt .visible .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r38; .reg .u32 %r44; .reg .u32 %r49; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r85; .reg .u32 %r87; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r102; .reg .f64 %r106; .reg .f64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u32 %r110; .reg .pred %r111; .reg .pred %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r121; .reg .pred %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r129; .reg .pred %r130; .reg .u32 %r132; .reg .u32 %r133; .reg .pred %r134; .reg .u32 %r135; .reg .u32 %r136; .reg .pred %r138; .reg .pred %r139; .reg .u32 %r141; .reg .u32 %r142; .reg .u32 %r144; .reg .u32 %r145; .reg .u16 %r146; .reg .u16 %r147; .reg .u16 %r148; .reg .u32 %r149; .reg .u16 %r150; .reg .pred %r151; .reg .pred %r152; .reg .pred %r153; .reg .pred %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .pred %r158; .reg .u32 %r159; .reg .pred %r160; .reg .pred %r161; .reg .u32 %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .pred %r165; .reg .u32 %r166; .reg .u32 %r167; .reg .u64 %r168; .reg .u64 %r172; .reg .u64 %r173; .reg .u64 %r174; .reg .pred %r176; mov.f64 %r107,%ar0; .loc 1 106 0 mov.b64 %r108,%r107; shr.u64 %r109,%r108,32; cvt.u32.u64 %r68,%r109; .loc 1 109 0 and.b32 %r110,%r68,2146435072; setp.ne.u32 %r111,%r110,2146435072; @ %r111 bra $L2; .loc 1 110 0 fma.rn.f64 %r106,%r107,%r107,%r107; bra $L1; $L2: cvt.u32.u64 %r67,%r108; .loc 1 114 0 setp.gt.s32 %r113,%r68,0; @ %r113 bra $L4; .loc 1 115 0 and.b32 %r114,%r68,2147483647; or.b32 %r115,%r114,%r67; setp.eq.u32 %r116,%r115,0; @ %r116 bra $L22; .loc 1 116 0 setp.eq.u32 %r117,%r68,0; @ %r117 bra $L23; .loc 1 117 0 sub.f64 %r38,%r107,%r107; div.rn.f64 %r106,%r38,%r38; bra $L1; $L23: .loc 1 106 0 cvt.u32.u64 %r82,%r108; $L5: .loc 1 123 0 add.u32 %r68,%r68,-21; .loc 1 124 0 shr.u32 %r80,%r82,11; shl.b32 %r82,%r82,21; .loc 1 122 0 setp.eq.u32 %r118,%r80,0; @ %r118 bra $L5; bra $L20; $L28: .loc 1 121 0 cvt.u32.u64 %r80,%r109; .loc 1 120 0 mov.u32 %r68,%r77; .loc 1 106 0 cvt.u32.u64 %r82,%r108; $L20: .loc 1 126 0 and.b32 %r74,%r80,1048576; setp.ne.u32 %r119,%r74,0; @ ! %r119 bra $L7; bra $L24; $L25: mov.u32 %r74,%r81; $L7: add.u32 %r80,%r80,%r80; add.u32 %r81,%r74,1; and.b32 %r121,%r80,1048576; setp.eq.u32 %r122,%r121,0; @ %r122 bra $L25; mov.u32 %r123,32; sub.u32 %r102,%r123,%r81; shl.b32 %r67,%r82,%r81; bra $L6; $L24: mov.u32 %r67,%r82; mov.u32 %r102,32; mov.u32 %r74,-1; $L6: .loc 1 127 0 sub.u32 %r77,%r68,%r74; .loc 1 128 0 shr.u32 %r124,%r82,%r102; or.b32 %r68,%r124,%r80; $L21: .loc 1 131 0 add.u32 %r83,%r77,-1023; .loc 1 132 0 and.b32 %r44,%r68,1048575; or.b32 %r125,%r44,1048576; add.u32 %r126,%r125,%r125; shr.u32 %r127,%r67,31; add.u32 %r72,%r126,%r127; add.u32 %r69,%r67,%r67; .loc 1 133 0 and.b32 %r129,%r83,1; setp.eq.u32 %r130,%r129,0; @ %r130 bra $L8; add.u32 %r132,%r72,%r72; shr.u32 %r133,%r69,31; add.u32 %r72,%r132,%r133; shl.b32 %r69,%r69,1; $L8: .loc 1 137 0 shr.s32 %r85,%r83,1; mov.u32 %r94,22; .loc 1 142 0 mov.u32 %r76,0; mov.u32 %r73,%r76; .loc 1 143 0 mov.u32 %r92,2097152; $L10: .loc 1 146 0 add.u32 %r49,%r73,%r92; .loc 1 147 0 setp.gt.s32 %r134,%r49,%r72; @ %r134 bra $L9; .loc 1 148 0 add.u32 %r73,%r49,%r92; .loc 1 149 0 sub.u32 %r72,%r72,%r49; .loc 1 150 0 add.u32 %r76,%r76,%r92; $L9: .loc 1 152 0 add.u32 %r135,%r72,%r72; shr.u32 %r136,%r69,31; add.u32 %r72,%r135,%r136; .loc 1 153 0 add.u32 %r69,%r69,%r69; .loc 1 154 0 shr.u32 %r92,%r92,1; add.u32 %r94,%r94,-1; .loc 1 145 0 setp.ne.u32 %r138,%r94,0; @ %r138 bra $L10; mov.u32 %r95,32; .loc 1 142 0 mov.u32 %r71,%r94; mov.u32 %r66,%r71; .loc 1 157 0 mov.u32 %r90,-2147483648; $L15: .loc 1 159 0 add.u32 %r89,%r90,%r66; .loc 1 161 0 setp.gt.s32 %r139,%r72,%r73; @ %r139 bra $L11; set.u32.eq.u32 %r141,%r72,%r73; neg.s32 %r142,%r141; set.u32.le.u32 %r144,%r89,%r69; neg.s32 %r145,%r144; cvt.u16.u32 %r147,%r142; cvt.u16.u32 %r148,%r145; and.b16 %r146,%r147,%r148; cvt.u32.u16 %r149,%r146; cvt.u16.u8 %r150,%r149; setp.eq.u16 %r151,%r150,0; @ %r151 bra $L12; $L11: .loc 1 162 0 add.u32 %r66,%r89,%r90; .loc 1 163 0 setp.ge.s32 %r152,%r89,0; @ %r152 bra $L26; setp.lt.s32 %r153,%r66,0; @ %r153 bra $L27; add.u32 %r75,%r73,1; bra $L13; $L26: mov.u32 %r75,%r73; bra $L13; $L27: mov.u32 %r75,%r73; $L13: .loc 1 164 0 sub.u32 %r72,%r72,%r73; .loc 1 165 0 setp.le.u32 %r154,%r89,%r69; @ %r154 bra $L14; add.u32 %r72,%r72,-1; $L14: .loc 1 166 0 sub.u32 %r69,%r69,%r89; .loc 1 167 0 add.u32 %r71,%r71,%r90; mov.u32 %r73,%r75; $L12: .loc 1 169 0 shr.u32 %r155,%r69,31; add.u32 %r156,%r72,%r72; add.u32 %r72,%r155,%r156; .loc 1 170 0 add.u32 %r69,%r69,%r69; .loc 1 171 0 shr.u32 %r90,%r90,1; add.u32 %r95,%r95,-1; .loc 1 158 0 setp.ne.u32 %r158,%r95,0; @ %r158 bra $L15; .loc 1 175 0 or.b32 %r159,%r72,%r69; setp.ne.u32 %r160,%r159,0; @ %r160 bra $L16; shr.u32 %r70,%r71,1; bra $L17; $L16: .loc 1 179 0 setp.ne.u32 %r161,%r71,-1; @ %r161 bra $L18; add.u32 %r76,%r76,1; mov.u32 %r70,%r95; bra $L17; $L18: .loc 1 184 0 add.u32 %r162,%r71,1; shr.u32 %r70,%r162,1; $L17: .loc 1 187 0 shr.s32 %r163,%r76,1; add.u32 %r87,%r163,1071644672; .loc 1 189 0 and.b32 %r164,%r76,1; setp.eq.u32 %r165,%r164,0; @ %r165 bra $L19; or.b32 %r70,%r70,-2147483648; $L19: .loc 1 190 0 shl.b32 %r166,%r85,20; add.u32 %r167,%r166,%r87; .loc 1 191 0 cvt.u64.u32 %r168,%r167; cvt.u64.u32 %r172,%r70; shl.b64 %r173,%r168,32; or.b64 %r174,%r173,%r172; mov.b64 %r106,%r174; .loc 1 192 0 bra $L1; $L22: .loc 1 115 0 mov.f64 %r106,%r107; bra $L1; $L4: .loc 1 120 0 shr.s32 %r77,%r68,20; .loc 1 121 0 setp.eq.u32 %r176,%r77,0; @ ! %r176 bra $L21; bra $L28; $L1: .loc 1 193 0 mov.f64 %value,%r106; st.param.f64 [%value_out],%value; ret; } lib_a-ef_acos.o/0 0 0 644 4982 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosf .visible .func (.param .f32 %value_out) __ieee754_acosf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_acos.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acosf .visible .func (.param .f32 %value_out) __ieee754_acosf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .u32 %r57; .reg .u32 %r58; .reg .f32 %r59; .reg .f32 %r62; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r74; .reg .f32 %r94; .reg .f32 %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r113; .reg .f32 %r114; .reg .f32 %r115; .reg .pred %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .f32 %r127; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .f32 %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r152; .reg .f32 %r153; .reg .f32 %r154; mov.f32 %r95,%ar0; .loc 1 47 0 mov.b32 %r57,%r95; .loc 1 48 0 and.b32 %r58,%r57,2147483647; .loc 1 49 0 setp.ne.u32 %r96,%r58,1065353216; @ %r96 bra $L2; .loc 1 50 0 setp.gt.s32 %r97,%r57,0; .loc 1 51 0 selp.f32 %r94,0f00000000,0f40490fdb,%r97; bra $L1; $L2: .loc 1 52 0 setp.le.s32 %r98,%r58,1065353216; @ %r98 bra $L4; .loc 1 53 0 sub.f32 %r22,%r95,%r95; div.rn.f32 %r94,%r22,%r22; bra $L1; $L4: .loc 1 55 0 setp.gt.s32 %r99,%r58,1056964607; @ %r99 bra $L5; .loc 1 56 0 setp.le.s32 %r100,%r58,587202560; @ %r100 bra $L8; .loc 1 57 0 mul.f32 %r74,%r95,%r95; .loc 1 61 0 neg.f32 %r101,%r95; .loc 1 58 0 fma.rn.f32 %r102,%r74,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r103,%r102,%r74,0fbd241146; fma.rn.f32 %r104,%r103,%r74,0f3e4e0aa8; fma.rn.f32 %r105,%r104,%r74,0fbea6b090; fma.rn.f32 %r106,%r105,%r74,0f3e2aaaab; mul.f32 %r107,%r106,%r74; .loc 1 59 0 fma.rn.f32 %r108,%r74,0f3d9dc62e,0fbf303361; fma.rn.f32 %r109,%r108,%r74,0f4001572d; fma.rn.f32 %r110,%r109,%r74,0fc019d139; fma.rn.f32 %r111,%r110,%r74,0f3f800000; .loc 1 60 0 div.rn.f32 %r112,%r107,%r111; .loc 1 61 0 fma.rn.f32 %r113,%r101,%r112,0f33a22168; sub.f32 %r114,%r95,%r113; mov.f32 %r115,0f3fc90fda; sub.f32 %r94,%r115,%r114; bra $L1; $L5: .loc 1 62 0 setp.ge.s32 %r116,%r57,0; @ %r116 bra $L6; .loc 1 63 0 add.f32 %r117,%r95,0f3f800000; mul.f32 %r68,%r117,0f3f000000; .loc 1 64 0 fma.rn.f32 %r118,%r68,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r119,%r118,%r68,0fbd241146; fma.rn.f32 %r120,%r119,%r68,0f3e4e0aa8; fma.rn.f32 %r121,%r120,%r68,0fbea6b090; fma.rn.f32 %r122,%r121,%r68,0f3e2aaaab; mul.f32 %r69,%r122,%r68; .loc 1 65 0 fma.rn.f32 %r123,%r68,0f3d9dc62e,0fbf303361; fma.rn.f32 %r124,%r123,%r68,0f4001572d; fma.rn.f32 %r125,%r124,%r68,0fc019d139; fma.rn.f32 %r70,%r125,%r68,0f3f800000; .loc 1 66 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r127,[%value_in]; } .loc 1 67 0 div.rn.f32 %r128,%r69,%r70; .loc 1 68 0 fma.rn.f32 %r129,%r127,%r128,0fb3a22168; .loc 1 69 0 add.f32 %r130,%r129,%r127; fma.rn.f32 %r94,%r130,0fc0000000,0f40490fda; bra $L1; $L6: .loc 1 72 0 mov.f32 %r133,0f3f800000; sub.f32 %r132,%r133,%r95; mul.f32 %r59,%r132,0f3f000000; .loc 1 73 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r59; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r135,[%value_in]; } .loc 1 76 0 mov.b32 %r137,%r135; and.b32 %r136,%r137,-4096; mov.b32 %r62,%r136; .loc 1 77 0 neg.f32 %r138,%r62; fma.rn.f32 %r139,%r138,%r62,%r59; add.f32 %r140,%r135,%r62; div.rn.f32 %r141,%r139,%r140; .loc 1 78 0 fma.rn.f32 %r142,%r59,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r143,%r142,%r59,0fbd241146; fma.rn.f32 %r144,%r143,%r59,0f3e4e0aa8; fma.rn.f32 %r145,%r144,%r59,0fbea6b090; fma.rn.f32 %r146,%r145,%r59,0f3e2aaaab; mul.f32 %r147,%r146,%r59; .loc 1 79 0 fma.rn.f32 %r148,%r59,0f3d9dc62e,0fbf303361; fma.rn.f32 %r149,%r148,%r59,0f4001572d; fma.rn.f32 %r150,%r149,%r59,0fc019d139; fma.rn.f32 %r151,%r150,%r59,0f3f800000; .loc 1 80 0 div.rn.f32 %r152,%r147,%r151; .loc 1 81 0 fma.rn.f32 %r153,%r135,%r152,%r141; .loc 1 82 0 add.f32 %r154,%r153,%r62; add.f32 %r94,%r154,%r154; bra $L1; $L8: .loc 1 56 0 mov.f32 %r94,0f3fc90fdb; $L1: .loc 1 84 0 mov.f32 %value,%r94; st.param.f32 [%value_out],%value; ret; } /103 0 0 0 644 3059 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_acoshf .visible .func (.param .f32 %value_out) __ieee754_acoshf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_acosh.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1pf .extern .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_acoshf .visible .func (.param .f32 %value_out) __ieee754_acoshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .u32 %r33; .reg .f32 %r34; .reg .f32 %r38; .reg .f32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r63; .reg .f32 %r64; mov.f32 %r39,%ar0; .loc 1 36 0 mov.b32 %r33,%r39; .loc 1 37 0 setp.gt.s32 %r40,%r33,1065353215; @ %r40 bra $L2; .loc 1 38 0 sub.f32 %r22,%r39,%r39; div.rn.f32 %r38,%r22,%r22; bra $L1; $L2: .loc 1 39 0 setp.le.s32 %r41,%r33,1300234239; @ %r41 bra $L4; .loc 1 40 0 setp.le.s32 %r42,%r33,2139095039; @ %r42 bra $L5; .loc 1 41 0 add.f32 %r38,%r39,%r39; bra $L1; $L5: .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } add.f32 %r38,%r44,0f3f317218; bra $L1; $L4: .loc 1 44 0 setp.eq.u32 %r45,%r33,1065353216; @ %r45 bra $L7; .loc 1 46 0 setp.le.s32 %r46,%r33,1073741824; @ %r46 bra $L6; .loc 1 48 0 fma.rn.f32 %r48,%r39,%r39,0fbf800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r48; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } add.f32 %r51,%r49,%r39; mov.f32 %r53,0f3f800000; div.rn.f32 %r52,%r53,%r51; neg.f32 %r54,%r52; fma.rn.f32 %r55,%r39,0f40000000,%r54; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r55; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r56,[%value_in]; } mov.f32 %r38,%r56; bra $L1; $L6: .loc 1 50 0 mov.f32 %r57,0f3f800000; sub.f32 %r34,%r39,%r57; .loc 1 51 0 mul.f32 %r59,%r34,%r34; fma.rn.f32 %r60,%r34,0f40000000,%r59; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r60; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r61,[%value_in]; } add.f32 %r63,%r61,%r34; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r63; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } mov.f32 %r38,%r64; bra $L1; $L7: .loc 1 45 0 mov.f32 %r38,0f00000000; $L1: .loc 1 53 0 mov.f32 %value,%r38; st.param.f32 [%value_out],%value; ret; } lib_a-ef_asin.o/0 0 0 644 4683 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_asinf .visible .func (.param .f32 %value_out) __ieee754_asinf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_asin.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_asinf .visible .func (.param .f32 %value_out) __ieee754_asinf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .f32 %r52; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r63; .reg .f32 %r65; .reg .f32 %r81; .reg .f32 %r82; .reg .pred %r83; .reg .f32 %r84; .reg .pred %r85; .reg .pred %r86; .reg .pred %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r114; .reg .pred %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .f32 %r126; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r132; .reg .f32 %r133; .reg .pred %r134; mov.f32 %r82,%ar0; .loc 1 49 0 mov.b32 %r50,%r82; .loc 1 50 0 and.b32 %r51,%r50,2147483647; .loc 1 51 0 setp.ne.u32 %r83,%r51,1065353216; @ %r83 bra $L2; .loc 1 53 0 mul.f32 %r84,%r82,0fb33bbd2e; fma.rn.f32 %r81,%r82,0f3fc90fdb,%r84; bra $L1; $L2: .loc 1 54 0 setp.le.s32 %r85,%r51,1065353216; @ %r85 bra $L4; .loc 1 55 0 sub.f32 %r23,%r82,%r82; div.rn.f32 %r81,%r23,%r23; bra $L1; $L4: .loc 1 56 0 setp.gt.s32 %r86,%r51,1056964607; @ %r86 bra $L5; .loc 1 57 0 setp.gt.s32 %r87,%r51,838860799; @ %r87 bra $L6; .loc 1 58 0 add.f32 %r88,%r82,0f7149f2ca; setp.gt.f32 %r89,%r88,0f3f800000; @ %r89 bra $L9; bra $L5; $L6: .loc 1 60 0 mul.f32 %r52,%r82,%r82; .loc 1 61 0 fma.rn.f32 %r90,%r52,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r91,%r90,%r52,0fbd241146; fma.rn.f32 %r92,%r91,%r52,0f3e4e0aa8; fma.rn.f32 %r93,%r92,%r52,0fbea6b090; fma.rn.f32 %r94,%r93,%r52,0f3e2aaaab; mul.f32 %r95,%r94,%r52; .loc 1 62 0 fma.rn.f32 %r96,%r52,0f3d9dc62e,0fbf303361; fma.rn.f32 %r97,%r96,%r52,0f4001572d; fma.rn.f32 %r98,%r97,%r52,0fc019d139; fma.rn.f32 %r99,%r98,%r52,0f3f800000; .loc 1 63 0 div.rn.f32 %r100,%r95,%r99; .loc 1 64 0 fma.rn.f32 %r81,%r82,%r100,%r82; bra $L1; $L5: .loc 1 68 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r82; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r102,[%value_in]; } mov.f32 %r104,0f3f800000; sub.f32 %r103,%r104,%r102; .loc 1 69 0 mul.f32 %r58,%r103,0f3f000000; .loc 1 70 0 fma.rn.f32 %r105,%r58,0f3811ef08,0f3a4f7f04; fma.rn.f32 %r106,%r105,%r58,0fbd241146; fma.rn.f32 %r107,%r106,%r58,0f3e4e0aa8; fma.rn.f32 %r108,%r107,%r58,0fbea6b090; fma.rn.f32 %r109,%r108,%r58,0f3e2aaaab; mul.f32 %r59,%r109,%r58; .loc 1 71 0 fma.rn.f32 %r110,%r58,0f3d9dc62e,0fbf303361; fma.rn.f32 %r111,%r110,%r58,0f4001572d; fma.rn.f32 %r112,%r111,%r58,0fc019d139; fma.rn.f32 %r60,%r112,%r58,0f3f800000; .loc 1 72 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r114,[%value_in]; } .loc 1 73 0 setp.le.s32 %r115,%r51,1064933785; @ %r115 bra $L7; .loc 1 74 0 div.rn.f32 %r116,%r59,%r60; .loc 1 75 0 fma.rn.f32 %r117,%r114,%r116,%r114; fma.rn.f32 %r118,%r117,0f40000000,0f333bbd2e; mov.f32 %r119,0f3fc90fdb; sub.f32 %r81,%r119,%r118; bra $L8; $L7: .loc 1 80 0 mov.b32 %r121,%r114; and.b32 %r120,%r121,-4096; mov.b32 %r63,%r120; .loc 1 82 0 div.rn.f32 %r65,%r59,%r60; .loc 1 83 0 add.f32 %r122,%r114,%r114; .loc 1 81 0 neg.f32 %r123,%r63; fma.rn.f32 %r124,%r123,%r63,%r58; add.f32 %r125,%r114,%r63; div.rn.f32 %r126,%r124,%r125; .loc 1 83 0 fma.rn.f32 %r128,%r126,0fc0000000,0fb33bbd2e; neg.f32 %r129,%r128; fma.rn.f32 %r130,%r122,%r65,%r129; .loc 1 84 0 fma.rn.f32 %r132,%r123,0f40000000,0f3f490fdb; .loc 1 85 0 sub.f32 %r49,%r130,%r132; mov.f32 %r133,0f3f490fdb; sub.f32 %r81,%r133,%r49; $L8: .loc 1 87 0 setp.gt.s32 %r134,%r50,0; @ %r134 bra $L1; neg.f32 %r81,%r81; bra $L1; $L9: .loc 1 58 0 mov.f32 %r81,%r82; $L1: .loc 1 88 0 mov.f32 %value,%r81; st.param.f32 [%value_out],%value; ret; } /121 0 0 0 644 5267 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2f .visible .func (.param .f32 %value_out) __ieee754_atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_atan2.c" // BEGIN GLOBAL FUNCTION DECL: atanf .extern .func (.param .f32 %value_out) atanf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atan2f .visible .func (.param .f32 %value_out) __ieee754_atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r36; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u16 %r56; .reg .u16 %r57; .reg .u16 %r58; .reg .u32 %r59; .reg .u16 %r60; .reg .pred %r61; .reg .pred %r62; .reg .f32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .pred %r73; .reg .pred %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u32 %r86; .reg .u32 %r88; .reg .u32 %r89; .reg .u16 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u32 %r94; .reg .u16 %r95; .reg .pred %r96; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .u32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; mov.f32 %r48,%ar0; mov.f32 %r49,%ar1; .loc 1 41 0 mov.b32 %r39,%r49; .loc 1 42 0 and.b32 %r40,%r39,2147483647; .loc 1 43 0 mov.b32 %r44,%r48; .loc 1 44 0 and.b32 %r42,%r44,2147483647; .loc 1 45 0 set.u32.gt.s32 %r51,%r40,2139095040; neg.s32 %r52,%r51; .loc 1 46 0 set.u32.gt.s32 %r54,%r42,2139095040; neg.s32 %r55,%r54; .loc 1 45 0 cvt.u16.u32 %r57,%r52; cvt.u16.u32 %r58,%r55; or.b16 %r56,%r57,%r58; cvt.u32.u16 %r59,%r56; cvt.u16.u8 %r60,%r59; setp.eq.u16 %r61,%r60,0; @ %r61 bra $L2; .loc 1 47 0 add.f32 %r47,%r49,%r48; bra $L1; $L2: .loc 1 48 0 setp.ne.u32 %r62,%r39,1065353216; @ %r62 bra $L4; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r48; call (%value_in),atanf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } mov.f32 %r47,%r64; bra $L1; $L4: .loc 1 49 0 shr.s32 %r65,%r39,30; and.b32 %r66,%r65,2; shr.u32 %r67,%r44,31; or.b32 %r43,%r66,%r67; .loc 1 52 0 setp.ne.u32 %r68,%r42,0; @ %r68 bra $L5; .loc 1 53 0 setp.eq.u32 %r69,%r43,2; @ %r69 bra $L22; setp.eq.u32 %r70,%r43,3; .loc 1 55 0 selp.f32 %r47,0fc0490fdb,%r48,%r70; bra $L1; $L5: .loc 1 61 0 setp.ne.u32 %r71,%r40,0; @ %r71 bra $L8; setp.ge.s32 %r72,%r44,0; selp.f32 %r47,0f3fc90fdb,0fbfc90fdb,%r72; bra $L1; $L8: .loc 1 64 0 setp.ne.u32 %r73,%r40,2139095040; @ %r73 bra $L9; .loc 1 65 0 setp.ne.u32 %r74,%r42,2139095040; @ %r74 bra $L10; .loc 1 66 0 setp.eq.u32 %r75,%r43,2; @ %r75 bra $L11; setp.eq.u32 %r76,%r43,3; @ %r76 bra $L12; setp.eq.u32 %r77,%r43,1; .loc 1 67 0 selp.f32 %r47,0fbf490fdb,0f3f490fdb,%r77; bra $L1; $L11: .loc 1 69 0 mov.f32 %r47,0f4016cbe4; bra $L1; $L12: .loc 1 70 0 mov.f32 %r47,0fc016cbe4; bra $L1; $L10: .loc 1 73 0 setp.eq.u32 %r78,%r43,2; @ %r78 bra $L25; setp.eq.u32 %r79,%r43,3; @ %r79 bra $L15; setp.eq.u32 %r80,%r43,1; .loc 1 74 0 selp.f32 %r47,0f80000000,0f00000000,%r80; bra $L1; $L15: .loc 1 57 0 mov.f32 %r47,0fc0490fdb; bra $L1; $L9: .loc 1 82 0 setp.ne.u32 %r81,%r42,2139095040; @ %r81 bra $L17; setp.ge.s32 %r82,%r44,0; .loc 1 61 0 selp.f32 %r47,0f3fc90fdb,0fbfc90fdb,%r82; bra $L1; $L17: .loc 1 85 0 sub.u32 %r83,%r42,%r40; shr.s32 %r46,%r83,23; .loc 1 86 0 setp.gt.s32 %r84,%r46,60; @ %r84 bra $L27; .loc 1 87 0 shr.u32 %r86,%r39,31; set.u32.lt.s32 %r88,%r46,-60; neg.s32 %r89,%r88; cvt.u16.u32 %r92,%r86; cvt.u16.u32 %r93,%r89; and.b16 %r91,%r92,%r93; cvt.u32.u16 %r94,%r91; cvt.u16.u8 %r95,%r94; setp.ne.u16 %r96,%r95,0; @ %r96 bra $L28; .loc 1 88 0 div.rn.f32 %r98,%r48,%r49; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r98; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r99,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r99; call (%value_in),atanf,(%out_arg1); ld.param.f32 %r101,[%value_in]; } mov.f32 %r47,%r101; bra $L18; $L27: .loc 1 86 0 mov.f32 %r47,0f3fc90fdb; bra $L18; $L28: .loc 1 87 0 mov.f32 %r47,0f00000000; $L18: .loc 1 89 0 setp.eq.u32 %r102,%r43,1; @ %r102 bra $L20; setp.eq.u32 %r103,%r43,2; @ %r103 bra $L21; setp.eq.u32 %r104,%r43,0; @ ! %r104 bra $L32; bra $L1; $L20: .loc 1 94 0 mov.b32 %r105,%r47; add.u32 %r36,%r105,-2147483648; mov.b32 %r47,%r36; .loc 1 96 0 bra $L1; $L21: .loc 1 97 0 add.f32 %r106,%r47,0f33bbbd2e; mov.f32 %r107,0f40490fdb; sub.f32 %r47,%r107,%r106; bra $L1; $L32: .loc 1 99 0 add.f32 %r108,%r47,0f33bbbd2e; mov.f32 %r109,0f40490fdb; sub.f32 %r47,%r108,%r109; bra $L1; $L22: .loc 1 56 0 mov.f32 %r47,0f40490fdb; bra $L1; $L25: mov.f32 %r47,0f40490fdb; $L1: .loc 1 101 0 mov.f32 %value,%r47; st.param.f32 [%value_out],%value; ret; } /139 0 0 0 644 2442 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanhf .visible .func (.param .f32 %value_out) __ieee754_atanhf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_atanh.c" // BEGIN GLOBAL FUNCTION DECL: log1pf .extern .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_atanhf .visible .func (.param .f32 %value_out) __ieee754_atanhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .f32 %r24; .reg .u32 %r31; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .f32 %r41; .reg .pred %r42; .reg .f32 %r43; .reg .pred %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r51; .reg .f32 %r52; .reg .pred %r53; .reg .f32 %r55; mov.f32 %r37,%ar0; .loc 1 40 0 mov.b32 %r31,%r37; .loc 1 41 0 and.b32 %r32,%r31,2147483647; .loc 1 42 0 setp.le.s32 %r38,%r32,1065353216; @ %r38 bra $L2; .loc 1 43 0 sub.f32 %r22,%r37,%r37; div.rn.f32 %r36,%r22,%r22; bra $L1; $L2: .loc 1 44 0 setp.ne.u32 %r39,%r32,1065353216; @ %r39 bra $L4; .loc 1 45 0 div.rn.f32 %r36,%r37,0f00000000; bra $L1; $L4: .loc 1 46 0 setp.gt.s32 %r40,%r32,830472191; @ %r40 bra $L5; add.f32 %r41,%r37,0f7149f2ca; setp.gt.f32 %r42,%r41,0f00000000; @ %r42 bra $L10; bra $L11; $L5: .loc 1 47 0 mov.b32 %r34,%r32; add.f32 %r24,%r34,%r34; mov.f32 %r43,0f3f800000; sub.f32 %r35,%r43,%r34; .loc 1 48 0 setp.gt.s32 %r44,%r32,1056964607; @ %r44 bra $L7; $L9: .loc 1 50 0 mul.f32 %r46,%r24,%r34; div.rn.f32 %r47,%r46,%r35; add.f32 %r48,%r47,%r24; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r48; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } mul.f32 %r36,%r49,0f3f000000; bra $L8; $L7: .loc 1 52 0 div.rn.f32 %r51,%r24,%r35; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r52,[%value_in]; } mul.f32 %r36,%r52,0f3f000000; $L8: .loc 1 53 0 setp.ge.s32 %r53,%r31,0; @ %r53 bra $L1; neg.f32 %r36,%r36; bra $L1; $L10: .loc 1 46 0 mov.f32 %r36,%r37; bra $L1; $L11: .loc 1 47 0 mov.b32 %r34,%r32; add.f32 %r24,%r34,%r34; mov.f32 %r55,0f3f800000; sub.f32 %r35,%r55,%r34; bra $L9; $L1: .loc 1 54 0 mov.f32 %value,%r36; st.param.f32 [%value_out],%value; ret; } lib_a-ef_cosh.o/0 0 0 644 3567 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_coshf .visible .func (.param .f32 %value_out) __ieee754_coshf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_cosh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1f .extern .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_coshf .visible .func (.param .f32 %value_out) __ieee754_coshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r32; .reg .u32 %r33; .reg .f32 %r39; .reg .f32 %r40; .reg .pred %r41; .reg .pred %r42; .reg .f32 %r44; .reg .f32 %r46; .reg .pred %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .pred %r51; .reg .f32 %r53; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .pred %r58; .reg .f32 %r60; .reg .f32 %r62; .reg .pred %r63; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; mov.f32 %r40,%ar0; .loc 1 38 0 mov.b32 %r32,%r40; .loc 1 39 0 and.b32 %r33,%r32,2147483647; .loc 1 42 0 setp.le.s32 %r41,%r33,2139095039; @ %r41 bra $L2; mul.f32 %r39,%r40,%r40; bra $L1; $L2: .loc 1 45 0 setp.gt.s32 %r42,%r33,1051816471; @ %r42 bra $L4; .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r46,[%value_in]; } .loc 1 47 0 add.f32 %r39,%r46,0f3f800000; .loc 1 48 0 setp.le.s32 %r47,%r33,603979775; @ %r47 bra $L1; .loc 1 49 0 mul.f32 %r48,%r46,%r46; add.f32 %r49,%r39,%r39; div.rn.f32 %r50,%r48,%r49; add.f32 %r39,%r50,0f3f800000; bra $L1; $L4: .loc 1 53 0 setp.gt.s32 %r51,%r33,1102053375; @ %r51 bra $L5; .loc 1 54 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r53,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r53; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r55,[%value_in]; } .loc 1 55 0 mov.f32 %r57,0f3f000000; div.rn.f32 %r56,%r57,%r55; fma.rn.f32 %r39,%r55,0f3f000000,%r56; bra $L1; $L5: .loc 1 59 0 setp.gt.s32 %r58,%r33,1118925335; @ %r58 bra $L6; .loc 1 60 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r60,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r60; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r62,[%value_in]; } mul.f32 %r39,%r62,0f3f000000; bra $L1; $L6: .loc 1 63 0 setp.gt.s32 %r63,%r33,1119016188; @ %r63 bra $L7; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r65,[%value_in]; } mul.f32 %r67,%r65,0f3f000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } .loc 1 65 0 mul.f32 %r69,%r68,0f3f000000; .loc 1 66 0 mul.f32 %r39,%r69,%r68; bra $L1; $L7: .loc 1 70 0 mov.f32 %r70,0f7149f2ca; mul.f32 %r39,%r70,0f7149f2ca; $L1: .loc 1 71 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } lib_a-ef_exp.o/ 0 0 0 644 4890 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .visible .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_exp.c" // BEGIN VAR DEF: ln2LO .const .align 4 .u32 ln2LO[2] = {924317649,3071801297 }; // BEGIN VAR DEF: halF .const .align 4 .u32 halF[2] = {1056964608,3204448256 }; // BEGIN VAR DEF: ln2HI .const .align 4 .u32 ln2HI[2] = {1060204928,3207688576 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_expf .visible .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f32 %r49; .reg .f32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r65; .reg .u32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .f32 %r73; .reg .u32 %r77; .reg .u32 %r78; .reg .u16 %r80; .reg .u16 %r81; .reg .u16 %r82; .reg .u32 %r83; .reg .u16 %r84; .reg .pred %r85; .reg .pred %r86; .reg .pred %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .f32 %r92; .reg .u64 %r93; .reg .u64 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .pred %r106; .reg .f32 %r107; .reg .pred %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .f32 %r126; .reg .pred %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .f32 %r133; mov.f32 %r68,%ar0; .loc 1 53 0 mov.b32 %r52,%r68; .loc 1 55 0 and.b32 %r55,%r52,2147483647; .loc 1 58 0 setp.le.u32 %r69,%r55,2139095040; @ %r69 bra $L2; .loc 1 59 0 add.f32 %r67,%r68,%r68; bra $L1; $L2: .loc 1 54 0 shr.u32 %r22,%r52,31; .loc 1 60 0 setp.ne.u32 %r70,%r55,2139095040; @ %r70 bra $L4; .loc 1 61 0 setp.ne.u32 %r71,%r22,0; selp.f32 %r67,0f00000000,%r68,%r71; bra $L1; $L4: .loc 1 62 0 setp.le.s32 %r72,%r52,1118925335; @ %r72 bra $L5; .loc 1 63 0 mov.f32 %r73,0f7149f2ca; mul.f32 %r67,%r73,0f7149f2ca; bra $L1; $L5: .loc 1 64 0 set.u32.gt.u32 %r77,%r55,1120924085; neg.s32 %r78,%r77; cvt.u16.u32 %r81,%r22; cvt.u16.u32 %r82,%r78; and.b16 %r80,%r81,%r82; cvt.u32.u16 %r83,%r80; cvt.u16.u8 %r84,%r83; setp.ne.u16 %r85,%r84,0; @ %r85 bra $L14; .loc 1 68 0 setp.le.u32 %r86,%r55,1051816472; @ %r86 bra $L6; .loc 1 69 0 setp.gt.u32 %r87,%r55,1065686417; @ %r87 bra $L7; .loc 1 70 0 cvta.const.u64 %r88,ln2HI; cvt.s64.s32 %r89,%r22; shl.b64 %r90,%r89,2; add.u64 %r91,%r88,%r90; ld.f32 %r92,[%r91]; sub.f32 %r49,%r68,%r92; cvta.const.u64 %r93,ln2LO; add.u64 %r96,%r93,%r90; ld.f32 %r50,[%r96]; mov.u32 %r98,1; sub.u32 %r97,%r98,%r22; sub.u32 %r51,%r97,%r22; bra $L8; $L7: .loc 1 72 0 cvta.const.u64 %r99,halF; cvt.s64.s32 %r100,%r22; shl.b64 %r101,%r100,2; add.u64 %r102,%r99,%r101; ld.f32 %r104,[%r102]; fma.rn.f32 %r103,%r68,0f3fb8aa3b,%r104; cvt.rzi.s32.f32 %r51,%r103; .loc 1 73 0 cvt.rn.f32.s32 %r56,%r51; .loc 1 74 0 fma.rn.f32 %r49,%r56,0fbf317180,%r68; .loc 1 75 0 mul.f32 %r50,%r56,0f3717f7d1; $L8: .loc 1 77 0 sub.f32 %r68,%r49,%r50; bra $L9; $L6: .loc 1 79 0 setp.gt.u32 %r106,%r55,830472191; @ %r106 bra $L15; .loc 1 80 0 add.f32 %r107,%r68,0f7149f2ca; setp.gt.f32 %r108,%r107,0f3f800000; @ ! %r108 bra $L18; add.f32 %r67,%r68,0f3f800000; bra $L1; $L15: .loc 1 50 0 mov.u32 %r51,0; bra $L9; $L18: mov.u32 %r51,0; $L9: .loc 1 84 0 mul.f32 %r57,%r68,%r68; .loc 1 85 0 fma.rn.f32 %r109,%r57,0f3331bb4c,0fb5ddea0e; fma.rn.f32 %r110,%r109,%r57,0f388ab355; fma.rn.f32 %r111,%r110,%r57,0fbb360b61; fma.rn.f32 %r112,%r111,%r57,0f3e2aaaab; neg.f32 %r113,%r112; fma.rn.f32 %r58,%r113,%r57,%r68; mul.f32 %r65,%r68,%r58; .loc 1 86 0 setp.ne.u32 %r114,%r51,0; @ %r114 bra $L11; mov.f32 %r116,0f40000000; sub.f32 %r115,%r58,%r116; div.rn.f32 %r117,%r65,%r115; sub.f32 %r118,%r117,%r68; mov.f32 %r119,0f3f800000; sub.f32 %r67,%r119,%r118; bra $L1; $L11: .loc 1 87 0 mov.f32 %r121,0f40000000; sub.f32 %r120,%r121,%r58; div.rn.f32 %r122,%r65,%r120; sub.f32 %r123,%r50,%r122; sub.f32 %r124,%r123,%r49; mov.f32 %r126,0f3f800000; sub.f32 %r125,%r126,%r124; mov.b32 %r66,%r125; .loc 1 88 0 setp.lt.s32 %r127,%r51,-125; @ %r127 bra $L12; .loc 1 91 0 shl.b32 %r128,%r51,23; add.u32 %r129,%r128,%r66; mov.b32 %r67,%r129; .loc 1 92 0 bra $L1; $L12: .loc 1 96 0 add.u32 %r130,%r51,100; shl.b32 %r131,%r130,23; add.u32 %r132,%r131,%r66; .loc 1 97 0 mov.b32 %r133,%r132; mul.f32 %r67,%r133,0f0d800000; bra $L1; $L14: .loc 1 61 0 mov.f32 %r67,0f00000000; $L1: .loc 1 99 0 mov.f32 %value,%r67; st.param.f32 [%value_out],%value; ret; } lib_a-ef_fmod.o/0 0 0 644 5851 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmodf .visible .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_fmod.c" // BEGIN VAR DEF: Zero .const .align 4 .u32 Zero[2] = {0,2147483648 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_fmodf .visible .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r33; .reg .u32 %r36; .reg .f32 %r37; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r53; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r65; .reg .u32 %r69; .reg .u32 %r73; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u32 %r89; .reg .u32 %r90; .reg .u16 %r92; .reg .u16 %r94; .reg .u32 %r95; .reg .u16 %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .u64 %r100; .reg .u32 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .u32 %r108; .reg .pred %r110; .reg .u32 %r111; .reg .pred %r112; .reg .pred %r114; .reg .u32 %r115; .reg .pred %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r120; .reg .u32 %r121; .reg .pred %r122; .reg .pred %r124; .reg .u64 %r125; .reg .u32 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r131; .reg .pred %r132; .reg .pred %r133; .reg .pred %r134; .reg .u64 %r135; .reg .u32 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r139; .reg .pred %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .u32 %r146; .reg .u32 %r147; .reg .u32 %r148; .reg .u32 %r149; .reg .u32 %r150; .reg .u32 %r151; .reg .pred %r153; mov.f32 %r77,%ar0; mov.f32 %r78,%ar1; .loc 1 39 0 mov.b32 %r57,%r77; .loc 1 40 0 mov.b32 %r58,%r78; .loc 1 42 0 and.b32 %r60,%r57,2147483647; .loc 1 43 0 and.b32 %r61,%r58,2147483647; .loc 1 46 0 set.u32.eq.u32 %r80,%r61,0; neg.s32 %r81,%r80; .loc 1 47 0 set.u32.gt.s32 %r83,%r61,2139095040; neg.s32 %r84,%r83; cvt.u16.u32 %r86,%r81; cvt.u16.u32 %r87,%r84; or.b16 %r85,%r86,%r87; set.u32.gt.s32 %r89,%r60,2139095039; neg.s32 %r90,%r89; cvt.u16.u32 %r94,%r90; or.b16 %r92,%r85,%r94; cvt.u32.u16 %r95,%r92; cvt.u16.u8 %r96,%r95; setp.eq.u16 %r97,%r96,0; @ %r97 bra $L2; .loc 1 49 0 mul.f32 %r37,%r77,%r78; div.rn.f32 %r76,%r37,%r37; bra $L1; $L2: .loc 1 50 0 setp.lt.s32 %r98,%r60,%r61; @ %r98 bra $L27; .loc 1 41 0 and.b32 %r59,%r57,-2147483648; .loc 1 51 0 setp.ne.u32 %r99,%r60,%r61; @ %r99 bra $L4; .loc 1 52 0 cvta.const.u64 %r100,Zero; shr.u32 %r101,%r59,31; cvt.u64.u32 %r102,%r101; shl.b64 %r103,%r102,2; add.u64 %r104,%r100,%r103; ld.f32 %r76,[%r104]; bra $L1; $L4: .loc 1 57 0 setp.gt.s32 %r105,%r60,8388607; @ %r105 bra $L5; .loc 1 58 0 shl.b32 %r63,%r60,8; setp.ne.u32 %r106,%r63,0; @ %r106 bra $L28; .loc 1 62 0 setp.le.s32 %r107,%r61,8388607; @ %r107 bra $L29; .loc 1 64 0 shr.s32 %r108,%r61,23; add.u32 %r73,%r108,-127; .loc 1 58 0 mov.u32 %r33,-126; bra $L8; $L28: mov.u32 %r33,-126; $L6: add.u32 %r33,%r33,-1; add.u32 %r63,%r63,%r63; setp.gt.s32 %r110,%r63,0; @ %r110 bra $L6; bra $L9; $L5: .loc 1 59 0 shr.s32 %r111,%r60,23; add.u32 %r33,%r111,-127; $L9: .loc 1 62 0 setp.gt.s32 %r112,%r61,8388607; @ %r112 bra $L10; bra $L7; $L29: .loc 1 58 0 mov.u32 %r33,-126; $L7: .loc 1 63 0 shl.b32 %r65,%r61,8; mov.u32 %r73,-126; $L11: add.u32 %r73,%r73,-1; add.u32 %r65,%r65,%r65; setp.ge.s32 %r114,%r65,0; @ %r114 bra $L11; bra $L12; $L10: .loc 1 64 0 shr.s32 %r115,%r61,23; add.u32 %r73,%r115,-127; $L12: .loc 1 67 0 setp.lt.s32 %r116,%r33,-126; @ %r116 bra $L13; $L8: .loc 1 68 0 and.b32 %r42,%r57,8388607; or.b32 %r53,%r42,8388608; bra $L14; $L13: .loc 1 70 0 mov.u32 %r118,-126; sub.u32 %r117,%r118,%r33; .loc 1 71 0 shl.b32 %r53,%r60,%r117; $L14: .loc 1 73 0 setp.lt.s32 %r153,%r73,-126; @ %r153 bra $L15; .loc 1 74 0 and.b32 %r43,%r58,8388607; or.b32 %r55,%r43,8388608; bra $L16; $L15: .loc 1 76 0 mov.u32 %r121,-126; sub.u32 %r120,%r121,%r73; .loc 1 77 0 shl.b32 %r55,%r61,%r120; $L16: .loc 1 81 0 sub.u32 %r36,%r33,%r73; .loc 1 82 0 bra $L17; $L21: .loc 1 84 0 setp.ge.s32 %r122,%r69,0; @ %r122 bra $L18; add.u32 %r53,%r53,%r53; bra $L19; $L18: .loc 1 86 0 setp.ne.u32 %r124,%r69,0; @ %r124 bra $L20; .loc 1 87 0 cvta.const.u64 %r125,Zero; shr.u32 %r126,%r59,31; cvt.u64.u32 %r127,%r126; shl.b64 %r128,%r127,2; add.u64 %r129,%r125,%r128; ld.f32 %r76,[%r129]; bra $L1; $L20: .loc 1 88 0 add.u32 %r53,%r69,%r69; $L19: add.u32 %r36,%r36,-1; $L17: sub.u32 %r69,%r53,%r55; .loc 1 82 0 setp.ne.u32 %r131,%r36,0; @ %r131 bra $L21; .loc 1 92 0 setp.ge.s32 %r132,%r69,0; selp.u32 %r69,%r69,%r53,%r132; .loc 1 95 0 setp.eq.u32 %r133,%r69,0; @ %r133 bra $L23; .loc 1 97 0 setp.le.s32 %r134,%r69,8388607; @ %r134 bra $L24; bra $L25; $L23: .loc 1 96 0 cvta.const.u64 %r135,Zero; shr.u32 %r136,%r59,31; cvt.u64.u32 %r137,%r136; shl.b64 %r138,%r137,2; add.u64 %r139,%r135,%r138; ld.f32 %r76,[%r139]; bra $L1; $L24: .loc 1 98 0 add.u32 %r69,%r69,%r69; .loc 1 99 0 add.u32 %r73,%r73,-1; .loc 1 97 0 setp.le.s32 %r141,%r69,8388607; @ %r141 bra $L24; setp.lt.s32 %r153,%r73,-126; $L25: .loc 1 101 0 @ %r153 bra $L26; .loc 1 102 0 add.u32 %r143,%r73,127; shl.b32 %r144,%r143,23; add.u32 %r145,%r69,-8388608; .loc 1 103 0 or.b32 %r146,%r145,%r59; or.b32 %r147,%r144,%r146; mov.b32 %r76,%r147; bra $L1; $L26: .loc 1 107 0 mov.u32 %r149,-126; sub.u32 %r148,%r149,%r73; .loc 1 108 0 shr.s32 %r150,%r69,%r148; .loc 1 109 0 or.b32 %r151,%r150,%r59; mov.b32 %r76,%r151; bra $L1; $L27: .loc 1 50 0 mov.f32 %r76,%r77; $L1: .loc 1 113 0 mov.f32 %value,%r76; st.param.f32 [%value_out],%value; ret; } /157 0 0 0 644 4525 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypotf .visible .func (.param .f32 %value_out) __ieee754_hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_hypot.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_hypotf .visible .func (.param .f32 %value_out) __ieee754_hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r42; .reg .f32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r52; .reg .u32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .pred %r72; .reg .pred %r73; .reg .pred %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .u32 %r81; .reg .f32 %r83; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r104; .reg .pred %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .f32 %r108; mov.f32 %r67,%ar0; mov.f32 %r68,%ar1; .loc 1 28 0 mov.b32 %r52,%r67; .loc 1 29 0 and.b32 %r49,%r52,2147483647; .loc 1 30 0 mov.b32 %r53,%r68; .loc 1 31 0 and.b32 %r48,%r53,2147483647; .loc 1 32 0 setp.lt.s32 %r70,%r49,%r48; @ %r70 bra $L2; mov.u32 %r69,%r48; mov.u32 %r48,%r49; mov.u32 %r49,%r69; $L2: .loc 1 33 0 mov.b32 %r66,%r48; .loc 1 34 0 mov.b32 %r46,%r49; .loc 1 35 0 sub.u32 %r71,%r48,%r49; setp.le.s32 %r72,%r71,251658240; @ %r72 bra $L3; add.f32 %r66,%r66,%r46; bra $L1; $L3: .loc 1 37 0 setp.le.s32 %r73,%r48,1484783616; @ %r73 bra $L13; .loc 1 38 0 setp.le.s32 %r74,%r48,2139095039; @ %r74 bra $L6; .loc 1 40 0 setp.eq.u32 %r75,%r48,2139095040; @ %r75 bra $L14; .loc 1 39 0 add.f32 %r66,%r66,%r46; bra $L7; $L14: .loc 1 40 0 mov.f32 %r66,0f7f800000; $L7: .loc 1 41 0 setp.eq.u32 %r76,%r49,2139095040; selp.f32 %r66,0f7f800000,%r66,%r76; bra $L1; $L6: .loc 1 45 0 add.u32 %r48,%r48,-570425344; add.u32 %r49,%r49,-570425344; .loc 1 46 0 mov.b32 %r66,%r48; .loc 1 47 0 mov.b32 %r46,%r49; .loc 1 45 0 mov.u32 %r47,68; bra $L5; $L13: .loc 1 36 0 mov.u32 %r47,0; $L5: .loc 1 49 0 setp.gt.s32 %r77,%r49,645922815; @ %r77 bra $L8; .loc 1 50 0 setp.eq.u32 %r78,%r49,0; @ %r78 bra $L1; .loc 1 52 0 setp.gt.s32 %r79,%r49,8388607; @ %r79 bra $L9; .loc 1 54 0 mul.f32 %r46,%r46,0f7e800000; .loc 1 55 0 mul.f32 %r66,%r66,0f7e800000; .loc 1 56 0 add.u32 %r47,%r47,-126; bra $L8; $L9: .loc 1 58 0 add.u32 %r48,%r48,570425344; .loc 1 59 0 add.u32 %r49,%r49,570425344; .loc 1 60 0 add.u32 %r47,%r47,-68; .loc 1 61 0 mov.b32 %r66,%r48; .loc 1 62 0 mov.b32 %r46,%r49; $L8: .loc 1 66 0 sub.f32 %r54,%r66,%r46; .loc 1 67 0 setp.lt.f32 %r80,%r46,%r54; @ ! %r80 bra $L23; .loc 1 68 0 and.b32 %r81,%r48,-4096; mov.b32 %r59,%r81; .loc 1 70 0 neg.f32 %r83,%r46; add.f32 %r84,%r66,%r59; .loc 1 69 0 sub.f32 %r85,%r66,%r59; .loc 1 70 0 mul.f32 %r86,%r84,%r85; neg.f32 %r87,%r86; fma.rn.f32 %r88,%r83,%r46,%r87; neg.f32 %r89,%r88; fma.rn.f32 %r90,%r59,%r59,%r89; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r90; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } mov.f32 %r66,%r91; bra $L12; $L23: .loc 1 73 0 and.b32 %r92,%r49,-4096; mov.b32 %r55,%r92; .loc 1 75 0 add.u32 %r93,%r48,8388608; mov.b32 %r57,%r93; .loc 1 77 0 neg.f32 %r94,%r54; .loc 1 74 0 sub.f32 %r95,%r46,%r55; .loc 1 76 0 neg.f32 %r96,%r57; fma.rn.f32 %r97,%r66,0f40000000,%r96; .loc 1 77 0 mul.f32 %r98,%r97,%r46; fma.rn.f32 %r99,%r95,%r57,%r98; neg.f32 %r100,%r99; fma.rn.f32 %r101,%r94,%r54,%r100; neg.f32 %r102,%r101; fma.rn.f32 %r42,%r55,%r57,%r102; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r104,[%value_in]; } mov.f32 %r66,%r104; $L12: .loc 1 79 0 setp.eq.u32 %r105,%r47,0; @ %r105 bra $L1; .loc 1 80 0 shl.b32 %r106,%r47,23; add.u32 %r107,%r106,1065353216; .loc 1 81 0 mov.b32 %r108,%r107; mul.f32 %r66,%r66,%r108; $L1: .loc 1 83 0 mov.f32 %value,%r66; st.param.f32 [%value_out],%value; ret; } lib_a-ef_j0.o/ 0 0 0 644 14761 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: pzerof .func (.param .f32 %value_out) pzerof (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_j0.c" // BEGIN FUNCTION DECL: qzerof .func (.param .f32 %value_out) qzerof (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0f .visible .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0f .visible .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN FUNCTION DEF: pzerof .func (.param .f32 %value_out) pzerof (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; mov.f32 %r50,%ar0; .loc 1 293 0 mov.b32 %r35,%r50; .loc 1 294 0 and.b32 %r36,%r35,2147483647; .loc 1 295 0 setp.gt.s32 %r51,%r36,1090519039; @ %r51 bra $L3; .loc 1 296 0 setp.gt.s32 %r52,%r36,1089936471; @ %r52 bra $L4; .loc 1 297 0 setp.gt.s32 %r53,%r36,1077336935; selp.f32 %r48,0f432d94b8,0f416a859a,%r53; selp.f32 %r47,0f448cffe6,0f4319e01a,%r53; selp.f32 %r46,0f44953373,0f43873c32,%r53; selp.f32 %r45,0f43b4c1ca,0f430834f0,%r53; selp.f32 %r44,0fc1fb9565,0fc04ef40d,%r53; selp.f32 %r43,0fc2685112,0fc1331736,%r53; selp.f32 %r42,0fc1afba52,0fc0f4579f,%r53; selp.f32 %r41,0fc01a2d95,0fbfb9b1cc,%r53; selp.f32 %r40,0fbd8fffb8,0fbd8ffb12,%r53; selp.f32 %r28,0f420f6c94,0f41b1c32d,%r53; selp.f32 %r23,0fb12f081b,0fb3be98b7,%r53; bra $L2; $L3: mov.f32 %r48,0f473a0bba; mov.f32 %r47,0f47e4087c; mov.f32 %r46,0f471e95db; mov.f32 %r45,0f456f9beb; mov.f32 %r44,0fc5a4285a; mov.f32 %r43,0fc51b5376; mov.f32 %r42,0fc3808814; mov.f32 %r41,0fc1014e86; mov.f32 %r40,0fbd900000; .loc 1 295 0 mov.f32 %r28,0f42e91198; mov.f32 %r23,0f00000000; bra $L2; $L4: mov.f32 %r48,0f451660ee; mov.f32 %r47,0f461665c8; mov.f32 %r46,0f45bad7c4; mov.f32 %r45,0f44836813; mov.f32 %r44,0fc3ad3779; mov.f32 %r43,0fc3a59d9b; mov.f32 %r42,0fc287597b; mov.f32 %r41,0fc0851b88; mov.f32 %r40,0fbd8fffff; .loc 1 296 0 mov.f32 %r28,0f42730408; mov.f32 %r23,0fad48c58a; $L2: .loc 1 299 0 mul.f32 %r54,%r50,%r50; mov.f32 %r55,0f3f800000; div.rn.f32 %r37,%r55,%r54; .loc 1 300 0 fma.rn.f32 %r57,%r37,%r44,%r43; fma.rn.f32 %r58,%r57,%r37,%r42; fma.rn.f32 %r59,%r58,%r37,%r41; fma.rn.f32 %r60,%r59,%r37,%r40; fma.rn.f32 %r61,%r60,%r37,%r23; .loc 1 301 0 fma.rn.f32 %r62,%r37,%r48,%r47; fma.rn.f32 %r63,%r62,%r37,%r46; fma.rn.f32 %r64,%r63,%r37,%r45; fma.rn.f32 %r65,%r64,%r37,%r28; fma.rn.f32 %r66,%r65,%r37,0f3f800000; .loc 1 302 0 div.rn.f32 %r67,%r61,%r66; add.f32 %value,%r67,0f3f800000; .loc 1 303 0 st.param.f32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qzerof .func (.param .f32 %value_out) qzerof (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r37; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; mov.f32 %r53,%ar0; .loc 1 429 0 mov.b32 %r37,%r53; .loc 1 430 0 and.b32 %r38,%r37,2147483647; .loc 1 431 0 setp.gt.s32 %r54,%r38,1090519039; @ %r54 bra $L8; .loc 1 432 0 setp.gt.s32 %r55,%r38,1089936471; @ %r55 bra $L9; .loc 1 433 0 setp.gt.s32 %r56,%r38,1077336935; selp.f32 %r51,0fc3153f59,0fc0a9f358,%r56; selp.f32 %r50,0f451d4557,0f4354aa98,%r56; selp.f32 %r49,0f45c9e367,0f445cbbe5,%r56; selp.f32 %r48,0f4567825f,0f44533229,%r56; selp.f32 %r47,0f44316c1c,0f4386ac8f,%r56; selp.f32 %r46,0f4326bbe4,0f4182058c,%r56; selp.f32 %r45,0f432acedf,0f41fd5471,%r56; selp.f32 %r44,0f422a7cc5,0f4167edfd,%r56; selp.f32 %r43,0f405607e3,0f3fffc4bf,%r56; selp.f32 %r42,0f3d95ff70,0f3d95f62a,%r56; selp.f32 %r28,0f42430916,0f41f2ecb8,%r56; selp.f32 %r23,0f3196681b,0f342189db,%r56; bra $L7; $L8: mov.f32 %r51,0fc8a7eb69; mov.f32 %r50,0f494d3359; mov.f32 %r49,0f49441ed4; mov.f32 %r48,0f480b3293; mov.f32 %r47,0f45fd12c2; mov.f32 %r46,0f471096a0; mov.f32 %r45,0f460a6cca; mov.f32 %r44,0f440b6b19; mov.f32 %r43,0f413c4a93; mov.f32 %r42,0f3d960000; .loc 1 431 0 mov.f32 %r28,0f4323c6aa; mov.f32 %r23,0f00000000; bra $L7; $L9: mov.f32 %r51,0fc5a752be; mov.f32 %r50,0f470c88c1; mov.f32 %r49,0f475daf1d; mov.f32 %r48,0f46933e94; mov.f32 %r47,0f4501dd07; mov.f32 %r46,0f44f8bf4b; mov.f32 %r45,0f448067cd; mov.f32 %r44,0f43071c90; mov.f32 %r43,0f40babd86; mov.f32 %r42,0f3d95ffff; .loc 1 432 0 mov.f32 %r28,0f42a58da0; mov.f32 %r23,0f2da1ec79; $L7: .loc 1 435 0 mul.f32 %r57,%r53,%r53; mov.f32 %r58,0f3f800000; div.rn.f32 %r39,%r58,%r57; .loc 1 436 0 fma.rn.f32 %r60,%r39,%r46,%r45; fma.rn.f32 %r61,%r60,%r39,%r44; fma.rn.f32 %r62,%r61,%r39,%r43; fma.rn.f32 %r63,%r62,%r39,%r42; fma.rn.f32 %r64,%r63,%r39,%r23; .loc 1 437 0 fma.rn.f32 %r65,%r39,%r51,%r50; fma.rn.f32 %r66,%r65,%r39,%r49; fma.rn.f32 %r67,%r66,%r39,%r48; fma.rn.f32 %r68,%r67,%r39,%r47; fma.rn.f32 %r69,%r68,%r39,%r28; fma.rn.f32 %r70,%r69,%r39,0f3f800000; .loc 1 438 0 div.rn.f32 %r71,%r64,%r70; mov.f32 %r73,0f3e000000; sub.f32 %r72,%r71,%r73; div.rn.f32 %value,%r72,%r53; .loc 1 439 0 st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j0f .visible .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r42; .reg .f32 %r43; .reg .u32 %r46; .reg .f32 %r48; .reg .f32 %r53; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r68; .reg .pred %r69; .reg .f32 %r71; .reg .f32 %r73; .reg .pred %r74; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .pred %r79; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .pred %r90; .reg .f32 %r91; .reg .pred %r92; .reg .pred %r93; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r103; .reg .pred %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r110; mov.f32 %r62,%ar0; .loc 1 60 0 mov.b32 %r63,%r62; and.b32 %r46,%r63,2147483647; .loc 1 61 0 setp.le.s32 %r64,%r46,2139095039; @ %r64 bra $L12; mul.f32 %r65,%r62,%r62; mov.f32 %r66,0f3f800000; div.rn.f32 %r61,%r66,%r65; bra $L11; $L12: .loc 1 62 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } .loc 1 63 0 setp.le.s32 %r69,%r46,1073741823; @ %r69 bra $L14; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 65 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r73,[%value_in]; } .loc 1 66 0 sub.f32 %r42,%r71,%r73; .loc 1 67 0 add.f32 %r43,%r71,%r73; .loc 1 68 0 setp.gt.s32 %r74,%r46,2130706431; @ %r74 bra $L15; .loc 1 69 0 add.f32 %r76,%r68,%r68; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r76; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r77,[%value_in]; } neg.f32 %r53,%r77; .loc 1 70 0 mul.f32 %r78,%r71,%r73; setp.lt.f32 %r79,%r78,0f00000000; @ ! %r79 bra $L24; div.rn.f32 %r43,%r53,%r42; bra $L15; $L24: .loc 1 71 0 div.rn.f32 %r42,%r53,%r43; $L15: .loc 1 79 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),pzerof,(%out_arg1); ld.param.f32 %r81,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),qzerof,(%out_arg1); ld.param.f32 %r83,[%value_in]; } .loc 1 80 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r85,[%value_in]; } mul.f32 %r86,%r42,%r83; neg.f32 %r87,%r86; fma.rn.f32 %r88,%r43,%r81,%r87; mul.f32 %r89,%r88,0f3f106ebb; div.rn.f32 %r61,%r89,%r85; .loc 1 82 0 bra $L11; $L14: .loc 1 84 0 setp.gt.s32 %r90,%r46,956301311; @ %r90 bra $L18; .loc 1 85 0 add.f32 %r91,%r68,0f7149f2ca; setp.gt.f32 %r92,%r91,0f3f800000; @ ! %r92 bra $L18; .loc 1 86 0 setp.le.s32 %r93,%r46,838860799; @ %r93 bra $L21; .loc 1 87 0 mul.f32 %r95,%r68,0fbe800000; fma.rn.f32 %r61,%r95,%r68,0f3f800000; bra $L11; $L18: .loc 1 90 0 mul.f32 %r48,%r68,%r68; .loc 1 91 0 fma.rn.f32 %r96,%r48,0fb19eaf3c,0f35f58e88; fma.rn.f32 %r97,%r96,%r48,0fb947352e; fma.rn.f32 %r98,%r97,%r48,0f3c800000; mul.f32 %r99,%r98,%r48; .loc 1 92 0 fma.rn.f32 %r100,%r48,0f30a045e8,0f3509daa6; fma.rn.f32 %r101,%r100,%r48,0f38f53697; fma.rn.f32 %r102,%r101,%r48,0f3c7fe744; fma.rn.f32 %r103,%r102,%r48,0f3f800000; div.rn.f32 %r60,%r99,%r103; .loc 1 93 0 setp.gt.s32 %r104,%r46,1065353215; @ %r104 bra $L20; .loc 1 94 0 mov.f32 %r106,0f3e800000; sub.f32 %r105,%r60,%r106; fma.rn.f32 %r61,%r105,%r48,0f3f800000; bra $L11; $L20: .loc 1 97 0 fma.rn.f32 %r107,%r68,0f3f000000,0f3f800000; mul.f32 %r108,%r48,%r60; fma.rn.f32 %r110,%r68,0fbf000000,0f3f800000; fma.rn.f32 %r61,%r107,%r110,%r108; bra $L11; $L21: .loc 1 86 0 mov.f32 %r61,0f3f800000; $L11: .loc 1 99 0 mov.f32 %value,%r61; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y0f .visible .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r39; .reg .f32 %r43; .reg .f32 %r44; .reg .u32 %r46; .reg .u32 %r47; .reg .f32 %r48; .reg .f32 %r53; .reg .f32 %r60; .reg .f32 %r61; .reg .pred %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .pred %r65; .reg .f32 %r66; .reg .pred %r67; .reg .f32 %r68; .reg .pred %r69; .reg .f32 %r71; .reg .f32 %r73; .reg .pred %r74; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .pred %r79; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r103; .reg .f32 %r105; .reg .f32 %r106; mov.f32 %r61,%ar0; .loc 1 128 0 mov.b32 %r46,%r61; .loc 1 129 0 and.b32 %r47,%r46,2147483647; .loc 1 131 0 setp.le.s32 %r62,%r47,2139095039; @ %r62 bra $L26; fma.rn.f32 %r63,%r61,%r61,%r61; mov.f32 %r64,0f3f800000; div.rn.f32 %r60,%r64,%r63; bra $L25; $L26: .loc 1 132 0 setp.ne.u32 %r65,%r47,0; @ %r65 bra $L28; mov.f32 %r66,0fbf800000; div.rn.f32 %r60,%r66,0f00000000; bra $L25; $L28: .loc 1 133 0 setp.ge.s32 %r67,%r46,0; @ %r67 bra $L29; mov.f32 %r68,0f00000000; div.rn.f32 %r60,%r68,0f00000000; bra $L25; $L29: .loc 1 134 0 setp.le.s32 %r69,%r47,1073741823; @ %r69 bra $L30; .loc 1 146 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 147 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r73,[%value_in]; } .loc 1 148 0 sub.f32 %r43,%r71,%r73; .loc 1 149 0 add.f32 %r44,%r71,%r73; .loc 1 154 0 setp.gt.s32 %r74,%r47,2130706431; @ %r74 bra $L31; .loc 1 155 0 add.f32 %r76,%r61,%r61; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r76; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r77,[%value_in]; } neg.f32 %r53,%r77; .loc 1 156 0 mul.f32 %r78,%r71,%r73; setp.lt.f32 %r79,%r78,0f00000000; @ ! %r79 bra $L36; div.rn.f32 %r44,%r53,%r43; bra $L31; $L36: .loc 1 157 0 div.rn.f32 %r43,%r53,%r44; $L31: .loc 1 161 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),pzerof,(%out_arg1); ld.param.f32 %r81,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),qzerof,(%out_arg1); ld.param.f32 %r83,[%value_in]; } .loc 1 162 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r85,[%value_in]; } mul.f32 %r86,%r44,%r83; fma.rn.f32 %r87,%r43,%r81,%r86; mul.f32 %r88,%r87,0f3f106ebb; div.rn.f32 %r60,%r88,%r85; .loc 1 164 0 bra $L25; $L30: .loc 1 166 0 setp.gt.s32 %r89,%r47,838860800; @ %r89 bra $L34; .loc 1 167 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } fma.rn.f32 %r60,%r91,0f3f22f983,0fbd9726b5; bra $L25; $L34: .loc 1 169 0 mul.f32 %r48,%r61,%r61; .loc 1 170 0 fma.rn.f32 %r92,%r48,0fae2f21eb,0f32a802ba; fma.rn.f32 %r93,%r92,%r48,0fb67ff53c; fma.rn.f32 %r94,%r93,%r48,0f39b62a69; fma.rn.f32 %r95,%r94,%r48,0fbc626746; fma.rn.f32 %r96,%r95,%r48,0f3e34e80d; fma.rn.f32 %r97,%r96,%r48,0fbd9726b5; .loc 1 171 0 fma.rn.f32 %r98,%r48,0f2ff280c2,0f348b216c; fma.rn.f32 %r99,%r98,%r48,0f389f65e0; fma.rn.f32 %r100,%r99,%r48,0f3c509385; fma.rn.f32 %r101,%r100,%r48,0f3f800000; .loc 1 172 0 div.rn.f32 %r39,%r97,%r101; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r103,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r105,[%value_in]; } mul.f32 %r106,%r103,%r105; fma.rn.f32 %r60,%r106,0f3f22f983,%r39; $L25: .loc 1 173 0 mov.f32 %value,%r60; st.param.f32 [%value_out],%value; ret; } lib_a-ef_j1.o/ 0 0 0 644 13730 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: ponef .func (.param .f32 %value_out) ponef (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_j1.c" // BEGIN FUNCTION DECL: qonef .func (.param .f32 %value_out) qonef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1f .visible .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1f .visible .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN FUNCTION DEF: ponef .func (.param .f32 %value_out) ponef (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; mov.f32 %r50,%ar0; .loc 1 292 0 mov.b32 %r35,%r50; .loc 1 293 0 and.b32 %r36,%r35,2147483647; .loc 1 294 0 setp.gt.s32 %r51,%r36,1090519039; @ %r51 bra $L3; .loc 1 295 0 setp.gt.s32 %r52,%r36,1089936471; @ %r52 bra $L4; .loc 1 296 0 setp.gt.s32 %r53,%r36,1077336935; selp.f32 %r48,0f42cf936c,0f4105d590,%r53; selp.f32 %r47,0f445eb3ed,0f42eb5bd7,%r53; selp.f32 %r46,0f4482dbe3,0f436846c7,%r53; selp.f32 %r45,0f43a86198,0f42fa9499,%r53; selp.f32 %r44,0f42423c7c,0f40a25a4d,%r53; selp.f32 %r43,0f42b61c2a,0f418d8d41,%r53; selp.f32 %r42,0f420c7a45,0f4143e1bc,%r53; selp.f32 %r41,0f407bb5e7,0f401795c0,%r53; selp.f32 %r40,0f3defffab,0f3deffa16,%r53; selp.f32 %r28,0f420b2a4d,0f41ab7dec,%r53; selp.f32 %r23,0f314fe10d,0f33e74ea8,%r53; bra $L2; $L3: mov.f32 %r48,0f46f0a88b; mov.f32 %r47,0f47bea166; mov.f32 %r46,0f47105c35; mov.f32 %r45,0f45642ee5; mov.f32 %r44,0f45f753d6; mov.f32 %r43,0f45722bed; mov.f32 %r42,0f43ce06a3; mov.f32 %r41,0f4153d4ea; mov.f32 %r40,0f3df00000; .loc 1 294 0 mov.f32 %r28,0f42e46a2c; mov.f32 %r23,0f00000000; bra $L2; $L4: mov.f32 %r48,0f44bc0180; mov.f32 %r47,0f45f52586; mov.f32 %r46,0f45a74a23; mov.f32 %r45,0f4477d9b1; mov.f32 %r44,0f44042dc6; mov.f32 %r43,0f440168b7; mov.f32 %r42,0f42d89dca; mov.f32 %r41,0f40d9b023; mov.f32 %r40,0f3defffff; .loc 1 295 0 mov.f32 %r28,0f426d1f55; mov.f32 %r23,0f2d68333f; $L2: .loc 1 298 0 mul.f32 %r54,%r50,%r50; mov.f32 %r55,0f3f800000; div.rn.f32 %r37,%r55,%r54; .loc 1 299 0 fma.rn.f32 %r57,%r37,%r44,%r43; fma.rn.f32 %r58,%r57,%r37,%r42; fma.rn.f32 %r59,%r58,%r37,%r41; fma.rn.f32 %r60,%r59,%r37,%r40; fma.rn.f32 %r61,%r60,%r37,%r23; .loc 1 300 0 fma.rn.f32 %r62,%r37,%r48,%r47; fma.rn.f32 %r63,%r62,%r37,%r46; fma.rn.f32 %r64,%r63,%r37,%r45; fma.rn.f32 %r65,%r64,%r37,%r28; fma.rn.f32 %r66,%r65,%r37,0f3f800000; .loc 1 301 0 div.rn.f32 %r67,%r61,%r66; add.f32 %value,%r67,0f3f800000; .loc 1 302 0 st.param.f32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: qonef .func (.param .f32 %value_out) qonef (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r28; .reg .u32 %r37; .reg .f32 %r39; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r46; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; mov.f32 %r53,%ar0; .loc 1 429 0 mov.b32 %r37,%r53; .loc 1 430 0 and.b32 %r54,%r37,2147483647; .loc 1 431 0 setp.gt.s32 %r55,%r54,1075838975; selp.f32 %r51,0fc88fcb48,0fc09eb437,%r55; selp.f32 %r50,0f4922be94,0f431bf2f2,%r55; selp.f32 %r49,0f492fb29c,0f4438d92a,%r55; selp.f32 %r48,0f4802bcd6,0f443d602e,%r55; selp.f32 %r47,0f45f48b17,0f437cfb47,%r55; selp.f32 %r46,0fc73d3683,0fc1aaf9b2,%r55; selp.f32 %r45,0fc639273a,0fc2294d1f,%r55; selp.f32 %r44,0fc43de683,0fc19d4f16,%r55; selp.f32 %r43,0fc1822c8d,0fc0302423,%r55; selp.f32 %r42,0fbdd20000,0fbdd1f475,%r55; selp.f32 %r28,0f43216537,0f41ec4454,%r55; selp.f32 %r23,0f00000000,0fb43f8932,%r55; .loc 1 435 0 mul.f32 %r56,%r53,%r53; mov.f32 %r57,0f3f800000; div.rn.f32 %r39,%r57,%r56; .loc 1 436 0 fma.rn.f32 %r59,%r39,%r46,%r45; fma.rn.f32 %r60,%r59,%r39,%r44; fma.rn.f32 %r61,%r60,%r39,%r43; fma.rn.f32 %r62,%r61,%r39,%r42; fma.rn.f32 %r63,%r62,%r39,%r23; .loc 1 437 0 fma.rn.f32 %r64,%r39,%r51,%r50; fma.rn.f32 %r65,%r64,%r39,%r49; fma.rn.f32 %r66,%r65,%r39,%r48; fma.rn.f32 %r67,%r66,%r39,%r47; fma.rn.f32 %r68,%r67,%r39,%r28; fma.rn.f32 %r69,%r68,%r39,0f3f800000; .loc 1 438 0 div.rn.f32 %r70,%r63,%r69; add.f32 %r71,%r70,0f3ec00000; div.rn.f32 %value,%r71,%r53; .loc 1 439 0 st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_j1f .visible .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r38; .reg .f32 %r39; .reg .u32 %r41; .reg .u32 %r42; .reg .f32 %r44; .reg .f32 %r45; .reg .f32 %r56; .reg .f32 %r57; .reg .pred %r58; .reg .f32 %r59; .reg .f32 %r61; .reg .pred %r62; .reg .f32 %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .pred %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .pred %r73; .reg .f32 %r75; .reg .f32 %r77; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r83; .reg .pred %r84; .reg .pred %r85; .reg .f32 %r86; .reg .pred %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; mov.f32 %r57,%ar0; .loc 1 60 0 mov.b32 %r41,%r57; .loc 1 61 0 and.b32 %r42,%r41,2147483647; .loc 1 62 0 setp.le.s32 %r58,%r42,2139095039; @ %r58 bra $L10; mov.f32 %r59,0f3f800000; div.rn.f32 %r56,%r59,%r57; bra $L9; $L10: .loc 1 63 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r57; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r61,[%value_in]; } .loc 1 64 0 setp.le.s32 %r62,%r42,1073741823; @ %r62 bra $L12; .loc 1 65 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r64,[%value_in]; } .loc 1 66 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r66,[%value_in]; } .loc 1 67 0 neg.f32 %r67,%r64; sub.f32 %r38,%r67,%r66; .loc 1 68 0 sub.f32 %r39,%r64,%r66; .loc 1 69 0 setp.gt.s32 %r68,%r42,2130706431; @ %r68 bra $L13; .loc 1 70 0 add.f32 %r70,%r61,%r61; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r70; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r71,[%value_in]; } .loc 1 71 0 mul.f32 %r72,%r64,%r66; setp.gt.f32 %r73,%r72,0f00000000; @ ! %r73 bra $L18; div.rn.f32 %r39,%r71,%r38; bra $L13; $L18: .loc 1 72 0 div.rn.f32 %r38,%r71,%r39; $L13: .loc 1 80 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),ponef,(%out_arg1); ld.param.f32 %r75,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),qonef,(%out_arg1); ld.param.f32 %r77,[%value_in]; } .loc 1 81 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r79,[%value_in]; } mul.f32 %r80,%r38,%r77; neg.f32 %r81,%r80; fma.rn.f32 %r82,%r39,%r75,%r81; mul.f32 %r83,%r82,0f3f106ebb; div.rn.f32 %r56,%r83,%r79; .loc 1 83 0 setp.ge.s32 %r84,%r41,0; @ %r84 bra $L9; neg.f32 %r56,%r56; bra $L9; $L12: mul.f32 %r56,%r57,0f3f000000; .loc 1 86 0 setp.gt.s32 %r85,%r42,838860799; @ %r85 bra $L16; .loc 1 87 0 add.f32 %r86,%r57,0f7149f2ca; setp.gt.f32 %r87,%r86,0f3f800000; @ %r87 bra $L9; $L16: .loc 1 89 0 mul.f32 %r44,%r57,%r57; .loc 1 90 0 fma.rn.f32 %r88,%r44,0f335557d2,0fb7862e36; fma.rn.f32 %r89,%r88,%r44,0f3ab86cfd; fma.rn.f32 %r90,%r89,%r44,0fbd800000; mul.f32 %r45,%r90,%r44; .loc 1 92 0 mul.f32 %r91,%r57,%r45; .loc 1 91 0 fma.rn.f32 %r92,%r44,0f2d59567e,0f31ad6446; fma.rn.f32 %r93,%r92,%r44,0f359dffc2; fma.rn.f32 %r94,%r93,%r44,0f3942fab6; fma.rn.f32 %r95,%r94,%r44,0f3c9ce859; fma.rn.f32 %r96,%r95,%r44,0f3f800000; .loc 1 93 0 div.rn.f32 %r97,%r91,%r96; add.f32 %r56,%r56,%r97; $L9: .loc 1 94 0 mov.f32 %value,%r56; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_y1f .visible .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r40; .reg .f32 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .f32 %r50; .reg .f32 %r61; .reg .f32 %r62; .reg .pred %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .pred %r66; .reg .f32 %r67; .reg .pred %r68; .reg .f32 %r69; .reg .pred %r70; .reg .f32 %r72; .reg .f32 %r74; .reg .f32 %r75; .reg .pred %r76; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .pred %r81; .reg .pred %r82; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r87; .reg .f32 %r89; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .pred %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r107; .reg .f32 %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r113; .reg .f32 %r114; mov.f32 %r62,%ar0; .loc 1 129 0 mov.b32 %r48,%r62; .loc 1 130 0 and.b32 %r49,%r48,2147483647; .loc 1 132 0 setp.le.s32 %r63,%r49,2139095039; @ %r63 bra $L20; fma.rn.f32 %r64,%r62,%r62,%r62; mov.f32 %r65,0f3f800000; div.rn.f32 %r61,%r65,%r64; bra $L19; $L20: .loc 1 133 0 setp.ne.u32 %r66,%r49,0; @ %r66 bra $L22; mov.f32 %r67,0fbf800000; div.rn.f32 %r61,%r67,0f00000000; bra $L19; $L22: .loc 1 134 0 setp.ge.s32 %r68,%r48,0; @ %r68 bra $L23; mov.f32 %r69,0f00000000; div.rn.f32 %r61,%r69,0f00000000; bra $L19; $L23: .loc 1 135 0 setp.le.s32 %r70,%r49,1073741823; @ %r70 bra $L24; .loc 1 136 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r72,[%value_in]; } .loc 1 137 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r74,[%value_in]; } .loc 1 138 0 neg.f32 %r75,%r72; sub.f32 %r46,%r75,%r74; .loc 1 139 0 sub.f32 %r47,%r72,%r74; .loc 1 140 0 setp.gt.s32 %r76,%r49,2130706431; @ %r76 bra $L25; .loc 1 141 0 add.f32 %r78,%r62,%r62; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r78; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r79,[%value_in]; } .loc 1 142 0 mul.f32 %r80,%r72,%r74; setp.gt.f32 %r81,%r80,0f00000000; @ ! %r81 bra $L31; div.rn.f32 %r47,%r79,%r46; bra $L25; $L31: .loc 1 143 0 div.rn.f32 %r46,%r79,%r47; $L25: .loc 1 156 0 setp.le.s32 %r82,%r49,1207959552; @ %r82 bra $L28; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r84,[%value_in]; } mul.f32 %r85,%r46,0f3f106ebb; div.rn.f32 %r61,%r85,%r84; bra $L19; $L28: .loc 1 158 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),ponef,(%out_arg1); ld.param.f32 %r87,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),qonef,(%out_arg1); ld.param.f32 %r89,[%value_in]; } .loc 1 159 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r91,[%value_in]; } mul.f32 %r92,%r47,%r89; fma.rn.f32 %r93,%r46,%r87,%r92; mul.f32 %r94,%r93,0f3f106ebb; div.rn.f32 %r61,%r94,%r91; bra $L19; $L24: .loc 1 163 0 setp.gt.s32 %r95,%r49,612368384; @ %r95 bra $L29; .loc 1 164 0 mov.f32 %r96,0fbf22f983; div.rn.f32 %r61,%r96,%r62; bra $L19; $L29: .loc 1 166 0 mul.f32 %r50,%r62,%r62; .loc 1 167 0 fma.rn.f32 %r97,%r50,0fb3c56003,0f37c5581c; fma.rn.f32 %r98,%r97,%r50,0fbafaaf2a; fma.rn.f32 %r99,%r98,%r50,0f3d4e9e3c; fma.rn.f32 %r100,%r99,%r50,0fbe48c331; .loc 1 168 0 fma.rn.f32 %r101,%r50,0f2d9281cf,0f31d5f8eb; fma.rn.f32 %r102,%r101,%r50,0f35b602d4; fma.rn.f32 %r103,%r102,%r50,0f3954644b; fma.rn.f32 %r104,%r103,%r50,0f3ca3286a; fma.rn.f32 %r105,%r104,%r50,0f3f800000; .loc 1 169 0 div.rn.f32 %r40,%r100,%r105; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r107,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r109,[%value_in]; } mov.f32 %r111,0f3f800000; div.rn.f32 %r110,%r111,%r62; neg.f32 %r112,%r110; fma.rn.f32 %r113,%r107,%r109,%r112; mul.f32 %r114,%r113,0f3f22f983; fma.rn.f32 %r61,%r40,%r62,%r114; $L19: .loc 1 170 0 mov.f32 %value,%r61; st.param.f32 [%value_out],%value; ret; } lib_a-ef_jn.o/ 0 0 0 644 12201 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_jnf .visible .func (.param .f32 %value_out) __ieee754_jnf (.param .u32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_jn.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_ynf .visible .func (.param .f32 %value_out) __ieee754_ynf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0f .extern .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1f .extern .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0f .extern .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1f .extern .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_jnf .visible .func (.param .f32 %value_out) __ieee754_jnf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r45; .reg .f32 %r53; .reg .f32 %r57; .reg .u32 %r59; .reg .f32 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .f32 %r66; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r77; .reg .f32 %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .u32 %r98; .reg .f32 %r99; .reg .u32 %r100; .reg .u32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .u32 %r107; .reg .f32 %r108; .reg .pred %r109; .reg .pred %r110; .reg .pred %r111; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r116; .reg .u32 %r118; .reg .f32 %r120; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r125; .reg .u32 %r126; .reg .u16 %r127; .reg .u16 %r128; .reg .u16 %r129; .reg .u32 %r130; .reg .u16 %r131; .reg .pred %r132; .reg .pred %r133; .reg .f32 %r135; .reg .f32 %r137; .reg .u32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .pred %r142; .reg .pred %r143; .reg .pred %r144; .reg .f32 %r145; .reg .pred %r146; .reg .f32 %r148; .reg .f32 %r149; .reg .pred %r150; .reg .f32 %r151; .reg .pred %r152; .reg .pred %r154; .reg .f32 %r155; .reg .f32 %r156; .reg .f32 %r157; .reg .pred %r158; .reg .f32 %r160; .reg .f32 %r161; .reg .f32 %r163; .reg .f32 %r164; .reg .pred %r165; .reg .f32 %r166; .reg .f32 %r167; .reg .pred %r168; .reg .f32 %r169; .reg .f32 %r170; .reg .pred %r171; .reg .pred %r172; .reg .f32 %r174; .reg .f32 %r175; .reg .pred %r176; .reg .f32 %r178; mov.u32 %r107,%ar0; mov.f32 %r108,%ar1; .loc 1 47 0 mov.b32 %r80,%r108; .loc 1 48 0 and.b32 %r81,%r80,2147483647; .loc 1 50 0 setp.le.s32 %r109,%r81,2139095040; @ %r109 bra $L2; add.f32 %r106,%r108,%r108; bra $L1; $L2: .loc 1 51 0 setp.ge.s32 %r110,%r107,0; @ %r110 bra $L4; .loc 1 52 0 neg.s32 %r107,%r107; .loc 1 53 0 neg.f32 %r108,%r108; .loc 1 54 0 add.u32 %r80,%r80,-2147483648; bra $L5; $L4: .loc 1 56 0 setp.ne.u32 %r111,%r107,0; @ %r111 bra $L5; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r108; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r113,[%value_in]; } mov.f32 %r106,%r113; bra $L1; $L5: .loc 1 57 0 setp.ne.u32 %r114,%r107,1; @ %r114 bra $L6; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r108; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r116,[%value_in]; } mov.f32 %r106,%r116; bra $L1; $L6: .loc 1 58 0 shr.u32 %r118,%r80,31; and.b32 %r82,%r118,%r107; .loc 1 59 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r108; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r120,[%value_in]; } .loc 1 60 0 set.u32.eq.u32 %r122,%r81,0; neg.s32 %r123,%r122; set.u32.eq.u32 %r125,%r81,2139095040; neg.s32 %r126,%r125; cvt.u16.u32 %r128,%r123; cvt.u16.u32 %r129,%r126; or.b16 %r127,%r128,%r129; cvt.u32.u16 %r130,%r127; cvt.u16.u8 %r131,%r130; setp.ne.u16 %r132,%r131,0; @ %r132 bra $L25; .loc 1 62 0 cvt.rn.f32.s32 %r53,%r107; setp.le.f32 %r133,%r53,%r120; @ ! %r133 bra $L40; .loc 1 64 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r120; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r135,[%value_in]; } mov.f32 %r62,%r135; .loc 1 65 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r120; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r137,[%value_in]; } mov.f32 %r99,%r137; .loc 1 66 0 mov.u32 %r100,1; bra $L10; $L26: .loc 1 68 0 mov.f32 %r99,%r106; $L10: add.u32 %r138,%r100,%r100; cvt.rn.f32.s32 %r139,%r138; div.rn.f32 %r140,%r139,%r120; neg.f32 %r141,%r62; fma.rn.f32 %r106,%r140,%r99,%r141; .loc 1 66 0 add.u32 %r100,%r100,1; mov.f32 %r62,%r99; setp.lt.s32 %r142,%r100,%r107; @ %r142 bra $L26; bra $L7; $L40: .loc 1 72 0 setp.gt.s32 %r143,%r81,813694975; @ %r143 bra $L11; .loc 1 76 0 setp.gt.s32 %r144,%r107,33; @ %r144 bra $L27; .loc 1 79 0 mul.f32 %r95,%r120,0f3f000000; mov.f32 %r97,%r95; .loc 1 80 0 mov.f32 %r96,0f3f800000; mov.u32 %r98,2; $L12: .loc 1 81 0 cvt.rn.f32.s32 %r145,%r98; mul.f32 %r96,%r96,%r145; .loc 1 82 0 mul.f32 %r97,%r97,%r95; .loc 1 80 0 add.u32 %r98,%r98,1; setp.le.s32 %r146,%r98,%r107; @ %r146 bra $L12; .loc 1 84 0 div.rn.f32 %r106,%r97,%r96; bra $L7; $L11: .loc 1 118 0 add.u32 %r59,%r107,%r107; cvt.rn.f32.s32 %r148,%r59; div.rn.f32 %r61,%r148,%r120; mov.f32 %r149,0f40000000; div.rn.f32 %r84,%r149,%r120; .loc 1 119 0 add.f32 %r85,%r61,%r84; fma.rn.f32 %r57,%r61,%r85,0fbf800000; .loc 1 120 0 setp.lt.f32 %r150,%r57,0f4e6e6b28; @ ! %r150 bra $L41; .loc 1 119 0 mov.u32 %r93,1; $L15: .loc 1 121 0 add.u32 %r93,%r93,1; add.f32 %r85,%r85,%r84; .loc 1 122 0 neg.f32 %r151,%r61; mov.f32 %r61,%r57; .loc 1 124 0 fma.rn.f32 %r57,%r85,%r57,%r151; .loc 1 120 0 setp.lt.f32 %r152,%r57,0f4e6e6b28; @ %r152 bra $L15; bra $L13; $L41: .loc 1 119 0 mov.u32 %r93,1; $L13: .loc 1 127 0 add.u32 %r63,%r93,%r107; add.u32 %r45,%r63,%r63; setp.lt.s32 %r154,%r63,%r107; @ %r154 bra $L29; mov.f32 %r78,0f00000000; mov.f32 %r157,0f3f800000; $L17: cvt.rn.f32.s32 %r155,%r45; div.rn.f32 %r156,%r155,%r120; sub.f32 %r66,%r156,%r78; div.rn.f32 %r78,%r157,%r66; add.u32 %r45,%r45,-2; setp.le.s32 %r158,%r59,%r45; @ %r158 bra $L17; bra $L16; $L29: mov.f32 %r78,0f00000000; $L16: .loc 1 140 0 mul.f32 %r160,%r53,%r84; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r160; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r161,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r161; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r163,[%value_in]; } add.u32 %r92,%r107,-1; add.u32 %r104,%r59,-2; mul.f32 %r164,%r53,%r163; .loc 1 141 0 setp.lt.f32 %r165,%r164,0f42b17180; @ ! %r165 bra $L42; .loc 1 142 0 cvt.rn.f32.s32 %r91,%r104; mov.f32 %r77,%r78; .loc 1 129 0 mov.f32 %r105,0f3f800000; .loc 1 147 0 mov.f32 %r167,0f40000000; bra $L20; $L30: .loc 1 145 0 mov.f32 %r105,%r75; $L20: .loc 1 144 0 mul.f32 %r166,%r105,%r91; .loc 1 145 0 div.rn.f32 %r70,%r166,%r120; sub.f32 %r75,%r70,%r77; .loc 1 147 0 sub.f32 %r91,%r91,%r167; .loc 1 142 0 add.u32 %r92,%r92,-1; mov.f32 %r77,%r105; setp.ne.u32 %r168,%r92,0; @ %r168 bra $L30; bra $L21; $L42: .loc 1 150 0 cvt.rn.f32.s32 %r89,%r104; mov.f32 %r74,%r78; .loc 1 129 0 mov.f32 %r75,0f3f800000; .loc 1 155 0 mov.f32 %r170,0f40000000; .loc 1 160 0 mov.f32 %r178,%r75; $L24: .loc 1 152 0 mul.f32 %r169,%r75,%r89; .loc 1 153 0 div.rn.f32 %r71,%r169,%r120; sub.f32 %r88,%r71,%r74; .loc 1 155 0 sub.f32 %r89,%r89,%r170; .loc 1 157 0 setp.gt.f32 %r171,%r88,0f501502f9; @ ! %r171 bra $L43; .loc 1 158 0 div.rn.f32 %r74,%r75,%r88; .loc 1 159 0 div.rn.f32 %r78,%r78,%r88; .loc 1 160 0 mov.f32 %r75,%r178; bra $L22; $L43: mov.f32 %r74,%r75; .loc 1 153 0 mov.f32 %r75,%r88; $L22: .loc 1 150 0 add.u32 %r92,%r92,-1; setp.ne.u32 %r172,%r92,0; @ %r172 bra $L24; $L21: .loc 1 164 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r120; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r174,[%value_in]; } mul.f32 %r175,%r174,%r78; div.rn.f32 %r106,%r175,%r75; bra $L7; $L25: .loc 1 61 0 mov.f32 %r106,0f00000000; bra $L7; $L27: mov.f32 %r106,0f00000000; $L7: .loc 1 167 0 setp.ne.u32 %r176,%r82,1; @ %r176 bra $L1; neg.f32 %r106,%r106; $L1: .loc 1 168 0 mov.f32 %value,%r106; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ieee754_ynf .visible .func (.param .f32 %value_out) __ieee754_ynf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .f32 %r41; .reg .u32 %r45; .reg .f32 %r47; .reg .f32 %r49; .reg .u32 %r50; .reg .f32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .f32 %r63; .reg .pred %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .pred %r68; .reg .f32 %r70; .reg .f32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .u32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .u32 %r89; .reg .u16 %r90; .reg .pred %r91; .reg .pred %r92; mov.u32 %r50,%ar0; mov.f32 %r51,%ar1; .loc 1 181 0 mov.b32 %r37,%r51; .loc 1 182 0 and.b32 %r38,%r37,2147483647; .loc 1 184 0 setp.le.s32 %r52,%r38,2139095040; @ %r52 bra $L45; add.f32 %r49,%r51,%r51; bra $L44; $L45: .loc 1 185 0 setp.ne.u32 %r53,%r38,0; @ %r53 bra $L47; mov.f32 %r54,0fbf800000; div.rn.f32 %r49,%r54,0f00000000; bra $L44; $L47: .loc 1 186 0 setp.ge.s32 %r55,%r37,0; @ %r55 bra $L48; mov.f32 %r56,0f00000000; div.rn.f32 %r49,%r56,0f00000000; bra $L44; $L48: .loc 1 188 0 setp.ge.s32 %r57,%r50,0; @ %r57 bra $L49; .loc 1 189 0 neg.s32 %r50,%r50; .loc 1 190 0 add.u32 %r58,%r50,%r50; and.b32 %r59,%r58,2; mov.u32 %r60,1; sub.u32 %r40,%r60,%r59; bra $L50; $L49: .loc 1 192 0 setp.ne.u32 %r61,%r50,0; @ %r61 bra $L54; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y0f,(%out_arg1); ld.param.f32 %r63,[%value_in]; } mov.f32 %r49,%r63; bra $L44; $L54: .loc 1 187 0 mov.u32 %r40,1; $L50: .loc 1 193 0 setp.ne.u32 %r64,%r50,1; @ %r64 bra $L51; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y1f,(%out_arg1); ld.param.f32 %r66,[%value_in]; } cvt.rn.f32.s32 %r67,%r40; mul.f32 %r49,%r67,%r66; bra $L44; $L51: .loc 1 194 0 setp.eq.u32 %r68,%r38,2139095040; @ %r68 bra $L55; .loc 1 196 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y0f,(%out_arg1); ld.param.f32 %r70,[%value_in]; } mov.f32 %r47,%r70; .loc 1 197 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; call (%value_in),__ieee754_y1f,(%out_arg1); ld.param.f32 %r72,[%value_in]; } mov.f32 %r41,%r72; .loc 1 200 0 mov.b32 %r73,%r41; setp.eq.u32 %r74,%r73,-8388608; @ %r74 bra $L56; mov.u32 %r45,1; bra $L53; $L57: .loc 1 202 0 mov.f32 %r41,%r49; $L53: add.u32 %r75,%r45,%r45; cvt.rn.f32.s32 %r76,%r75; div.rn.f32 %r77,%r76,%r51; neg.f32 %r78,%r47; fma.rn.f32 %r49,%r77,%r41,%r78; .loc 1 200 0 add.u32 %r45,%r45,1; mov.f32 %r47,%r41; set.u32.lt.s32 %r80,%r45,%r50; neg.s32 %r81,%r80; mov.b32 %r83,%r49; set.u32.ne.u32 %r84,%r83,-8388608; neg.s32 %r85,%r84; cvt.u16.u32 %r87,%r81; cvt.u16.u32 %r88,%r85; and.b16 %r86,%r87,%r88; cvt.u32.u16 %r89,%r86; cvt.u16.u8 %r90,%r89; setp.ne.u16 %r91,%r90,0; @ %r91 bra $L57; bra $L52; $L56: .loc 1 197 0 mov.f32 %r49,%r72; $L52: .loc 1 206 0 setp.eq.u32 %r92,%r40,1; @ %r92 bra $L44; neg.f32 %r49,%r49; bra $L44; $L55: .loc 1 194 0 mov.f32 %r49,0f00000000; $L44: .loc 1 207 0 mov.f32 %value,%r49; st.param.f32 [%value_out],%value; ret; } lib_a-ef_log.o/ 0 0 0 644 4936 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .visible .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_log.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_logf .visible .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .u32 %r64; .reg .f32 %r65; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r84; .reg .f32 %r85; .reg .u32 %r86; .reg .pred %r87; .reg .f32 %r88; .reg .pred %r89; .reg .f32 %r90; .reg .pred %r91; .reg .pred %r92; .reg .f32 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .u32 %r102; .reg .u32 %r103; .reg .pred %r104; .reg .pred %r105; .reg .pred %r106; .reg .f32 %r107; .reg .f32 %r109; .reg .f32 %r110; .reg .pred %r111; .reg .f32 %r113; .reg .f32 %r114; .reg .f32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .f32 %r118; .reg .f32 %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u32 %r125; .reg .pred %r126; .reg .f32 %r127; .reg .f32 %r128; .reg .pred %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .f32 %r135; .reg .pred %r136; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; mov.f32 %r85,%ar0; .loc 1 50 0 mov.b32 %r51,%r85; .loc 1 53 0 and.b32 %r86,%r51,2147483647; setp.ne.u32 %r87,%r86,0; @ %r87 bra $L2; .loc 1 54 0 mov.f32 %r88,0fcc000000; div.rn.f32 %r84,%r88,0f00000000; bra $L1; $L2: .loc 1 55 0 setp.ge.s32 %r89,%r51,0; @ %r89 bra $L4; sub.f32 %r90,%r85,%r85; div.rn.f32 %r84,%r90,0f00000000; bra $L1; $L4: .loc 1 56 0 setp.le.s32 %r91,%r51,2139095039; @ %r91 bra $L5; add.f32 %r84,%r85,%r85; bra $L1; $L5: .loc 1 57 0 setp.gt.s32 %r92,%r51,8388607; @ %r92 bra $L13; .loc 1 58 0 mul.f32 %r93,%r85,0f4c000000; .loc 1 59 0 mov.b32 %r51,%r93; .loc 1 58 0 mov.u32 %r50,-25; bra $L6; $L13: .loc 1 52 0 mov.u32 %r50,0; $L6: .loc 1 61 0 shr.s32 %r94,%r51,23; add.u32 %r95,%r94,-127; add.u32 %r55,%r95,%r50; .loc 1 62 0 and.b32 %r56,%r51,8388607; .loc 1 63 0 add.u32 %r96,%r56,4913952; and.b32 %r57,%r96,8388608; .loc 1 65 0 shr.s32 %r97,%r57,23; add.u32 %r59,%r97,%r55; .loc 1 64 0 xor.b32 %r98,%r57,1065353216; or.b32 %r99,%r98,%r56; .loc 1 66 0 mov.b32 %r100,%r99; mov.f32 %r101,0f3f800000; sub.f32 %r60,%r100,%r101; .loc 1 67 0 add.u32 %r102,%r56,15; and.b32 %r103,%r102,8388607; setp.gt.s32 %r104,%r103,15; @ %r104 bra $L7; .loc 1 68 0 setp.neu.f32 %r105,%r60,0f00000000; @ %r105 bra $L8; setp.eq.u32 %r106,%r59,0; @ %r106 bra $L14; cvt.rn.f32.s32 %r73,%r59; .loc 1 69 0 mul.f32 %r107,%r73,0f3717f7d1; fma.rn.f32 %r84,%r73,0f3f317180,%r107; bra $L1; $L8: .loc 1 70 0 fma.rn.f32 %r109,%r60,0fbeaaaaab,0f3f000000; mul.f32 %r110,%r60,%r60; mul.f32 %r71,%r109,%r110; .loc 1 71 0 setp.ne.u32 %r111,%r59,0; @ %r111 bra $L9; sub.f32 %r84,%r60,%r71; bra $L1; $L9: cvt.rn.f32.s32 %r72,%r59; .loc 1 72 0 fma.rn.f32 %r113,%r72,0fb717f7d1,%r71; sub.f32 %r114,%r113,%r60; neg.f32 %r115,%r114; fma.rn.f32 %r84,%r72,0f3f317180,%r115; bra $L1; $L7: .loc 1 74 0 add.f32 %r116,%r60,0f40000000; div.rn.f32 %r61,%r60,%r116; .loc 1 75 0 cvt.rn.f32.s32 %r62,%r59; .loc 1 76 0 mul.f32 %r63,%r61,%r61; .loc 1 77 0 add.u32 %r64,%r56,-3187664; .loc 1 78 0 mul.f32 %r65,%r63,%r63; .loc 1 80 0 fma.rn.f32 %r117,%r65,0f3e1cd04f,0f3e638e29; fma.rn.f32 %r118,%r117,%r65,0f3ecccccd; .loc 1 81 0 fma.rn.f32 %r119,%r65,0f3e178897,0f3e3a3325; fma.rn.f32 %r120,%r119,%r65,0f3e924925; fma.rn.f32 %r121,%r120,%r65,0f3f2aaaab; mul.f32 %r122,%r121,%r63; .loc 1 83 0 fma.rn.f32 %r69,%r118,%r65,%r122; .loc 1 79 0 mov.u32 %r124,3523208; sub.u32 %r123,%r124,%r56; .loc 1 82 0 or.b32 %r125,%r123,%r64; .loc 1 84 0 setp.le.s32 %r126,%r125,0; @ %r126 bra $L10; .loc 1 85 0 mul.f32 %r127,%r60,0f3f000000; mul.f32 %r70,%r127,%r60; add.f32 %r128,%r69,%r70; mul.f32 %r83,%r128,%r61; .loc 1 86 0 setp.ne.u32 %r129,%r59,0; @ %r129 bra $L11; sub.f32 %r130,%r70,%r83; sub.f32 %r84,%r60,%r130; bra $L1; $L11: .loc 1 87 0 fma.rn.f32 %r131,%r62,0f3717f7d1,%r83; sub.f32 %r132,%r70,%r131; sub.f32 %r133,%r132,%r60; neg.f32 %r134,%r133; fma.rn.f32 %r84,%r62,0f3f317180,%r134; bra $L1; $L10: sub.f32 %r135,%r60,%r69; mul.f32 %r81,%r135,%r61; .loc 1 89 0 setp.ne.u32 %r136,%r59,0; @ %r136 bra $L12; sub.f32 %r84,%r60,%r81; bra $L1; $L12: .loc 1 90 0 fma.rn.f32 %r138,%r62,0fb717f7d1,%r81; sub.f32 %r139,%r138,%r60; neg.f32 %r140,%r139; fma.rn.f32 %r84,%r62,0f3f317180,%r140; bra $L1; $L14: .loc 1 68 0 mov.f32 %r84,0f00000000; $L1: .loc 1 92 0 mov.f32 %value,%r84; st.param.f32 [%value_out],%value; ret; } /175 0 0 0 644 2363 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10f .visible .func (.param .f32 %value_out) __ieee754_log10f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_log10.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_log10f .visible .func (.param .f32 %value_out) __ieee754_log10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r28; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r39; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r45; .reg .f32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .f32 %r49; .reg .pred %r50; .reg .f32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .f32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; mov.f32 %r46,%ar0; .loc 1 44 0 mov.b32 %r35,%r46; .loc 1 47 0 and.b32 %r47,%r35,2147483647; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L2; .loc 1 48 0 mov.f32 %r49,0fcc000000; div.rn.f32 %r45,%r49,0f00000000; bra $L1; $L2: .loc 1 49 0 setp.ge.s32 %r50,%r35,0; @ %r50 bra $L4; sub.f32 %r51,%r46,%r46; div.rn.f32 %r45,%r51,0f00000000; bra $L1; $L4: .loc 1 50 0 setp.le.s32 %r52,%r35,2139095039; @ %r52 bra $L5; add.f32 %r45,%r46,%r46; bra $L1; $L5: .loc 1 51 0 setp.gt.s32 %r53,%r35,8388607; @ %r53 bra $L7; .loc 1 52 0 mul.f32 %r54,%r46,0f4c000000; .loc 1 53 0 mov.b32 %r35,%r54; .loc 1 52 0 mov.u32 %r34,-25; bra $L6; $L7: .loc 1 46 0 mov.u32 %r34,0; $L6: .loc 1 55 0 shr.s32 %r55,%r35,23; add.u32 %r56,%r55,-127; add.u32 %r39,%r56,%r34; .loc 1 56 0 shr.u32 %r40,%r39,31; .loc 1 57 0 and.b32 %r28,%r35,8388607; .loc 1 58 0 add.u32 %r57,%r39,%r40; cvt.rn.f32.s32 %r42,%r57; .loc 1 57 0 mov.u32 %r60,127; sub.u32 %r59,%r60,%r40; shl.b32 %r61,%r59,23; or.b32 %r62,%r61,%r28; .loc 1 60 0 mov.b32 %r58,%r62; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r63,[%value_in]; } mul.f32 %r64,%r63,0f3ede5bd9; fma.rn.f32 %r65,%r42,0f355427db,%r64; .loc 1 61 0 fma.rn.f32 %r45,%r42,0f3e9a2080,%r65; $L1: .loc 1 62 0 mov.f32 %value,%r45; st.param.f32 [%value_out],%value; ret; } lib_a-ef_pow.o/ 0 0 0 644 17102 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __ieee754_powf .visible .func (.param .f32 %value_out) __ieee754_powf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_pow.c" // BEGIN GLOBAL FUNCTION DECL: nanf .extern .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_powf .visible .func (.param .f32 %value_out) __ieee754_powf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r26; .reg .f32 %r32; .reg .u32 %r35; .reg .f32 %r38; .reg .u32 %r43; .reg .u32 %r49; .reg .u32 %r67; .reg .u32 %r72; .reg .u32 %r78; .reg .u32 %r103; .reg .f32 %r118; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .f32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u32 %r134; .reg .u32 %r135; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r142; .reg .f32 %r146; .reg .f32 %r147; .reg .f32 %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r153; .reg .f32 %r154; .reg .f32 %r155; .reg .f32 %r157; .reg .f32 %r159; .reg .f32 %r161; .reg .f32 %r163; .reg .f32 %r164; .reg .f32 %r166; .reg .f32 %r168; .reg .f32 %r170; .reg .f32 %r171; .reg .f32 %r172; .reg .u32 %r174; .reg .u32 %r175; .reg .u32 %r176; .reg .f32 %r177; .reg .f32 %r178; .reg .f32 %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r182; .reg .f32 %r183; .reg .f32 %r185; .reg .u32 %r186; .reg .u32 %r187; .reg .u32 %r189; .reg .u32 %r207; .reg .f32 %r208; .reg .u32 %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r212; .reg .f32 %r213; .reg .f32 %r214; .reg .pred %r215; .reg .u32 %r217; .reg .u32 %r218; .reg .u32 %r220; .reg .u32 %r221; .reg .u16 %r222; .reg .u16 %r223; .reg .u16 %r224; .reg .u32 %r225; .reg .u16 %r226; .reg .pred %r227; .reg .pred %r228; .reg .u64 %r229; .reg .f32 %r230; .reg .pred %r232; .reg .pred %r233; .reg .u32 %r234; .reg .u32 %r236; .reg .u32 %r237; .reg .pred %r238; .reg .u32 %r239; .reg .u32 %r240; .reg .pred %r241; .reg .pred %r242; .reg .pred %r243; .reg .pred %r244; .reg .pred %r245; .reg .pred %r246; .reg .pred %r247; .reg .f32 %r248; .reg .pred %r249; .reg .u32 %r251; .reg .u32 %r252; .reg .u32 %r254; .reg .u32 %r255; .reg .u16 %r257; .reg .u16 %r258; .reg .u16 %r259; .reg .u32 %r260; .reg .u16 %r261; .reg .pred %r262; .reg .f32 %r264; .reg .f32 %r266; .reg .u32 %r267; .reg .u32 %r269; .reg .u32 %r270; .reg .u32 %r272; .reg .u32 %r273; .reg .u16 %r274; .reg .u16 %r275; .reg .u16 %r276; .reg .u32 %r277; .reg .u16 %r278; .reg .pred %r279; .reg .pred %r280; .reg .f32 %r281; .reg .u32 %r283; .reg .u32 %r284; .reg .pred %r285; .reg .pred %r286; .reg .u32 %r288; .reg .pred %r289; .reg .pred %r290; .reg .pred %r291; .reg .pred %r292; .reg .f32 %r293; .reg .pred %r294; .reg .pred %r295; .reg .f32 %r296; .reg .f32 %r297; .reg .f32 %r298; .reg .f32 %r299; .reg .f32 %r300; .reg .f32 %r301; .reg .f32 %r302; .reg .f32 %r304; .reg .f32 %r305; .reg .u32 %r306; .reg .f32 %r308; .reg .pred %r309; .reg .f32 %r310; .reg .u32 %r311; .reg .u32 %r312; .reg .pred %r313; .reg .pred %r314; .reg .f32 %r315; .reg .f32 %r316; .reg .u32 %r317; .reg .u32 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .f32 %r323; .reg .f32 %r325; .reg .f32 %r326; .reg .f32 %r327; .reg .f32 %r328; .reg .f32 %r329; .reg .f32 %r330; .reg .f32 %r331; .reg .f32 %r332; .reg .f32 %r333; .reg .f32 %r334; .reg .f32 %r335; .reg .f32 %r336; .reg .f32 %r337; .reg .f32 %r338; .reg .u32 %r339; .reg .f32 %r341; .reg .f32 %r342; .reg .f32 %r343; .reg .f32 %r344; .reg .f32 %r345; .reg .f32 %r346; .reg .u32 %r347; .reg .f32 %r349; .reg .f32 %r350; .reg .f32 %r351; .reg .f32 %r352; .reg .f32 %r353; .reg .f32 %r354; .reg .f32 %r355; .reg .u32 %r356; .reg .f32 %r358; .reg .f32 %r359; .reg .f32 %r360; .reg .u32 %r361; .reg .u32 %r362; .reg .pred %r363; .reg .u32 %r364; .reg .f32 %r365; .reg .f32 %r366; .reg .pred %r367; .reg .pred %r368; .reg .f32 %r369; .reg .pred %r370; .reg .f32 %r371; .reg .f32 %r372; .reg .pred %r373; .reg .f32 %r374; .reg .pred %r375; .reg .f32 %r376; .reg .pred %r377; .reg .f32 %r378; .reg .pred %r379; .reg .f32 %r380; .reg .pred %r381; .reg .u32 %r382; .reg .u32 %r383; .reg .u32 %r384; .reg .u32 %r385; .reg .u32 %r386; .reg .u32 %r387; .reg .u32 %r388; .reg .u32 %r389; .reg .u32 %r390; .reg .u32 %r391; .reg .u32 %r392; .reg .u32 %r393; .reg .pred %r394; .reg .f32 %r395; .reg .u32 %r396; .reg .f32 %r397; .reg .f32 %r398; .reg .f32 %r399; .reg .f32 %r401; .reg .f32 %r402; .reg .f32 %r403; .reg .f32 %r404; .reg .f32 %r405; .reg .f32 %r406; .reg .f32 %r407; .reg .f32 %r408; .reg .f32 %r409; .reg .f32 %r410; .reg .f32 %r411; .reg .f32 %r412; .reg .f32 %r413; .reg .pred %r415; .reg .f32 %r418; .reg .pred %r420; mov.f32 %r213,%ar0; mov.f32 %r214,%ar1; .loc 1 72 0 mov.b32 %r138,%r214; .loc 1 73 0 and.b32 %r134,%r138,2147483647; .loc 1 76 0 setp.eq.u32 %r215,%r134,0; @ %r215 bra $L35; .loc 1 71 0 mov.b32 %r135,%r213; .loc 1 73 0 and.b32 %r130,%r135,2147483647; .loc 1 79 0 set.u32.gt.s32 %r217,%r130,2139095040; neg.s32 %r218,%r217; .loc 1 80 0 set.u32.gt.s32 %r220,%r134,2139095040; neg.s32 %r221,%r220; .loc 1 79 0 cvt.u16.u32 %r223,%r218; cvt.u16.u32 %r224,%r221; or.b16 %r222,%r223,%r224; cvt.u32.u16 %r225,%r222; cvt.u16.u8 %r226,%r225; setp.eq.u16 %r227,%r226,0; @ %r227 bra $L3; .loc 1 81 0 setp.eq.u32 %r228,%r130,1065353216; @ %r228 bra $L36; .loc 1 82 0 cvta.const.u64 %r229,$LC0; { .param .f32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r229; call (%value_in),nanf,(%out_arg1); ld.param.f32 %r230,[%value_in]; } mov.f32 %r212,%r230; bra $L1; $L3: .loc 1 91 0 setp.ge.s32 %r420,%r135,0; @ %r420 bra $L37; .loc 1 92 0 setp.gt.s32 %r232,%r134,1266679807; @ %r232 bra $L38; .loc 1 93 0 setp.le.s32 %r233,%r134,1065353215; @ %r233 bra $L39; .loc 1 94 0 shr.s32 %r234,%r134,23; .loc 1 95 0 mov.u32 %r236,150; sub.u32 %r26,%r236,%r234; shr.s32 %r137,%r134,%r26; .loc 1 96 0 shl.b32 %r237,%r137,%r26; setp.ne.u32 %r238,%r237,%r134; @ %r238 bra $L40; and.b32 %r239,%r137,1; mov.u32 %r240,2; sub.u32 %r126,%r240,%r239; bra $L5; $L37: .loc 1 90 0 mov.u32 %r126,0; bra $L4; $L38: .loc 1 92 0 mov.u32 %r126,2; $L4: .loc 1 101 0 setp.ne.u32 %r241,%r134,2139095040; @ %r241 bra $L5; .loc 1 102 0 setp.eq.u32 %r242,%r130,1065353216; @ %r242 bra $L41; .loc 1 104 0 setp.le.s32 %r243,%r130,1065353216; @ %r243 bra $L6; .loc 1 105 0 setp.ge.s32 %r244,%r138,0; @ %r244 bra $L42; $L7: mov.f32 %r212,0f00000000; bra $L1; $L6: .loc 1 107 0 setp.ge.s32 %r245,%r138,0; @ %r245 bra $L7; neg.f32 %r212,%r214; bra $L1; $L39: .loc 1 90 0 mov.u32 %r126,0; bra $L5; $L40: mov.u32 %r126,0; $L5: .loc 1 109 0 setp.ne.u32 %r246,%r134,1065353216; @ %r246 bra $L8; .loc 1 110 0 setp.ge.s32 %r247,%r138,0; @ %r247 bra $L43; mov.f32 %r248,0f3f800000; div.rn.f32 %r212,%r248,%r213; bra $L1; $L8: .loc 1 112 0 setp.ne.u32 %r249,%r138,1073741824; @ %r249 bra $L9; mul.f32 %r212,%r213,%r213; bra $L1; $L9: .loc 1 114 0 not.b32 %r251,%r135; shr.u32 %r252,%r251,31; .loc 1 113 0 set.u32.eq.u32 %r254,%r138,1056964608; neg.s32 %r255,%r254; .loc 1 114 0 cvt.u16.u32 %r258,%r252; cvt.u16.u32 %r259,%r255; and.b16 %r257,%r258,%r259; cvt.u32.u16 %r260,%r257; cvt.u16.u8 %r261,%r260; setp.eq.u16 %r262,%r261,0; @ %r262 bra $L10; .loc 1 115 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r213; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r264,[%value_in]; } mov.f32 %r212,%r264; bra $L1; $L10: .loc 1 118 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r213; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r266,[%value_in]; } mov.f32 %r212,%r266; .loc 1 120 0 and.b32 %r267,%r135,1073741823; set.u32.eq.u32 %r269,%r267,1065353216; neg.s32 %r270,%r269; set.u32.eq.u32 %r272,%r130,0; neg.s32 %r273,%r272; cvt.u16.u32 %r275,%r270; cvt.u16.u32 %r276,%r273; or.b16 %r274,%r275,%r276; cvt.u32.u16 %r277,%r274; cvt.u16.u8 %r278,%r277; setp.eq.u16 %r279,%r278,0; @ %r279 bra $L11; .loc 1 122 0 setp.ge.s32 %r280,%r138,0; @ %r280 bra $L12; mov.f32 %r281,0f3f800000; div.rn.f32 %r212,%r281,%r212; $L12: .loc 1 123 0 @ %r420 bra $L1; .loc 1 124 0 add.u32 %r283,%r130,-1065353216; or.b32 %r284,%r283,%r126; setp.ne.u32 %r285,%r284,0; @ %r285 bra $L13; .loc 1 125 0 sub.f32 %r32,%r212,%r212; div.rn.f32 %r212,%r32,%r32; bra $L1; $L13: .loc 1 126 0 setp.ne.u32 %r286,%r126,1; @ %r286 bra $L1; .loc 1 127 0 neg.f32 %r212,%r212; bra $L1; $L11: .loc 1 133 0 set.u32.ge.s32 %r35,%r135,0; or.b32 %r288,%r126,%r35; setp.ne.u32 %r289,%r288,0; @ %r289 bra $L14; sub.f32 %r38,%r213,%r213; div.rn.f32 %r212,%r38,%r38; bra $L1; $L14: .loc 1 136 0 setp.le.s32 %r290,%r134,1291845632; @ %r290 bra $L15; .loc 1 138 0 setp.gt.s32 %r291,%r130,1065353207; @ %r291 bra $L16; setp.ge.s32 %r292,%r138,0; @ %r292 bra $L7; $L18: mov.f32 %r293,0f7149f2ca; mul.f32 %r212,%r293,0f7149f2ca; bra $L1; $L16: .loc 1 139 0 setp.le.s32 %r294,%r130,1065353223; @ %r294 bra $L17; setp.gt.s32 %r295,%r138,0; @ %r295 bra $L18; bra $L7; $L17: .loc 1 142 0 mov.f32 %r296,0f3f800000; sub.f32 %r166,%r266,%r296; .loc 1 143 0 neg.f32 %r297,%r166; fma.rn.f32 %r298,%r297,0f3e800000,0f3eaaaaab; neg.f32 %r299,%r298; fma.rn.f32 %r300,%r299,%r166,0f3f000000; mul.f32 %r301,%r166,%r166; mul.f32 %r302,%r300,%r301; .loc 1 145 0 mul.f32 %r304,%r302,0fbfb8aa3b; fma.rn.f32 %r168,%r166,0f36eca570,%r304; .loc 1 146 0 fma.rn.f32 %r305,%r166,0f3fb8aa00,%r168; .loc 1 148 0 mov.b32 %r306,%r305; and.b32 %r43,%r306,-4096; mov.b32 %r123,%r43; .loc 1 149 0 fma.rn.f32 %r308,%r297,0f3fb8aa00,%r123; sub.f32 %r124,%r168,%r308; bra $L19; $L15: .loc 1 154 0 setp.gt.s32 %r309,%r130,8388607; @ %r309 bra $L44; .loc 1 155 0 mul.f32 %r310,%r266,0f4b800000; mov.b32 %r130,%r310; mov.u32 %r127,-24; bra $L20; $L44: .loc 1 152 0 mov.u32 %r127,0; $L20: .loc 1 156 0 shr.s32 %r311,%r130,23; add.u32 %r312,%r311,-127; add.u32 %r128,%r312,%r127; .loc 1 157 0 and.b32 %r142,%r130,8388607; .loc 1 159 0 or.b32 %r131,%r142,1065353216; .loc 1 160 0 setp.le.s32 %r313,%r142,1885297; @ %r313 bra $L45; .loc 1 161 0 setp.le.s32 %r314,%r142,6140886; @ %r314 bra $L46; .loc 1 162 0 add.u32 %r128,%r128,1; add.u32 %r131,%r131,-8388608; mov.f32 %r211,0f00000000; mov.f32 %r210,%r211; mov.u32 %r209,0; mov.f32 %r208,0f3f800000; bra $L21; $L45: mov.f32 %r211,0f00000000; mov.f32 %r210,%r211; mov.u32 %r209,0; mov.f32 %r208,0f3f800000; bra $L21; $L46: mov.f32 %r211,0f3f15c000; mov.f32 %r210,0f35d1cfdc; mov.u32 %r209,2097152; mov.f32 %r208,0f3fc00000; $L21: .loc 1 163 0 mov.b32 %r146,%r131; .loc 1 166 0 sub.f32 %r147,%r146,%r208; .loc 1 167 0 add.f32 %r315,%r146,%r208; mov.f32 %r316,0f3f800000; div.rn.f32 %r148,%r316,%r315; .loc 1 168 0 mul.f32 %r149,%r147,%r148; .loc 1 171 0 mov.b32 %r318,%r149; and.b32 %r317,%r318,-4096; mov.b32 %r150,%r317; .loc 1 173 0 shr.s32 %r319,%r131,1; or.b32 %r320,%r319,536870912; add.u32 %r321,%r320,262144; add.u32 %r322,%r321,%r209; mov.b32 %r151,%r322; .loc 1 175 0 neg.f32 %r323,%r150; fma.rn.f32 %r325,%r323,%r151,%r147; .loc 1 174 0 sub.f32 %r326,%r151,%r208; sub.f32 %r327,%r146,%r326; .loc 1 175 0 fma.rn.f32 %r328,%r323,%r327,%r325; mul.f32 %r153,%r328,%r148; .loc 1 177 0 mul.f32 %r154,%r149,%r149; .loc 1 178 0 mul.f32 %r329,%r154,%r154; .loc 1 179 0 add.f32 %r330,%r149,%r150; mul.f32 %r331,%r330,%r153; .loc 1 178 0 fma.rn.f32 %r332,%r154,0f3e53f142,0f3e6c3255; fma.rn.f32 %r333,%r332,%r154,0f3e8ba305; fma.rn.f32 %r334,%r333,%r154,0f3eaaaaab; fma.rn.f32 %r335,%r334,%r154,0f3edb6db7; fma.rn.f32 %r336,%r335,%r154,0f3f19999a; .loc 1 179 0 fma.rn.f32 %r155,%r329,%r336,%r331; .loc 1 181 0 fma.rn.f32 %r337,%r150,%r150,0f40400000; add.f32 %r338,%r337,%r155; .loc 1 183 0 mov.b32 %r339,%r338; and.b32 %r67,%r339,-4096; mov.b32 %r157,%r67; .loc 1 184 0 mov.f32 %r342,0f40400000; sub.f32 %r341,%r157,%r342; fma.rn.f32 %r343,%r323,%r150,%r341; sub.f32 %r344,%r155,%r343; .loc 1 187 0 mul.f32 %r345,%r344,%r149; fma.rn.f32 %r159,%r153,%r157,%r345; .loc 1 189 0 fma.rn.f32 %r346,%r150,%r157,%r159; .loc 1 191 0 mov.b32 %r347,%r346; and.b32 %r72,%r347,-4096; mov.b32 %r161,%r72; .loc 1 192 0 fma.rn.f32 %r349,%r323,%r157,%r161; sub.f32 %r350,%r159,%r349; .loc 1 194 0 mul.f32 %r351,%r350,0f3f76384f; fma.rn.f32 %r352,%r161,0f369dc3a0,%r351; add.f32 %r163,%r352,%r210; .loc 1 196 0 cvt.rn.f32.s32 %r164,%r128; .loc 1 197 0 fma.rn.f32 %r353,%r161,0f3f763800,%r163; add.f32 %r354,%r353,%r211; add.f32 %r355,%r354,%r164; .loc 1 199 0 mov.b32 %r356,%r355; and.b32 %r78,%r356,-4096; mov.b32 %r123,%r78; .loc 1 200 0 sub.f32 %r358,%r123,%r164; sub.f32 %r359,%r358,%r211; fma.rn.f32 %r360,%r161,0fbf763800,%r359; sub.f32 %r124,%r163,%r360; $L19: .loc 1 204 0 add.u32 %r361,%r126,-1; or.b32 %r362,%r361,%r35; setp.eq.u32 %r363,%r362,0; .loc 1 203 0 selp.f32 %r125,0fbf800000,0f3f800000,%r363; .loc 1 209 0 and.b32 %r364,%r138,-4096; mov.b32 %r170,%r364; .loc 1 210 0 sub.f32 %r365,%r214,%r170; mul.f32 %r366,%r124,%r214; fma.rn.f32 %r171,%r365,%r123,%r366; .loc 1 211 0 mul.f32 %r122,%r123,%r170; .loc 1 212 0 add.f32 %r172,%r171,%r122; .loc 1 213 0 mov.b32 %r49,%r172; .loc 1 214 0 and.b32 %r174,%r49,2147483647; .loc 1 215 0 setp.le.s32 %r367,%r49,0; @ %r367 bra $L23; .loc 1 216 0 setp.le.s32 %r368,%r174,1124073472; @ %r368 bra $L24; .loc 1 217 0 mul.f32 %r369,%r125,0f7149f2ca; mul.f32 %r212,%r369,0f7149f2ca; bra $L1; $L24: .loc 1 218 0 setp.ne.u32 %r370,%r174,1124073472; @ %r370 bra $L25; .loc 1 219 0 add.f32 %r371,%r171,0f3338aa3c; sub.f32 %r372,%r172,%r122; setp.gt.f32 %r373,%r371,%r372; @ ! %r373 bra $L26; mul.f32 %r374,%r125,0f7149f2ca; mul.f32 %r212,%r374,0f7149f2ca; bra $L1; $L23: .loc 1 221 0 setp.le.s32 %r375,%r174,1125515264; @ %r375 bra $L28; .loc 1 222 0 mul.f32 %r376,%r125,0f0da24260; mul.f32 %r212,%r376,0f0da24260; bra $L1; $L28: .loc 1 223 0 setp.ne.u32 %r377,%r174,1125515264; @ %r377 bra $L25; .loc 1 224 0 sub.f32 %r378,%r172,%r122; setp.ge.f32 %r379,%r378,%r171; @ ! %r379 bra $L26; mul.f32 %r380,%r125,0f0da24260; mul.f32 %r212,%r380,0f0da24260; bra $L1; $L25: .loc 1 231 0 setp.le.s32 %r381,%r174,1056964608; @ %r381 bra $L48; .loc 1 229 0 shr.s32 %r189,%r174,23; $L34: .loc 1 232 0 add.u32 %r382,%r189,-126; mov.u32 %r384,8388608; shr.s32 %r383,%r384,%r382; add.u32 %r175,%r383,%r49; .loc 1 233 0 shr.s32 %r385,%r175,23; and.b32 %r386,%r385,255; add.u32 %r176,%r386,-127; .loc 1 234 0 mov.u32 %r388,8388607; shr.s32 %r387,%r388,%r176; not.b32 %r389,%r387; and.b32 %r390,%r389,%r175; mov.b32 %r177,%r390; .loc 1 235 0 and.b32 %r391,%r175,8388607; or.b32 %r103,%r391,8388608; mov.u32 %r393,23; sub.u32 %r392,%r393,%r176; shr.s32 %r129,%r103,%r392; .loc 1 236 0 setp.ge.s32 %r394,%r49,0; @ %r394 bra $L31; neg.s32 %r129,%r129; $L31: .loc 1 237 0 sub.f32 %r122,%r122,%r177; add.f32 %r395,%r171,%r122; mov.b32 %r49,%r395; shl.b32 %r207,%r129,23; bra $L30; $L48: mov.u32 %r207,0; .loc 1 230 0 mov.u32 %r129,%r207; $L30: .loc 1 241 0 and.b32 %r396,%r49,-4096; mov.b32 %r178,%r396; .loc 1 243 0 sub.f32 %r397,%r178,%r122; sub.f32 %r398,%r171,%r397; mul.f32 %r399,%r178,0f35bfbe8c; fma.rn.f32 %r179,%r398,0f3f317218,%r399; .loc 1 244 0 fma.rn.f32 %r180,%r178,0f3f317200,%r179; .loc 1 245 0 fma.rn.f32 %r401,%r178,0fbf317200,%r180; sub.f32 %r181,%r179,%r401; .loc 1 246 0 mul.f32 %r182,%r180,%r180; .loc 1 247 0 fma.rn.f32 %r402,%r182,0f3331bb4c,0fb5ddea0e; fma.rn.f32 %r403,%r402,%r182,0f388ab355; fma.rn.f32 %r404,%r403,%r182,0fbb360b61; fma.rn.f32 %r405,%r404,%r182,0f3e2aaaab; neg.f32 %r406,%r405; fma.rn.f32 %r183,%r406,%r182,%r180; .loc 1 248 0 mul.f32 %r407,%r180,%r183; mov.f32 %r409,0f40000000; sub.f32 %r408,%r183,%r409; div.rn.f32 %r410,%r407,%r408; fma.rn.f32 %r411,%r180,%r181,%r181; sub.f32 %r412,%r410,%r411; .loc 1 249 0 sub.f32 %r118,%r412,%r180; mov.f32 %r413,0f3f800000; sub.f32 %r185,%r413,%r118; .loc 1 250 0 mov.b32 %r186,%r185; .loc 1 251 0 add.u32 %r187,%r186,%r207; .loc 1 252 0 setp.gt.s32 %r415,%r187,8388607; @ %r415 bra $L32; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r185; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r129; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r418,[%value_in]; } mov.f32 %r121,%r418; bra $L33; $L32: .loc 1 253 0 mov.b32 %r121,%r187; $L33: .loc 1 254 0 mul.f32 %r212,%r121,%r125; bra $L1; $L35: .loc 1 76 0 mov.f32 %r212,0f3f800000; bra $L1; $L36: mov.f32 %r212,0f3f800000; bra $L1; $L41: mov.f32 %r212,0f3f800000; bra $L1; $L42: .loc 1 105 0 mov.f32 %r212,%r214; bra $L1; $L43: .loc 1 110 0 mov.f32 %r212,%r213; bra $L1; $L26: .loc 1 229 0 shr.s32 %r189,%r174,23; bra $L34; $L1: .loc 1 255 0 mov.f32 %value,%r212; st.param.f32 [%value_out],%value; ret; } /193 0 0 0 644 9700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .visible .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2f .extern .func (.param .u32 %value_out) __kernel_rem_pio2f (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: npio2_hw .const .align 4 .u32 npio2_hw[32] = {1070141184,1078529792,1083624192,1086918400,1090212608,1092012800,1093659904,1095307008,1096954112,1098601216,1099577856,1100401408,1101224960,1102048512,1102872064,1103695616,1104519168,1105342720,1106166272,1106989824,1107554816,1107966464,1108378368,1108790016,1109201920,1109613568,1110025472,1110437120,1110849024,1111260672,1111672576,1112084224 }; // BEGIN VAR DEF: two_over_pi .const .align 4 .u32 two_over_pi[198] = {162,249,131,110,78,68,21,41,252,39,87,209,245,52,221,192,219,98,149,153,60,67,144,65,254,81,99,171,222,187,197,97,183,36,110,58,66,77,210,224,6,73,46,234,9,209,146,28,254,29,235,28,177,41,167,62,232,130,53,245,46,187,68,132,233,156,112,38,180,95,126,65,57,145,214,57,131,83,57,244,156,132,95,139,189,249,40,59,31,248,151,255,222,5,152,15,239,47,17,139,90,10,109,31,109,54,126,207,39,203,9,183,79,70,63,102,158,95,234,45,117,39,186,199,235,229,241,123,61,7,57,247,138,82,146,234,107,251,95,177,31,141,93,8,86,3,48,70,252,123,107,171,240,207,188,32,154,244,54,29,169,227,145,97,94,230,27,8,101,153,133,95,20,160,104,64,141,255,216,128,77,115,39,49,6,6,21,86,202,115,168,201,96,226,123,192,140,107 }; // BEGIN GLOBAL FUNCTION DEF: __ieee754_rem_pio2f .visible .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r22; .reg .f32 %r24; .reg .f32 %r28; .reg .f32 %r32; .reg .f32 %r35; .reg .u32 %r45; .reg .f32 %r58; .reg .f32 %r61; .reg .f32 %r65; .reg .f32 %r70; .reg .f32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .f32 %r75; .reg .f32 %r78; .reg .f32 %r81; .reg .f32 %r83; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r86; .reg .u32 %r89; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .u32 %r101; .reg .f32 %r102; .reg .u64 %r103; .reg .pred %r104; .reg .f32 %r105; .reg .pred %r106; .reg .pred %r107; .reg .f32 %r108; .reg .pred %r109; .reg .f32 %r110; .reg .f32 %r111; .reg .f32 %r112; .reg .f32 %r114; .reg .f32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .pred %r119; .reg .f32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .pred %r124; .reg .f32 %r126; .reg .f32 %r127; .reg .pred %r129; .reg .u32 %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u32 %r136; .reg .pred %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r141; .reg .pred %r142; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .u32 %r148; .reg .u32 %r149; .reg .u32 %r150; .reg .u32 %r151; .reg .pred %r152; .reg .f32 %r155; .reg .f32 %r156; .reg .f32 %r157; .reg .f32 %r158; .reg .pred %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .pred %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .u32 %r165; .reg .u32 %r166; .reg .u32 %r167; .reg .pred %r168; .reg .pred %r169; .reg .u32 %r174; .reg .u64 %r175; .reg .u32 %r176; .reg .pred %r177; .reg .f32 %r178; .reg .f32 %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r183; mov.f32 %r102,%ar0; mov.u64 %r103,%ar1; .loc 1 110 0 mov.b32 %r72,%r102; .loc 1 111 0 and.b32 %r73,%r72,2147483647; .loc 1 112 0 setp.gt.s32 %r104,%r73,1061752792; @ %r104 bra $L2; .loc 1 113 0 st.f32 [%r103],%r102; mov.f32 %r105,0f00000000; st.f32 [%r103+4],%r105; mov.u32 %r101,0; bra $L1; $L2: .loc 1 114 0 setp.gt.s32 %r106,%r73,1075235811; @ %r106 bra $L4; and.b32 %r89,%r72,2147483632; .loc 1 115 0 setp.le.s32 %r107,%r72,0; @ %r107 bra $L5; .loc 1 116 0 mov.f32 %r108,0f3fc90f80; sub.f32 %r85,%r102,%r108; .loc 1 117 0 setp.eq.u32 %r109,%r89,1070141392; @ %r109 bra $L6; .loc 1 118 0 mov.f32 %r110,0f37354443; sub.f32 %r24,%r85,%r110; st.f32 [%r103],%r24; .loc 1 119 0 sub.f32 %r111,%r85,%r24; sub.f32 %r112,%r111,%r110; st.f32 [%r103+4],%r112; .loc 1 125 0 mov.u32 %r101,1; bra $L1; $L6: .loc 1 121 0 mov.f32 %r114,0f37354400; sub.f32 %r86,%r85,%r114; .loc 1 122 0 mov.f32 %r115,0f2e85a308; sub.f32 %r28,%r86,%r115; st.f32 [%r103],%r28; .loc 1 123 0 sub.f32 %r116,%r86,%r28; sub.f32 %r117,%r116,%r115; st.f32 [%r103+4],%r117; .loc 1 125 0 mov.u32 %r101,1; bra $L1; $L5: .loc 1 127 0 add.f32 %r83,%r102,0f3fc90f80; .loc 1 128 0 setp.eq.u32 %r119,%r89,1070141392; @ %r119 bra $L7; .loc 1 129 0 add.f32 %r32,%r83,0f37354443; st.f32 [%r103],%r32; .loc 1 130 0 sub.f32 %r120,%r83,%r32; add.f32 %r121,%r120,0f37354443; st.f32 [%r103+4],%r121; .loc 1 136 0 mov.u32 %r101,-1; bra $L1; $L7: .loc 1 132 0 add.f32 %r84,%r83,0f37354400; .loc 1 133 0 add.f32 %r35,%r84,0f2e85a308; st.f32 [%r103],%r35; .loc 1 134 0 sub.f32 %r122,%r84,%r35; add.f32 %r123,%r122,0f2e85a308; st.f32 [%r103+4],%r123; .loc 1 136 0 mov.u32 %r101,-1; bra $L1; $L4: .loc 1 139 0 setp.gt.s32 %r124,%r73,1128861568; @ %r124 bra $L8; .loc 1 140 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r102; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r126,[%value_in]; } .loc 1 141 0 fma.rn.f32 %r127,%r126,0f3f22f984,0f3f000000; cvt.rzi.s32.f32 %r101,%r127; .loc 1 142 0 cvt.rn.f32.s32 %r78,%r101; .loc 1 143 0 neg.f32 %r183,%r78; fma.rn.f32 %r71,%r183,0f3fc90f80,%r126; .loc 1 144 0 mul.f32 %r70,%r78,0f37354443; .loc 1 145 0 setp.gt.s32 %r129,%r101,31; @ %r129 bra $L9; sub.f32 %r65,%r71,%r70; and.b32 %r130,%r72,2147483392; cvta.const.u64 %r131,npio2_hw; add.u32 %r132,%r101,-1; cvt.s64.s32 %r133,%r132; shl.b64 %r134,%r133,2; add.u64 %r135,%r131,%r134; ld.u32 %r136,[%r135]; setp.eq.u32 %r137,%r130,%r136; @ %r137 bra $L10; .loc 1 146 0 st.f32 [%r103],%r65; bra $L11; $L9: sub.f32 %r65,%r71,%r70; $L10: .loc 1 149 0 shr.s32 %r45,%r73,23; .loc 1 152 0 mov.b32 %r139,%r65; shr.u32 %r138,%r139,23; and.b32 %r140,%r138,255; sub.u32 %r141,%r45,%r140; .loc 1 153 0 setp.gt.s32 %r142,%r141,8; @ %r142 bra $L12; .loc 1 150 0 st.f32 [%r103],%r65; bra $L11; $L12: .loc 1 156 0 fma.rn.f32 %r81,%r183,0f37354400,%r71; .loc 1 157 0 sub.f32 %r145,%r71,%r81; fma.rn.f32 %r146,%r183,0f37354400,%r145; neg.f32 %r147,%r146; fma.rn.f32 %r70,%r78,0f2e85a308,%r147; .loc 1 158 0 sub.f32 %r65,%r81,%r70; .loc 1 160 0 mov.b32 %r149,%r65; shr.u32 %r148,%r149,23; and.b32 %r150,%r148,255; sub.u32 %r151,%r45,%r150; .loc 1 161 0 setp.gt.s32 %r152,%r151,25; @ %r152 bra $L13; .loc 1 158 0 st.f32 [%r103],%r65; .loc 1 156 0 mov.f32 %r71,%r81; bra $L11; $L13: .loc 1 164 0 fma.rn.f32 %r71,%r183,0f2e85a300,%r81; .loc 1 165 0 sub.f32 %r155,%r81,%r71; fma.rn.f32 %r156,%r183,0f2e85a300,%r155; neg.f32 %r157,%r156; fma.rn.f32 %r70,%r78,0f248d3132,%r157; .loc 1 166 0 sub.f32 %r65,%r71,%r70; st.f32 [%r103],%r65; $L11: .loc 1 170 0 sub.f32 %r158,%r71,%r65; sub.f32 %r58,%r158,%r70; st.f32 [%r103+4],%r58; .loc 1 171 0 setp.ge.s32 %r159,%r72,0; @ %r159 bra $L1; neg.f32 %r160,%r65; st.f32 [%r103],%r160; neg.f32 %r161,%r58; st.f32 [%r103+4],%r161; neg.s32 %r101,%r101; bra $L1; $L8: .loc 1 177 0 setp.le.s32 %r162,%r73,2139095039; @ %r162 bra $L14; .loc 1 178 0 sub.f32 %r61,%r102,%r102; st.f32 [%r103+4],%r61; st.f32 [%r103],%r61; mov.u32 %r101,0; bra $L1; $L14: .loc 1 181 0 shr.s32 %r163,%r73,23; add.u32 %r74,%r163,-134; .loc 1 182 0 shl.b32 %r164,%r74,23; sub.u32 %r165,%r73,%r164; mov.b32 %r75,%r165; .loc 1 184 0 cvt.rzi.s32.f32 %r166,%r75; cvt.rn.f32.s32 %r92,%r166; st.f32 [%frame],%r92; .loc 1 185 0 sub.f32 %r93,%r75,%r92; mul.f32 %r94,%r93,0f43800000; .loc 1 184 0 cvt.rzi.s32.f32 %r167,%r94; cvt.rn.f32.s32 %r97,%r167; st.f32 [%frame+4],%r97; .loc 1 185 0 sub.f32 %r98,%r94,%r97; mul.f32 %r99,%r98,0f43800000; .loc 1 187 0 st.f32 [%frame+8],%r99; .loc 1 189 0 setp.neu.f32 %r168,%r99,0f00000000; @ %r168 bra $L16; setp.eq.f32 %r169,%r97,0f00000000; selp.u32 %r22,1,2,%r169; bra $L15; $L16: .loc 1 188 0 mov.u32 %r22,3; $L15: .loc 1 190 0 cvta.const.u64 %r175,two_over_pi; mov.u32 %r174,2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r103; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r74; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r22; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r174; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r175; call (%value_in),__kernel_rem_pio2f,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u32 %r176,[%value_in]; } mov.u32 %r101,%r176; .loc 1 191 0 setp.ge.s32 %r177,%r72,0; @ %r177 bra $L1; ld.f32 %r179,[%r103]; neg.f32 %r178,%r179; st.f32 [%r103],%r178; ld.f32 %r181,[%r103+4]; neg.f32 %r180,%r181; st.f32 [%r103+4],%r180; neg.s32 %r101,%r101; $L1: .loc 1 193 0 mov.u32 %value,%r101; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } /214 0 0 0 644 3592 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainderf .visible .func (.param .f32 %value_out) __ieee754_remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_remainder.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmodf .extern .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_remainderf .visible .func (.param .f32 %value_out) __ieee754_remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .f32 %r25; .reg .u32 %r30; .reg .f32 %r31; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r38; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r50; .reg .u32 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .u16 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u16 %r59; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .pred %r65; .reg .f32 %r68; .reg .f32 %r69; .reg .pred %r70; .reg .f32 %r72; .reg .f32 %r74; .reg .pred %r75; .reg .f32 %r76; .reg .pred %r77; .reg .f32 %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .u32 %r82; .reg .u32 %r83; mov.f32 %r44,%ar0; mov.f32 %r45,%ar1; .loc 1 36 0 mov.b32 %r22,%r44; .loc 1 37 0 mov.b32 %r33,%r45; .loc 1 39 0 and.b32 %r35,%r33,2147483647; .loc 1 40 0 and.b32 %r36,%r22,2147483647; .loc 1 43 0 set.u32.eq.u32 %r47,%r35,0; neg.s32 %r48,%r47; .loc 1 44 0 set.u32.gt.s32 %r50,%r35,2139095040; neg.s32 %r51,%r50; cvt.u16.u32 %r53,%r48; cvt.u16.u32 %r54,%r51; or.b16 %r52,%r53,%r54; set.u32.gt.s32 %r56,%r36,2139095039; neg.s32 %r57,%r56; cvt.u16.u32 %r61,%r57; or.b16 %r59,%r52,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; .loc 1 46 0 mul.f32 %r25,%r44,%r45; div.rn.f32 %r43,%r25,%r25; bra $L1; $L2: .loc 1 49 0 setp.gt.s32 %r65,%r35,2130706431; @ %r65 bra $L4; add.f32 %r68,%r45,%r45; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r68; call (%value_in),__ieee754_fmodf,(%out_arg1,%out_arg2); ld.param.f32 %r69,[%value_in]; } mov.f32 %r44,%r69; $L4: .loc 1 50 0 setp.ne.u32 %r70,%r35,%r36; @ %r70 bra $L5; mul.f32 %r43,%r44,0f00000000; bra $L1; $L5: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r72,[%value_in]; } mov.f32 %r31,%r72; .loc 1 52 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r74,[%value_in]; } .loc 1 53 0 setp.gt.s32 %r75,%r35,16777215; @ %r75 bra $L6; .loc 1 54 0 add.f32 %r76,%r31,%r31; setp.gt.f32 %r77,%r76,%r74; @ ! %r77 bra $L7; .loc 1 55 0 sub.f32 %r31,%r31,%r74; .loc 1 56 0 add.f32 %r78,%r31,%r31; setp.ge.f32 %r79,%r78,%r74; @ ! %r79 bra $L7; sub.f32 %r31,%r31,%r74; bra $L7; $L6: .loc 1 59 0 mul.f32 %r38,%r74,0f3f000000; .loc 1 60 0 setp.gt.f32 %r80,%r31,%r38; @ ! %r80 bra $L7; .loc 1 61 0 sub.f32 %r31,%r31,%r74; .loc 1 62 0 setp.le.f32 %r81,%r38,%r31; @ ! %r81 bra $L7; sub.f32 %r31,%r31,%r74; $L7: .loc 1 38 0 and.b32 %r82,%r22,-2147483648; .loc 1 66 0 mov.b32 %r83,%r31; xor.b32 %r30,%r82,%r83; mov.b32 %r43,%r30; $L1: .loc 1 68 0 mov.f32 %value,%r43; st.param.f32 [%value_out],%value; ret; } /236 0 0 0 644 3481 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalbf .visible .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/ef_scalb.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rintf .extern .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: __ieee754_scalbf .visible .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r27; .reg .f32 %r29; .reg .f32 %r30; .reg .f32 %r31; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f32 %r42; .reg .f32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u32 %r48; .reg .f32 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .f32 %r53; .reg .u32 %r56; .reg .f32 %r57; mov.f32 %r30,%ar0; mov.f32 %r31,%ar1; .loc 1 38 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r33,[%value_in]; } setp.ne.u32 %r34,%r33,0; @ ! %r34 bra $L3; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r36,[%value_in]; } setp.eq.u32 %r37,%r36,0; @ ! %r37 bra $L18; $L3: mul.f32 %r29,%r30,%r31; bra $L1; $L18: .loc 1 39 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.ne.u32 %r40,%r39,0; @ %r40 bra $L7; .loc 1 40 0 setp.gt.f32 %r41,%r31,0f00000000; @ %r41 bra $L3; .loc 1 41 0 neg.f32 %r42,%r31; div.rn.f32 %r29,%r30,%r42; bra $L1; $L7: .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),rintf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.eq.f32 %r45,%r44,%r31; @ %r45 bra $L8; sub.f32 %r27,%r31,%r31; div.rn.f32 %r29,%r27,%r27; bra $L1; $L8: .loc 1 45 0 setp.gt.f32 %r46,%r31,0f477de800; @ ! %r46 bra $L19; mov.u32 %r48,65000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r49,[%value_in]; } mov.f32 %r29,%r49; bra $L1; $L19: .loc 1 46 0 setp.lt.f32 %r50,%r31,0fc77de800; @ ! %r50 bra $L20; mov.u32 %r52,-65000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r52; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r53,[%value_in]; } mov.f32 %r29,%r53; bra $L1; $L20: .loc 1 51 0 cvt.rzi.s32.f32 %r56,%r31; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r56; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r57,[%value_in]; } mov.f32 %r29,%r57; $L1: .loc 1 53 0 mov.f32 %value,%r29; st.param.f32 [%value_out],%value; ret; } lib_a-ef_sinh.o/0 0 0 644 3946 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinhf .visible .func (.param .f32 %value_out) __ieee754_sinhf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_sinh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1f .extern .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_sinhf .visible .func (.param .f32 %value_out) __ieee754_sinhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .f32 %r43; .reg .f32 %r44; .reg .f32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .f32 %r50; .reg .pred %r51; .reg .f32 %r53; .reg .f32 %r55; .reg .pred %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .pred %r65; .reg .f32 %r67; .reg .f32 %r69; .reg .pred %r70; .reg .f32 %r72; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; .reg .f32 %r79; .reg .f32 %r81; mov.f32 %r45,%ar0; .loc 1 34 0 mov.b32 %r36,%r45; .loc 1 35 0 and.b32 %r37,%r36,2147483647; .loc 1 38 0 setp.le.s32 %r46,%r37,2139095039; @ %r46 bra $L2; add.f32 %r44,%r45,%r45; bra $L1; $L2: .loc 1 41 0 setp.ge.s32 %r47,%r36,0; selp.f32 %r35,0f3f000000,0fbf000000,%r47; .loc 1 43 0 setp.gt.s32 %r48,%r37,1102053375; @ %r48 bra $L5; .loc 1 44 0 setp.gt.s32 %r49,%r37,830472191; @ %r49 bra $L6; .loc 1 45 0 add.f32 %r50,%r45,0f7cf0bdc2; setp.gt.f32 %r51,%r50,0f3f800000; @ %r51 bra $L13; bra $L14; $L6: .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r53,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r53; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r55,[%value_in]; } mov.f32 %r43,%r55; .loc 1 47 0 setp.gt.s32 %r56,%r37,1065353215; @ %r56 bra $L8; $L11: mul.f32 %r57,%r43,%r43; add.f32 %r58,%r43,0f3f800000; div.rn.f32 %r59,%r57,%r58; neg.f32 %r60,%r59; fma.rn.f32 %r61,%r43,0f40000000,%r60; mul.f32 %r44,%r61,%r35; bra $L1; $L8: .loc 1 48 0 add.f32 %r62,%r55,0f3f800000; div.rn.f32 %r63,%r55,%r62; add.f32 %r64,%r63,%r55; mul.f32 %r44,%r64,%r35; bra $L1; $L5: .loc 1 52 0 setp.gt.s32 %r65,%r37,1118925335; @ %r65 bra $L9; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r67,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r69,[%value_in]; } mul.f32 %r44,%r69,%r35; bra $L1; $L9: .loc 1 55 0 setp.gt.s32 %r70,%r37,1119016188; @ %r70 bra $L10; .loc 1 56 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r72,[%value_in]; } mul.f32 %r74,%r72,0f3f000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r74; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r75,[%value_in]; } .loc 1 57 0 mul.f32 %r76,%r35,%r75; .loc 1 58 0 mul.f32 %r44,%r76,%r75; bra $L1; $L10: .loc 1 62 0 mul.f32 %r44,%r45,0f7cf0bdc2; bra $L1; $L13: .loc 1 45 0 mov.f32 %r44,%r45; bra $L1; $L14: .loc 1 46 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r45; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r79,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r79; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r81,[%value_in]; } mov.f32 %r43,%r81; bra $L11; $L1: .loc 1 63 0 mov.f32 %value,%r44; st.param.f32 [%value_out],%value; ret; } lib_a-ef_sqrt.o/0 0 0 644 2976 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .visible .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/ef_sqrt.c" // BEGIN GLOBAL FUNCTION DEF: __ieee754_sqrtf .visible .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .f32 %r28; .reg .u32 %r29; .reg .u32 %r32; .reg .u32 %r36; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .pred %r60; .reg .pred %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u32 %r68; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r73; .reg .pred %r75; .reg .pred %r76; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; mov.f32 %r59,%ar0; .loc 1 35 0 mov.b32 %r27,%r59; .loc 1 36 0 and.b32 %r44,%r27,2147483647; .loc 1 39 0 setp.le.u32 %r60,%r44,2139095039; @ %r60 bra $L2; .loc 1 40 0 fma.rn.f32 %r58,%r59,%r59,%r59; bra $L1; $L2: .loc 1 43 0 setp.eq.u32 %r61,%r44,0; @ %r61 bra $L12; .loc 1 35 0 mov.u32 %r45,%r27; .loc 1 44 0 setp.ge.s32 %r62,%r27,0; @ %r62 bra $L4; sub.f32 %r28,%r59,%r59; div.rn.f32 %r58,%r28,%r28; bra $L1; $L4: .loc 1 47 0 shr.s32 %r43,%r45,23; .loc 1 48 0 setp.gt.u32 %r63,%r44,8388607; @ %r63 bra $L5; and.b32 %r56,%r45,8388608; .loc 1 49 0 setp.ne.u32 %r64,%r56,0; @ ! %r64 bra $L7; bra $L13; $L14: mov.u32 %r56,%r46; $L7: add.u32 %r45,%r45,%r45; add.u32 %r46,%r56,1; and.b32 %r66,%r45,8388608; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L14; bra $L6; $L13: mov.u32 %r56,-1; $L6: .loc 1 50 0 sub.u32 %r43,%r43,%r56; $L5: .loc 1 52 0 add.u32 %r47,%r43,-127; .loc 1 53 0 and.b32 %r29,%r45,8388607; or.b32 %r68,%r29,8388608; add.u32 %r54,%r68,%r68; .loc 1 54 0 and.b32 %r70,%r47,1; setp.eq.u32 %r71,%r70,0; @ %r71 bra $L8; add.u32 %r54,%r54,%r54; $L8: .loc 1 56 0 shr.s32 %r49,%r47,1; mov.u32 %r57,25; .loc 1 60 0 mov.u32 %r42,0; mov.u32 %r41,%r42; .loc 1 61 0 mov.u32 %r55,16777216; $L10: .loc 1 64 0 add.u32 %r32,%r41,%r55; .loc 1 65 0 setp.gt.s32 %r73,%r32,%r54; @ %r73 bra $L9; .loc 1 66 0 add.u32 %r41,%r32,%r55; .loc 1 67 0 sub.u32 %r54,%r54,%r32; .loc 1 68 0 add.u32 %r42,%r42,%r55; $L9: .loc 1 70 0 add.u32 %r54,%r54,%r54; .loc 1 71 0 shr.u32 %r55,%r55,1; add.u32 %r57,%r57,-1; .loc 1 63 0 setp.ne.u32 %r75,%r57,0; @ %r75 bra $L10; .loc 1 75 0 setp.eq.u32 %r76,%r54,0; @ %r76 bra $L11; .loc 1 82 0 add.u32 %r36,%r42,1; and.b32 %r42,%r36,-2; $L11: .loc 1 85 0 shr.s32 %r77,%r42,1; add.u32 %r51,%r77,1056964608; .loc 1 86 0 shl.b32 %r78,%r49,23; add.u32 %r79,%r78,%r51; .loc 1 87 0 mov.b32 %r58,%r79; .loc 1 88 0 bra $L1; $L12: .loc 1 43 0 mov.f32 %r58,%r59; $L1: .loc 1 89 0 mov.f32 %value,%r58; st.param.f32 [%value_out],%value; ret; } /254 0 0 0 644 1386 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .visible .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/er_gamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .extern .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_gamma_r .visible .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .u64 %r25; .reg .f64 %r28; .reg .f64 %r30; mov.f64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 31 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),__ieee754_lgamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r30,[%value_in]; } .loc 1 32 0 mov.f64 %value,%r30; st.param.f64 [%value_out],%value; ret; } /272 0 0 0 644 18254 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .visible .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/er_lgamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .extern .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .extern .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_lgamma_r .visible .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r77; .reg .f64 %r91; .reg .f64 %r92; .reg .f64 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .f64 %r98; .reg .f64 %r99; .reg .u32 %r101; .reg .f64 %r102; .reg .f64 %r109; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r120; .reg .f64 %r124; .reg .f64 %r126; .reg .f64 %r128; .reg .f64 %r131; .reg .u32 %r133; .reg .u32 %r134; .reg .f64 %r135; .reg .u32 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r140; .reg .f64 %r142; .reg .f64 %r147; .reg .f64 %r148; .reg .f64 %r170; .reg .f64 %r171; .reg .u64 %r172; .reg .u64 %r173; .reg .u64 %r174; .reg .u32 %r175; .reg .pred %r176; .reg .u32 %r178; .reg .pred %r179; .reg .f64 %r180; .reg .pred %r181; .reg .pred %r182; .reg .u32 %r183; .reg .f64 %r185; .reg .f64 %r186; .reg .f64 %r188; .reg .pred %r190; .reg .pred %r191; .reg .f64 %r193; .reg .u32 %r194; .reg .f64 %r195; .reg .f64 %r196; .reg .f64 %r198; .reg .pred %r199; .reg .f64 %r201; .reg .f64 %r202; .reg .f64 %r203; .reg .f64 %r204; .reg .u64 %r205; .reg .pred %r206; .reg .pred %r207; .reg .pred %r208; .reg .pred %r209; .reg .pred %r210; .reg .f64 %r212; .reg .f64 %r214; .reg .f64 %r215; .reg .f64 %r216; .reg .f64 %r218; .reg .f64 %r219; .reg .f64 %r220; .reg .f64 %r221; .reg .f64 %r223; .reg .u32 %r224; .reg .f64 %r225; .reg .f64 %r227; .reg .f64 %r228; .reg .f64 %r229; .reg .f64 %r230; .reg .f64 %r231; .reg .f64 %r232; .reg .f64 %r233; .reg .f64 %r235; .reg .u32 %r236; .reg .f64 %r237; .reg .pred %r238; .reg .f64 %r240; .reg .f64 %r241; .reg .f64 %r243; .reg .f64 %r244; .reg .f64 %r245; .reg .pred %r246; .reg .u32 %r247; .reg .u32 %r248; .reg .u32 %r249; .reg .pred %r250; .reg .pred %r251; .reg .pred %r252; .reg .f64 %r254; .reg .pred %r255; .reg .f64 %r256; .reg .pred %r257; .reg .f64 %r258; .reg .pred %r259; .reg .f64 %r260; .reg .pred %r261; .reg .f64 %r262; .reg .f64 %r263; .reg .f64 %r265; .reg .f64 %r266; .reg .f64 %r267; .reg .f64 %r268; .reg .f64 %r269; .reg .f64 %r270; .reg .f64 %r271; .reg .f64 %r272; .reg .f64 %r273; .reg .f64 %r274; .reg .f64 %r275; .reg .f64 %r276; .reg .f64 %r277; .reg .f64 %r278; .reg .f64 %r279; .reg .f64 %r280; .reg .f64 %r281; .reg .f64 %r282; .reg .f64 %r283; .reg .f64 %r284; .reg .f64 %r285; .reg .f64 %r286; .reg .f64 %r287; .reg .f64 %r288; .reg .f64 %r289; .reg .f64 %r290; .reg .f64 %r291; .reg .f64 %r292; .reg .f64 %r293; .reg .f64 %r294; .reg .f64 %r295; .reg .f64 %r296; .reg .f64 %r297; .reg .f64 %r298; .reg .f64 %r299; .reg .f64 %r300; .reg .f64 %r301; .reg .f64 %r302; .reg .f64 %r303; .reg .f64 %r304; .reg .f64 %r305; .reg .f64 %r306; .reg .f64 %r307; .reg .f64 %r308; .reg .f64 %r309; .reg .pred %r310; .reg .f64 %r311; .reg .f64 %r312; .reg .f64 %r313; .reg .f64 %r314; .reg .f64 %r315; .reg .f64 %r316; .reg .f64 %r317; .reg .f64 %r318; .reg .f64 %r319; .reg .f64 %r320; .reg .f64 %r321; .reg .f64 %r322; .reg .f64 %r323; .reg .f64 %r324; .reg .f64 %r325; .reg .pred %r326; .reg .pred %r327; .reg .pred %r328; .reg .pred %r329; .reg .pred %r330; .reg .pred %r331; .reg .f64 %r332; .reg .f64 %r333; .reg .f64 %r334; .reg .f64 %r336; .reg .f64 %r337; .reg .f64 %r338; .reg .pred %r339; .reg .f64 %r341; .reg .f64 %r342; .reg .f64 %r343; .reg .f64 %r344; .reg .f64 %r345; .reg .f64 %r346; .reg .f64 %r347; .reg .f64 %r348; .reg .f64 %r349; .reg .f64 %r350; .reg .f64 %r351; .reg .f64 %r354; .reg .f64 %r355; .reg .f64 %r356; .reg .u32 %r359; .reg .u32 %r360; .reg .pred %r361; .reg .u32 %r362; .reg .u32 %r363; .reg .pred %r364; .reg .u32 %r365; .reg .u32 %r366; .reg .pred %r367; .reg .pred %r368; mov.f64 %r171,%ar0; mov.u64 %r172,%ar1; .loc 1 222 0 mov.b64 %r173,%r171; shr.u64 %r174,%r173,32; cvt.u32.u64 %r94,%r174; .loc 1 225 0 mov.u32 %r175,1; st.u32 [%r172],%r175; .loc 1 226 0 and.b32 %r96,%r94,2147483647; .loc 1 227 0 setp.le.s32 %r176,%r96,2146435071; @ %r176 bra $L2; mul.f64 %r170,%r171,%r171; bra $L1; $L2: .loc 1 222 0 cvt.u32.u64 %r95,%r173; .loc 1 228 0 or.b32 %r178,%r95,%r96; setp.ne.u32 %r179,%r178,0; @ %r179 bra $L4; $L8: mov.f64 %r180,0d3ff0000000000000; div.rn.f64 %r170,%r180,0d0000000000000000; bra $L1; $L4: .loc 1 229 0 setp.gt.s32 %r181,%r96,999292927; @ %r181 bra $L5; .loc 1 230 0 setp.ge.s32 %r182,%r94,0; @ %r182 bra $L6; .loc 1 231 0 mov.u32 %r183,-1; st.u32 [%r172],%r183; .loc 1 232 0 neg.f64 %r185,%r171; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r185; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r186,[%value_in]; } neg.f64 %r170,%r186; bra $L1; $L6: .loc 1 233 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r188,[%value_in]; } neg.f64 %r170,%r188; bra $L1; $L5: .loc 1 235 0 setp.ge.s32 %r368,%r94,0; @ %r368 bra $L7; .loc 1 236 0 setp.gt.s32 %r190,%r96,1127219199; @ %r190 bra $L8; .loc 1 175 0 setp.gt.s32 %r191,%r96,1070596095; @ %r191 bra $L9; mul.f64 %r195,%r171,0d400921fb54442d18; mov.u32 %r194,0; mov.f64 %r193,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r195; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r193; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r194; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r196,[%value_in]; } mov.f64 %r148,%r196; bra $L10; $L9: .loc 1 176 0 neg.f64 %r124,%r171; .loc 1 182 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r124; call (%value_in),floor,(%out_arg1); ld.param.f64 %r198,[%value_in]; } .loc 1 183 0 setp.eq.f64 %r199,%r124,%r198; @ %r199 bra $L11; .loc 1 184 0 mul.f64 %r126,%r124,0d3fe0000000000000; .loc 1 185 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r126; call (%value_in),floor,(%out_arg1); ld.param.f64 %r201,[%value_in]; } sub.f64 %r128,%r126,%r201; add.f64 %r135,%r128,%r128; .loc 1 186 0 mul.f64 %r202,%r135,0d4010000000000000; cvt.rzi.s32.f64 %r136,%r202; bra $L12; $L11: .loc 1 192 0 mov.f64 %r204,0d4330000000000000; sub.f64 %r203,%r204,%r171; mov.b64 %r205,%r203; cvt.u32.u64 %r133,%r205; .loc 1 193 0 and.b32 %r134,%r133,1; .loc 1 194 0 cvt.rn.f64.s32 %r135,%r134; .loc 1 195 0 shl.b32 %r136,%r134,2; $L12: .loc 1 198 0 setp.gt.s32 %r206,%r136,4; @ %r206 bra $L14; setp.ge.s32 %r207,%r136,3; @ %r207 bra $L15; setp.eq.u32 %r208,%r136,0; @ %r208 bra $L16; setp.lt.s32 %r209,%r136,0; @ ! %r209 bra $L52; bra $L13; $L14: setp.gt.s32 %r210,%r136,6; @ ! %r210 bra $L53; bra $L13; $L16: .loc 1 199 0 mul.f64 %r137,%r135,0d400921fb54442d18; mov.f64 %r212,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r137; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r212; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r136; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r214,[%value_in]; } mov.f64 %r138,%r214; bra $L19; $L52: .loc 1 201 0 mov.f64 %r216,0d3fe0000000000000; sub.f64 %r215,%r216,%r135; mul.f64 %r140,%r215,0d400921fb54442d18; mov.f64 %r218,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r140; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r218; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r219,[%value_in]; } mov.f64 %r138,%r219; bra $L19; $L15: .loc 1 203 0 mov.f64 %r221,0d3ff0000000000000; sub.f64 %r220,%r221,%r135; mul.f64 %r142,%r220,0d400921fb54442d18; mov.u32 %r224,0; mov.f64 %r223,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r142; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r223; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r224; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r225,[%value_in]; } mov.f64 %r138,%r225; bra $L19; $L53: .loc 1 205 0 mov.f64 %r229,0d3ff8000000000000; sub.f64 %r228,%r135,%r229; mul.f64 %r230,%r228,0d400921fb54442d18; mov.f64 %r227,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r230; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r227; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r231,[%value_in]; } neg.f64 %r138,%r231; bra $L19; $L13: .loc 1 206 0 mov.f64 %r233,0d4000000000000000; sub.f64 %r232,%r135,%r233; mul.f64 %r147,%r232,0d400921fb54442d18; mov.u32 %r236,0; mov.f64 %r235,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r147; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r235; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r236; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r237,[%value_in]; } mov.f64 %r138,%r237; $L19: .loc 1 208 0 neg.f64 %r148,%r138; $L10: .loc 1 239 0 setp.eq.f64 %r238,%r148,0d0000000000000000; @ %r238 bra $L8; .loc 1 240 0 mul.f64 %r240,%r171,%r148; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r240; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r241,[%value_in]; } mov.f64 %r244,0d400921fb54442d18; div.rn.f64 %r243,%r244,%r241; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r243; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r245,[%value_in]; } mov.f64 %r131,%r245; .loc 1 241 0 setp.lt.f64 %r246,%r148,0d0000000000000000; @ ! %r246 bra $L20; mov.u32 %r247,-1; st.u32 [%r172],%r247; $L20: .loc 1 242 0 neg.f64 %r171,%r171; .loc 1 246 0 add.u32 %r248,%r96,-1072693248; or.b32 %r249,%r248,%r95; setp.eq.u32 %r250,%r249,0; @ ! %r250 bra $L54; bra $L43; $L42: .loc 1 248 0 setp.gt.s32 %r251,%r96,1073741823; @ %r251 bra $L24; .loc 1 249 0 setp.gt.s32 %r252,%r96,1072483532; @ %r252 bra $L25; .loc 1 250 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r254,[%value_in]; } neg.f64 %r111,%r254; .loc 1 251 0 setp.le.s32 %r255,%r96,1072130371; @ %r255 bra $L26; mov.f64 %r256,0d3ff0000000000000; sub.f64 %r110,%r256,%r171; bra $L27; $L26: .loc 1 252 0 setp.le.s32 %r257,%r96,1070442080; @ %r257 bra $L28; mov.f64 %r258,0d3fdd8b618d5af8fc; sub.f64 %r109,%r171,%r258; bra $L29; $L25: .loc 1 256 0 setp.le.s32 %r259,%r96,1073460418; @ %r259 bra $L30; mov.f64 %r260,0d4000000000000000; sub.f64 %r110,%r260,%r171; .loc 1 255 0 mov.f64 %r111,0d0000000000000000; bra $L27; $L30: .loc 1 257 0 setp.le.s32 %r261,%r96,1072936131; @ %r261 bra $L31; mov.f64 %r262,0d3ff762d86356be3f; sub.f64 %r109,%r171,%r262; .loc 1 255 0 mov.f64 %r111,0d0000000000000000; bra $L29; $L31: .loc 1 258 0 mov.f64 %r263,0d3ff0000000000000; sub.f64 %r171,%r171,%r263; .loc 1 255 0 mov.f64 %r111,0d0000000000000000; bra $L28; $L27: .loc 1 262 0 mul.f64 %r120,%r110,%r110; .loc 1 264 0 fma.rn.f64 %r265,%r120,0d3f07858e90a45837,0d3f1c5088987dfb07; fma.rn.f64 %r266,%r265,%r120,0d3f40b6c689b99c00; fma.rn.f64 %r267,%r266,%r120,0d3f67add8ccb7926b; fma.rn.f64 %r268,%r267,%r120,0d3f951322ac92547b; fma.rn.f64 %r269,%r268,%r120,0d3fd4a34cc4a60fad; .loc 1 263 0 fma.rn.f64 %r270,%r120,0d3efa7074428cfa52,0d3f2cf2eced10e54d; fma.rn.f64 %r271,%r270,%r120,0d3f538a94116f3f5d; fma.rn.f64 %r272,%r271,%r120,0d3f7e404fb68fefe8; fma.rn.f64 %r273,%r272,%r120,0d3fb13e001a5562a7; fma.rn.f64 %r274,%r273,%r120,0d3fb3c467e37db0c8; .loc 1 265 0 mul.f64 %r275,%r274,%r110; fma.rn.f64 %r276,%r269,%r120,%r275; .loc 1 266 0 fma.rn.f64 %r277,%r110,0dbfe0000000000000,%r276; add.f64 %r170,%r277,%r111; bra $L32; $L29: .loc 1 268 0 mul.f64 %r114,%r109,%r109; .loc 1 269 0 mul.f64 %r115,%r114,%r109; .loc 1 272 0 fma.rn.f64 %r278,%r115,0d3f35fd3ee8c2d3f4,0dbf41a6109c73e0ec; fma.rn.f64 %r279,%r278,%r115,0d3f6282d32e15c915; fma.rn.f64 %r280,%r279,%r115,0dbf851f9fba91ec6a; fma.rn.f64 %r281,%r280,%r115,0d3fb08b4294d5419b; .loc 1 271 0 fma.rn.f64 %r282,%r115,0dbf347f24ecc38c38,0d3f4cdf0cef61a8e9; fma.rn.f64 %r283,%r282,%r115,0dbf6e2effb3e914d7; fma.rn.f64 %r284,%r283,%r115,0d3f9266e7970af9ec; fma.rn.f64 %r285,%r284,%r115,0dbfc2e4278dc6c509; .loc 1 273 0 fma.rn.f64 %r286,%r281,%r109,%r285; neg.f64 %r287,%r286; fma.rn.f64 %r288,%r287,%r115,0dbc50c7caa48a971f; neg.f64 %r289,%r288; .loc 1 270 0 fma.rn.f64 %r290,%r115,0d3f34af6d6c0ebbf7,0dbf56fe8ebf2d1af1; fma.rn.f64 %r291,%r290,%r115,0d3f78fce0e370e344; fma.rn.f64 %r292,%r291,%r115,0dbfa0c9a8df35b713; fma.rn.f64 %r293,%r292,%r115,0d3fdef72bc8ee38a2; .loc 1 273 0 fma.rn.f64 %r294,%r114,%r293,%r289; .loc 1 274 0 mov.f64 %r296,0d3fbf19b9bcc38a42; sub.f64 %r295,%r294,%r296; add.f64 %r170,%r295,%r111; bra $L32; $L28: .loc 1 276 0 fma.rn.f64 %r297,%r171,0d3f8b678bbf2bab09,0d3fcd4eaef6010924; fma.rn.f64 %r298,%r297,%r171,0d3fef497644ea8450; fma.rn.f64 %r299,%r298,%r171,0d3ff7475cd119bd6f; fma.rn.f64 %r300,%r299,%r171,0d3fe4401e8b005dff; fma.rn.f64 %r301,%r300,%r171,0dbfb3c467e37db0c8; mul.f64 %r302,%r301,%r171; .loc 1 277 0 fma.rn.f64 %r303,%r171,0d3f6a5abb57d0cf61,0d3fbaae55d6537c88; fma.rn.f64 %r304,%r303,%r171,0d3fe89dfbe45050af; fma.rn.f64 %r305,%r304,%r171,0d40010725a42b18f5; fma.rn.f64 %r306,%r305,%r171,0d4003a5d7c2bd619c; fma.rn.f64 %r307,%r306,%r171,0d3ff0000000000000; .loc 1 278 0 div.rn.f64 %r308,%r302,%r307; fma.rn.f64 %r309,%r171,0dbfe0000000000000,%r308; add.f64 %r170,%r309,%r111; bra $L32; $L24: .loc 1 281 0 setp.gt.s32 %r310,%r96,1075838975; @ %r310 bra $L33; .loc 1 282 0 cvt.rzi.s32.f64 %r101,%r171; .loc 1 284 0 cvt.rn.f64.s32 %r311,%r101; sub.f64 %r102,%r171,%r311; .loc 1 285 0 fma.rn.f64 %r312,%r102,0d3f00bfecdd17e945,0d3f5e26b67368f239; fma.rn.f64 %r313,%r312,%r102,0d3f9b481c7e939961; fma.rn.f64 %r314,%r313,%r102,0d3fc2bb9cbee5f2f7; fma.rn.f64 %r315,%r314,%r102,0d3fd4d98f4f139f59; fma.rn.f64 %r316,%r315,%r102,0d3fcb848b36e20878; fma.rn.f64 %r317,%r316,%r102,0dbfb3c467e37db0c8; mul.f64 %r318,%r317,%r102; .loc 1 286 0 fma.rn.f64 %r319,%r102,0d3edebaf7a5b38140,0d3f497ddaca41a95b; fma.rn.f64 %r320,%r319,%r102,0d3f9317ea742ed475; fma.rn.f64 %r321,%r320,%r102,0d3fc601edccfbdf27; fma.rn.f64 %r322,%r321,%r102,0d3fe71a1893d3dcdc; fma.rn.f64 %r323,%r322,%r102,0d3ff645a762c4ab74; fma.rn.f64 %r324,%r323,%r102,0d3ff0000000000000; .loc 1 287 0 div.rn.f64 %r325,%r318,%r324; fma.rn.f64 %r170,%r102,0d3fe0000000000000,%r325; .loc 1 289 0 setp.eq.u32 %r326,%r101,5; @ %r326 bra $L46; setp.gt.s32 %r327,%r101,5; @ %r327 bra $L35; setp.eq.u32 %r328,%r101,3; @ %r328 bra $L44; setp.eq.u32 %r329,%r101,4; @ %r329 bra $L45; bra $L32; $L35: setp.eq.u32 %r330,%r101,6; @ %r330 bra $L47; setp.eq.u32 %r331,%r101,7; @ ! %r331 bra $L32; .loc 1 290 0 add.f64 %r77,%r102,0d4018000000000000; bra $L38; $L47: .loc 1 288 0 mov.f64 %r77,0d3ff0000000000000; $L38: .loc 1 291 0 add.f64 %r332,%r102,0d4014000000000000; mul.f64 %r91,%r332,%r77; bra $L34; $L46: .loc 1 288 0 mov.f64 %r91,0d3ff0000000000000; $L34: .loc 1 292 0 add.f64 %r333,%r102,0d4010000000000000; mul.f64 %r92,%r333,%r91; bra $L37; $L45: .loc 1 288 0 mov.f64 %r92,0d3ff0000000000000; $L37: .loc 1 293 0 add.f64 %r334,%r102,0d4008000000000000; mul.f64 %r93,%r334,%r92; bra $L36; $L44: .loc 1 288 0 mov.f64 %r93,0d3ff0000000000000; $L36: .loc 1 294 0 add.f64 %r336,%r102,0d4000000000000000; mul.f64 %r337,%r336,%r93; .loc 1 295 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r337; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r338,[%value_in]; } add.f64 %r170,%r170,%r338; bra $L32; $L33: .loc 1 298 0 setp.gt.s32 %r339,%r96,1133510655; @ %r339 bra $L40; .loc 1 299 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r341,[%value_in]; } .loc 1 300 0 mov.f64 %r342,0d3ff0000000000000; div.rn.f64 %r98,%r342,%r171; .loc 1 301 0 mul.f64 %r99,%r98,%r98; .loc 1 303 0 mov.f64 %r344,0d3fe0000000000000; sub.f64 %r343,%r171,%r344; .loc 1 302 0 fma.rn.f64 %r345,%r99,0dbf5ab89d0b9e43e4,0d3f4b67ba4cdad5d1; fma.rn.f64 %r346,%r345,%r99,0dbf4380cb8c0fe741; fma.rn.f64 %r347,%r346,%r99,0d3f4a019f98cf38b6; fma.rn.f64 %r348,%r347,%r99,0dbf66c16c16b02e5c; fma.rn.f64 %r349,%r348,%r99,0d3fb555555555553b; fma.rn.f64 %r350,%r349,%r98,0d3fdacfe390c97d69; .loc 1 303 0 sub.f64 %r351,%r341,%r342; fma.rn.f64 %r170,%r343,%r351,%r350; bra $L32; $L40: .loc 1 306 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r171; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r354,[%value_in]; } mov.f64 %r356,0d3ff0000000000000; sub.f64 %r355,%r354,%r356; mul.f64 %r170,%r355,%r171; $L32: .loc 1 307 0 @ ! %r368 bra $L22; bra $L1; $L43: .loc 1 246 0 mov.f64 %r170,0d0000000000000000; bra $L22; $L49: mov.f64 %r170,0d0000000000000000; $L22: .loc 1 307 0 sub.f64 %r170,%r131,%r170; bra $L1; $L48: .loc 1 246 0 mov.f64 %r170,0d0000000000000000; bra $L1; $L50: mov.f64 %r170,0d0000000000000000; bra $L1; $L7: add.u32 %r359,%r96,-1072693248; or.b32 %r360,%r359,%r95; setp.eq.u32 %r361,%r360,0; @ %r361 bra $L48; bra $L55; $L54: add.u32 %r362,%r96,-1073741824; or.b32 %r363,%r362,%r95; setp.eq.u32 %r364,%r363,0; @ %r364 bra $L49; bra $L42; $L55: add.u32 %r365,%r96,-1073741824; or.b32 %r366,%r365,%r95; setp.eq.u32 %r367,%r366,0; @ %r367 bra $L50; .loc 1 219 0 mov.f64 %r131,0d0000000000000000; bra $L42; $L1: .loc 1 309 0 mov.f64 %value,%r170; st.param.f64 [%value_out],%value; ret; } /291 0 0 0 644 1397 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .visible .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/erf_gamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .extern .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_gammaf_r .visible .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r24; .reg .u64 %r25; .reg .f32 %r28; .reg .f32 %r30; mov.f32 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 33 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),__ieee754_lgammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r28,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r28; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r30,[%value_in]; } .loc 1 34 0 mov.f32 %value,%r30; st.param.f32 [%value_out],%value; ret; } /310 0 0 0 644 16728 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .visible .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/erf_lgamma.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .extern .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .extern .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __ieee754_lgammaf_r .visible .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r76; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .f32 %r98; .reg .f32 %r99; .reg .u32 %r101; .reg .f32 %r102; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r112; .reg .f32 %r113; .reg .f32 %r118; .reg .f32 %r122; .reg .f32 %r124; .reg .f32 %r126; .reg .u32 %r130; .reg .u32 %r131; .reg .f32 %r132; .reg .u32 %r133; .reg .f32 %r135; .reg .f32 %r136; .reg .f32 %r138; .reg .f32 %r140; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r149; .reg .f32 %r165; .reg .f32 %r166; .reg .u64 %r167; .reg .u32 %r168; .reg .pred %r169; .reg .pred %r170; .reg .f32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .u32 %r174; .reg .f32 %r176; .reg .f32 %r177; .reg .f32 %r179; .reg .pred %r181; .reg .pred %r182; .reg .f32 %r184; .reg .u32 %r185; .reg .f32 %r186; .reg .f32 %r187; .reg .f32 %r189; .reg .pred %r190; .reg .f32 %r192; .reg .f32 %r193; .reg .f32 %r194; .reg .f32 %r195; .reg .pred %r196; .reg .pred %r197; .reg .pred %r198; .reg .pred %r199; .reg .pred %r200; .reg .f32 %r202; .reg .f32 %r204; .reg .f32 %r205; .reg .f32 %r206; .reg .f32 %r208; .reg .f32 %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r213; .reg .u32 %r214; .reg .f32 %r215; .reg .f32 %r217; .reg .f32 %r218; .reg .f32 %r219; .reg .f32 %r220; .reg .f32 %r221; .reg .f32 %r222; .reg .f32 %r223; .reg .f32 %r225; .reg .u32 %r226; .reg .f32 %r227; .reg .pred %r228; .reg .f32 %r230; .reg .f32 %r231; .reg .f32 %r233; .reg .f32 %r234; .reg .f32 %r235; .reg .pred %r236; .reg .u32 %r237; .reg .u32 %r238; .reg .u32 %r239; .reg .pred %r240; .reg .pred %r241; .reg .pred %r242; .reg .f32 %r244; .reg .pred %r245; .reg .f32 %r246; .reg .pred %r247; .reg .f32 %r248; .reg .pred %r249; .reg .f32 %r250; .reg .pred %r251; .reg .f32 %r252; .reg .f32 %r253; .reg .f32 %r255; .reg .f32 %r256; .reg .f32 %r257; .reg .f32 %r258; .reg .f32 %r259; .reg .f32 %r260; .reg .f32 %r261; .reg .f32 %r262; .reg .f32 %r263; .reg .f32 %r264; .reg .f32 %r265; .reg .f32 %r266; .reg .f32 %r267; .reg .f32 %r268; .reg .f32 %r269; .reg .f32 %r270; .reg .f32 %r271; .reg .f32 %r272; .reg .f32 %r273; .reg .f32 %r274; .reg .f32 %r275; .reg .f32 %r276; .reg .f32 %r277; .reg .f32 %r278; .reg .f32 %r279; .reg .f32 %r280; .reg .f32 %r281; .reg .f32 %r282; .reg .f32 %r283; .reg .f32 %r284; .reg .f32 %r285; .reg .f32 %r286; .reg .f32 %r287; .reg .f32 %r288; .reg .f32 %r289; .reg .f32 %r290; .reg .f32 %r291; .reg .f32 %r292; .reg .f32 %r293; .reg .f32 %r294; .reg .f32 %r295; .reg .f32 %r296; .reg .f32 %r297; .reg .f32 %r298; .reg .f32 %r299; .reg .pred %r300; .reg .f32 %r301; .reg .f32 %r302; .reg .f32 %r303; .reg .f32 %r304; .reg .f32 %r305; .reg .f32 %r306; .reg .f32 %r307; .reg .f32 %r308; .reg .f32 %r309; .reg .f32 %r310; .reg .f32 %r311; .reg .f32 %r312; .reg .f32 %r313; .reg .f32 %r314; .reg .f32 %r315; .reg .pred %r316; .reg .pred %r317; .reg .pred %r318; .reg .pred %r319; .reg .pred %r320; .reg .pred %r321; .reg .f32 %r322; .reg .f32 %r323; .reg .f32 %r324; .reg .f32 %r326; .reg .f32 %r327; .reg .f32 %r328; .reg .pred %r329; .reg .f32 %r331; .reg .f32 %r332; .reg .f32 %r333; .reg .f32 %r334; .reg .f32 %r335; .reg .f32 %r336; .reg .f32 %r337; .reg .f32 %r338; .reg .f32 %r339; .reg .f32 %r340; .reg .f32 %r341; .reg .f32 %r344; .reg .f32 %r345; .reg .f32 %r346; .reg .u32 %r349; .reg .u32 %r350; .reg .pred %r351; .reg .pred %r352; mov.f32 %r166,%ar0; mov.u64 %r167,%ar1; .loc 1 157 0 mov.b32 %r94,%r166; .loc 1 160 0 mov.u32 %r168,1; st.u32 [%r167],%r168; .loc 1 161 0 and.b32 %r95,%r94,2147483647; .loc 1 162 0 setp.le.s32 %r169,%r95,2139095039; @ %r169 bra $L2; mul.f32 %r165,%r166,%r166; bra $L1; $L2: .loc 1 163 0 setp.ne.u32 %r170,%r95,0; @ %r170 bra $L4; $L8: mov.f32 %r171,0f3f800000; div.rn.f32 %r165,%r171,0f00000000; bra $L1; $L4: .loc 1 164 0 setp.gt.s32 %r172,%r95,478150655; @ %r172 bra $L5; .loc 1 165 0 setp.ge.s32 %r173,%r94,0; @ %r173 bra $L6; .loc 1 166 0 mov.u32 %r174,-1; st.u32 [%r167],%r174; .loc 1 167 0 neg.f32 %r176,%r166; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r176; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r177,[%value_in]; } neg.f32 %r165,%r177; bra $L1; $L6: .loc 1 168 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r179,[%value_in]; } neg.f32 %r165,%r179; bra $L1; $L5: .loc 1 170 0 setp.ge.s32 %r352,%r94,0; @ %r352 bra $L7; .loc 1 171 0 setp.gt.s32 %r181,%r95,1258291199; @ %r181 bra $L8; .loc 1 110 0 setp.gt.s32 %r182,%r95,1048575999; @ %r182 bra $L9; mul.f32 %r186,%r166,0f40490fdb; mov.u32 %r185,0; mov.f32 %r184,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r186; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r184; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r185; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r187,[%value_in]; } mov.f32 %r146,%r187; bra $L10; $L9: .loc 1 111 0 neg.f32 %r122,%r166; .loc 1 117 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r122; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r189,[%value_in]; } .loc 1 118 0 setp.eq.f32 %r190,%r122,%r189; @ %r190 bra $L11; .loc 1 119 0 mul.f32 %r124,%r122,0f3f000000; .loc 1 120 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r124; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r192,[%value_in]; } sub.f32 %r126,%r124,%r192; add.f32 %r132,%r126,%r126; .loc 1 121 0 mul.f32 %r193,%r132,0f40800000; cvt.rzi.s32.f32 %r133,%r193; bra $L12; $L11: .loc 1 127 0 mov.f32 %r195,0f4b000000; sub.f32 %r194,%r195,%r166; mov.b32 %r130,%r194; .loc 1 128 0 and.b32 %r131,%r130,1; .loc 1 129 0 cvt.rn.f32.s32 %r132,%r131; .loc 1 130 0 shl.b32 %r133,%r131,2; $L12: .loc 1 133 0 setp.gt.s32 %r196,%r133,4; @ %r196 bra $L14; setp.ge.s32 %r197,%r133,3; @ %r197 bra $L15; setp.eq.u32 %r198,%r133,0; @ %r198 bra $L16; setp.lt.s32 %r199,%r133,0; @ ! %r199 bra $L48; bra $L13; $L14: setp.gt.s32 %r200,%r133,6; @ ! %r200 bra $L49; bra $L13; $L16: .loc 1 134 0 mul.f32 %r135,%r132,0f40490fdb; mov.f32 %r202,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r135; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r202; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r133; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r204,[%value_in]; } mov.f32 %r136,%r204; bra $L19; $L48: .loc 1 136 0 mov.f32 %r206,0f3f000000; sub.f32 %r205,%r206,%r132; mul.f32 %r138,%r205,0f40490fdb; mov.f32 %r208,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r138; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r208; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r209,[%value_in]; } mov.f32 %r136,%r209; bra $L19; $L15: .loc 1 138 0 mov.f32 %r211,0f3f800000; sub.f32 %r210,%r211,%r132; mul.f32 %r140,%r210,0f40490fdb; mov.u32 %r214,0; mov.f32 %r213,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r140; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r213; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r214; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r215,[%value_in]; } mov.f32 %r136,%r215; bra $L19; $L49: .loc 1 140 0 mov.f32 %r219,0f3fc00000; sub.f32 %r218,%r132,%r219; mul.f32 %r220,%r218,0f40490fdb; mov.f32 %r217,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r220; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r217; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r221,[%value_in]; } neg.f32 %r136,%r221; bra $L19; $L13: .loc 1 141 0 mov.f32 %r223,0f40000000; sub.f32 %r222,%r132,%r223; mul.f32 %r145,%r222,0f40490fdb; mov.u32 %r226,0; mov.f32 %r225,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r145; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r225; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r226; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r227,[%value_in]; } mov.f32 %r136,%r227; $L19: .loc 1 143 0 neg.f32 %r146,%r136; $L10: .loc 1 174 0 setp.eq.f32 %r228,%r146,0f00000000; @ %r228 bra $L8; .loc 1 175 0 mul.f32 %r230,%r166,%r146; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r230; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r231,[%value_in]; } mov.f32 %r234,0f40490fdb; div.rn.f32 %r233,%r234,%r231; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r233; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r235,[%value_in]; } mov.f32 %r149,%r235; .loc 1 176 0 setp.lt.f32 %r236,%r146,0f00000000; @ ! %r236 bra $L20; mov.u32 %r237,-1; st.u32 [%r167],%r237; $L20: .loc 1 177 0 neg.f32 %r166,%r166; .loc 1 181 0 add.u32 %r238,%r95,-1065353216; and.b32 %r239,%r238,-8388609; setp.eq.u32 %r240,%r239,0; @ %r240 bra $L41; $L40: .loc 1 183 0 setp.gt.s32 %r241,%r95,1073741823; @ %r241 bra $L23; .loc 1 184 0 setp.gt.s32 %r242,%r95,1063675494; @ %r242 bra $L24; .loc 1 185 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r244,[%value_in]; } neg.f32 %r109,%r244; .loc 1 186 0 setp.le.s32 %r245,%r95,1060850207; @ %r245 bra $L25; mov.f32 %r246,0f3f800000; sub.f32 %r108,%r246,%r166; bra $L26; $L25: .loc 1 187 0 setp.le.s32 %r247,%r95,1047343879; @ %r247 bra $L27; mov.f32 %r248,0f3eec5b0c; sub.f32 %r107,%r166,%r248; bra $L28; $L24: .loc 1 191 0 setp.le.s32 %r249,%r95,1071490583; @ %r249 bra $L29; mov.f32 %r250,0f40000000; sub.f32 %r108,%r250,%r166; .loc 1 190 0 mov.f32 %r109,0f00000000; bra $L26; $L29: .loc 1 192 0 setp.le.s32 %r251,%r95,1067296287; @ %r251 bra $L30; mov.f32 %r252,0f3fbb16c3; sub.f32 %r107,%r166,%r252; .loc 1 190 0 mov.f32 %r109,0f00000000; bra $L28; $L30: .loc 1 193 0 mov.f32 %r253,0f3f800000; sub.f32 %r166,%r166,%r253; .loc 1 190 0 mov.f32 %r109,0f00000000; bra $L27; $L26: .loc 1 197 0 mul.f32 %r118,%r108,%r108; .loc 1 199 0 fma.rn.f32 %r255,%r118,0f383c2c75,0f38e28445; fma.rn.f32 %r256,%r255,%r118,0f3a05b634; fma.rn.f32 %r257,%r256,%r118,0f3b3d6ec6; fma.rn.f32 %r258,%r257,%r118,0f3ca89915; fma.rn.f32 %r259,%r258,%r118,0f3ea51a66; .loc 1 198 0 fma.rn.f32 %r260,%r118,0f37d383a2,0f39679767; fma.rn.f32 %r261,%r260,%r118,0f3a9c54a1; fma.rn.f32 %r262,%r261,%r118,0f3bf2027e; fma.rn.f32 %r263,%r262,%r118,0f3d89f001; fma.rn.f32 %r264,%r263,%r118,0f3d9e233f; .loc 1 200 0 mul.f32 %r265,%r264,%r108; fma.rn.f32 %r266,%r259,%r118,%r265; .loc 1 201 0 fma.rn.f32 %r267,%r108,0fbf000000,%r266; add.f32 %r165,%r267,%r109; bra $L31; $L28: .loc 1 203 0 mul.f32 %r112,%r107,%r107; .loc 1 204 0 mul.f32 %r113,%r112,%r107; .loc 1 207 0 fma.rn.f32 %r268,%r113,0f39afe9f7,0fba0d3085; fma.rn.f32 %r269,%r268,%r113,0f3b141699; fma.rn.f32 %r270,%r269,%r113,0fbc28fcfe; fma.rn.f32 %r271,%r270,%r113,0f3d845a15; .loc 1 206 0 fma.rn.f32 %r272,%r113,0fb9a3f927,0f3a66f867; fma.rn.f32 %r273,%r272,%r113,0fbb7177fe; fma.rn.f32 %r274,%r273,%r113,0f3c93373d; fma.rn.f32 %r275,%r274,%r113,0fbe17213c; .loc 1 208 0 fma.rn.f32 %r276,%r271,%r107,%r275; neg.f32 %r277,%r276; fma.rn.f32 %r278,%r277,%r113,0f31e61c52; neg.f32 %r279,%r278; .loc 1 205 0 fma.rn.f32 %r280,%r113,0f39a57b6b,0fbab7f476; fma.rn.f32 %r281,%r280,%r113,0f3bc7e707; fma.rn.f32 %r282,%r281,%r113,0fbd064d47; fma.rn.f32 %r283,%r282,%r113,0f3ef7b95e; .loc 1 208 0 fma.rn.f32 %r284,%r112,%r283,%r279; .loc 1 209 0 mov.f32 %r286,0f3df8cdcd; sub.f32 %r285,%r284,%r286; add.f32 %r165,%r285,%r109; bra $L31; $L27: .loc 1 211 0 fma.rn.f32 %r287,%r166,0f3c5b3c5e,0f3e6a7578; fma.rn.f32 %r288,%r287,%r166,0f3f7a4bb2; fma.rn.f32 %r289,%r288,%r166,0f3fba3ae7; fma.rn.f32 %r290,%r289,%r166,0f3f2200f4; fma.rn.f32 %r291,%r290,%r166,0fbd9e233f; mul.f32 %r292,%r291,%r166; .loc 1 212 0 fma.rn.f32 %r293,%r166,0f3b52d5db,0f3dd572af; fma.rn.f32 %r294,%r293,%r166,0f3f44efdf; fma.rn.f32 %r295,%r294,%r166,0f4008392d; fma.rn.f32 %r296,%r295,%r166,0f401d2ebe; fma.rn.f32 %r297,%r296,%r166,0f3f800000; .loc 1 213 0 div.rn.f32 %r298,%r292,%r297; fma.rn.f32 %r299,%r166,0fbf000000,%r298; add.f32 %r165,%r299,%r109; bra $L31; $L23: .loc 1 216 0 setp.gt.s32 %r300,%r95,1090519039; @ %r300 bra $L32; .loc 1 217 0 cvt.rzi.s32.f32 %r101,%r166; .loc 1 219 0 cvt.rn.f32.s32 %r301,%r101; sub.f32 %r102,%r166,%r301; .loc 1 220 0 fma.rn.f32 %r302,%r102,0f3805ff67,0f3af135b4; fma.rn.f32 %r303,%r302,%r102,0f3cda40e4; fma.rn.f32 %r304,%r303,%r102,0f3e15dce6; fma.rn.f32 %r305,%r304,%r102,0f3ea6cc7a; fma.rn.f32 %r306,%r305,%r102,0f3e5c245a; fma.rn.f32 %r307,%r306,%r102,0fbd9e233f; mul.f32 %r308,%r307,%r102; .loc 1 221 0 fma.rn.f32 %r309,%r102,0f36f5d7bd,0f3a4beed6; fma.rn.f32 %r310,%r309,%r102,0f3c98bf54; fma.rn.f32 %r311,%r310,%r102,0f3e300f6e; fma.rn.f32 %r312,%r311,%r102,0f3f38d0c5; fma.rn.f32 %r313,%r312,%r102,0f3fb22d3b; fma.rn.f32 %r314,%r313,%r102,0f3f800000; .loc 1 222 0 div.rn.f32 %r315,%r308,%r314; fma.rn.f32 %r165,%r102,0f3f000000,%r315; .loc 1 224 0 setp.eq.u32 %r316,%r101,5; @ %r316 bra $L44; setp.gt.s32 %r317,%r101,5; @ %r317 bra $L34; setp.eq.u32 %r318,%r101,3; @ %r318 bra $L42; setp.eq.u32 %r319,%r101,4; @ %r319 bra $L43; bra $L31; $L34: setp.eq.u32 %r320,%r101,6; @ %r320 bra $L45; setp.eq.u32 %r321,%r101,7; @ ! %r321 bra $L31; .loc 1 225 0 add.f32 %r76,%r102,0f40c00000; bra $L37; $L45: .loc 1 223 0 mov.f32 %r76,0f3f800000; $L37: .loc 1 226 0 add.f32 %r322,%r102,0f40a00000; mul.f32 %r90,%r322,%r76; bra $L33; $L44: .loc 1 223 0 mov.f32 %r90,0f3f800000; $L33: .loc 1 227 0 add.f32 %r323,%r102,0f40800000; mul.f32 %r91,%r323,%r90; bra $L36; $L43: .loc 1 223 0 mov.f32 %r91,0f3f800000; $L36: .loc 1 228 0 add.f32 %r324,%r102,0f40400000; mul.f32 %r92,%r324,%r91; bra $L35; $L42: .loc 1 223 0 mov.f32 %r92,0f3f800000; $L35: .loc 1 229 0 add.f32 %r326,%r102,0f40000000; mul.f32 %r327,%r326,%r92; .loc 1 230 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r327; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r328,[%value_in]; } add.f32 %r165,%r165,%r328; bra $L31; $L32: .loc 1 233 0 setp.gt.s32 %r329,%r95,1551892479; @ %r329 bra $L39; .loc 1 234 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r331,[%value_in]; } .loc 1 235 0 mov.f32 %r332,0f3f800000; div.rn.f32 %r98,%r332,%r166; .loc 1 236 0 mul.f32 %r99,%r98,%r98; .loc 1 238 0 mov.f32 %r334,0f3f000000; sub.f32 %r333,%r166,%r334; .loc 1 237 0 fma.rn.f32 %r335,%r99,0fbad5c4e8,0f3a5b3dd2; fma.rn.f32 %r336,%r335,%r99,0fba1c065c; fma.rn.f32 %r337,%r336,%r99,0f3a500cfd; fma.rn.f32 %r338,%r337,%r99,0fbb360b61; fma.rn.f32 %r339,%r338,%r99,0f3daaaaab; fma.rn.f32 %r340,%r339,%r98,0f3ed67f1d; .loc 1 238 0 sub.f32 %r341,%r331,%r332; fma.rn.f32 %r165,%r333,%r341,%r340; bra $L31; $L39: .loc 1 241 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r166; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r344,[%value_in]; } mov.f32 %r346,0f3f800000; sub.f32 %r345,%r344,%r346; mul.f32 %r165,%r345,%r166; $L31: .loc 1 242 0 @ ! %r352 bra $L22; bra $L1; $L41: .loc 1 181 0 mov.f32 %r165,0f00000000; $L22: .loc 1 242 0 sub.f32 %r165,%r149,%r165; bra $L1; $L46: .loc 1 181 0 mov.f32 %r165,0f00000000; bra $L1; $L7: add.u32 %r349,%r95,-1065353216; and.b32 %r350,%r349,-8388609; setp.eq.u32 %r351,%r350,0; @ %r351 bra $L46; .loc 1 154 0 mov.f32 %r149,0f00000000; bra $L40; $L1: .loc 1 244 0 mov.f32 %value,%r165; st.param.f32 [%value_out],%value; ret; } lib_a-erfcl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erfcl .visible .func (.param .f64 %value_out) erfcl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/erfcl.c" // BEGIN GLOBAL FUNCTION DECL: erfc .extern .func (.param .f64 %value_out) erfc (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erfcl .visible .func (.param .f64 %value_out) erfcl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),erfc,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-erfl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erfl .visible .func (.param .f64 %value_out) erfl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/erfl.c" // BEGIN GLOBAL FUNCTION DECL: erf .extern .func (.param .f64 %value_out) erf (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erfl .visible .func (.param .f64 %value_out) erfl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),erf,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-exp2l.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp2l .visible .func (.param .f64 %value_out) exp2l (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/exp2l.c" // BEGIN GLOBAL FUNCTION DECL: exp2 .extern .func (.param .f64 %value_out) exp2 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: exp2l .visible .func (.param .f64 %value_out) exp2l (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),exp2,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-expl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expl .visible .func (.param .f64 %value_out) expl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/expl.c" // BEGIN GLOBAL FUNCTION DECL: exp .extern .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: expl .visible .func (.param .f64 %value_out) expl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),exp,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-expm1l.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expm1l .visible .func (.param .f64 %value_out) expm1l (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/expm1l.c" // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: expm1l .visible .func (.param .f64 %value_out) expm1l (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-fabsl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fabsl .visible .func (.param .f64 %value_out) fabsl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/fabsl.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fabsl .visible .func (.param .f64 %value_out) fabsl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-fdiml.o/ 0 0 0 644 1002 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fdiml .visible .func (.param .f64 %value_out) fdiml (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/fdiml.c" // BEGIN GLOBAL FUNCTION DECL: fdim .extern .func (.param .f64 %value_out) fdim (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fdiml .visible .func (.param .f64 %value_out) fdiml (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fdim,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-floorl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: floorl .visible .func (.param .f64 %value_out) floorl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/floorl.c" // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: floorl .visible .func (.param .f64 %value_out) floorl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),floor,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-fmal.o/ 0 0 0 644 1201 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmal .visible .func (.param .f64 %value_out) fmal (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/common/fmal.c" // BEGIN GLOBAL FUNCTION DECL: fma .extern .func (.param .f64 %value_out) fma (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: fmal .visible .func (.param .f64 %value_out) fmal (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r29; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; mov.f64 %r25,%ar2; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r25; call (%value_in),fma,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r29,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r29; st.param.f64 [%value_out],%value; ret; } lib_a-fmaxl.o/ 0 0 0 644 1002 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmaxl .visible .func (.param .f64 %value_out) fmaxl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/fmaxl.c" // BEGIN GLOBAL FUNCTION DECL: fmax .extern .func (.param .f64 %value_out) fmax (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fmaxl .visible .func (.param .f64 %value_out) fmaxl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fmax,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-fminl.o/ 0 0 0 644 1002 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fminl .visible .func (.param .f64 %value_out) fminl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/fminl.c" // BEGIN GLOBAL FUNCTION DECL: fmin .extern .func (.param .f64 %value_out) fmin (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fminl .visible .func (.param .f64 %value_out) fminl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fmin,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-fmodl.o/ 0 0 0 644 1002 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmodl .visible .func (.param .f64 %value_out) fmodl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/fmodl.c" // BEGIN GLOBAL FUNCTION DECL: fmod .extern .func (.param .f64 %value_out) fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: fmodl .visible .func (.param .f64 %value_out) fmodl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),fmod,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-frexpl.o/ 0 0 0 644 1010 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexpl .visible .func (.param .f64 %value_out) frexpl (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/frexpl.c" // BEGIN GLOBAL FUNCTION DECL: frexp .extern .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: frexpl .visible .func (.param .f64 %value_out) frexpl (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),frexp,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-hypotl.o/ 0 0 0 644 1010 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: hypotl .visible .func (.param .f64 %value_out) hypotl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/hypotl.c" // BEGIN GLOBAL FUNCTION DECL: hypot .extern .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: hypotl .visible .func (.param .f64 %value_out) hypotl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),hypot,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-ilogbl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ilogbl .visible .func (.param .u32 %value_out) ilogbl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/ilogbl.c" // BEGIN GLOBAL FUNCTION DECL: ilogb .extern .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: ilogbl .visible .func (.param .u32 %value_out) ilogbl (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u32 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),ilogb,(%out_arg1); ld.param.u32 %r25,[%value_in]; } .loc 1 40 0 mov.u32 %value,%r25; st.param.u32 [%value_out],%value; ret; } lib_a-k_cos.o/ 0 0 0 644 3128 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .visible .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/k_cos.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_cos .visible .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r46; .reg .f64 %r52; .reg .f64 %r54; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .pred %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .pred %r71; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .pred %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u64 %r84; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r87; .reg .f64 %r88; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; mov.f64 %r59,%ar0; mov.f64 %r60,%ar1; .loc 1 75 0 mov.b64 %r61,%r59; shr.u64 %r62,%r61,32; cvt.u32.u64 %r37,%r62; .loc 1 76 0 and.b32 %r38,%r37,2147483647; .loc 1 77 0 setp.gt.s32 %r63,%r38,1044381695; @ %r63 bra $L2; .loc 1 78 0 cvt.rzi.s32.f64 %r64,%r59; setp.eq.u32 %r65,%r64,0; @ ! %r65 bra $L10; bra $L8; $L2: .loc 1 80 0 mul.f64 %r46,%r59,%r59; .loc 1 81 0 fma.rn.f64 %r66,%r46,0dbda8fae9be8838d4,0d3e21ee9ebdb4b1c4; fma.rn.f64 %r67,%r66,%r46,0dbe927e4f809c52ad; fma.rn.f64 %r68,%r67,%r46,0d3efa01a019cb1590; fma.rn.f64 %r69,%r68,%r46,0dbf56c16c16c15177; fma.rn.f64 %r70,%r69,%r46,0d3fa555555555554c; mul.f64 %r52,%r70,%r46; .loc 1 82 0 setp.gt.s32 %r71,%r38,1070805810; @ %r71 bra $L5; $L7: .loc 1 83 0 mul.f64 %r72,%r59,%r60; neg.f64 %r73,%r72; fma.rn.f64 %r74,%r46,%r52,%r73; neg.f64 %r75,%r74; fma.rn.f64 %r76,%r46,0d3fe0000000000000,%r75; mov.f64 %r77,0d3ff0000000000000; sub.f64 %r58,%r77,%r76; bra $L1; $L5: .loc 1 85 0 setp.gt.s32 %r78,%r38,1072234496; @ %r78 bra $L9; .loc 1 88 0 add.u32 %r79,%r38,-2097152; cvt.u64.u32 %r80,%r79; shl.b64 %r84,%r80,32; mov.b64 %r36,%r84; mov.f64 %r85,0d3ff0000000000000; sub.f64 %r54,%r85,%r36; bra $L6; $L9: mov.f64 %r54,0d3fe7000000000000; .loc 1 86 0 mov.f64 %r36,0d3fd2000000000000; $L6: .loc 1 90 0 neg.f64 %r86,%r36; fma.rn.f64 %r87,%r46,0d3fe0000000000000,%r86; .loc 1 92 0 mul.f64 %r88,%r59,%r60; neg.f64 %r89,%r88; fma.rn.f64 %r90,%r46,%r52,%r89; sub.f64 %r91,%r87,%r90; sub.f64 %r58,%r54,%r91; bra $L1; $L8: .loc 1 78 0 mov.f64 %r58,0d3ff0000000000000; bra $L1; $L10: .loc 1 80 0 mul.f64 %r46,%r59,%r59; .loc 1 81 0 fma.rn.f64 %r93,%r46,0dbda8fae9be8838d4,0d3e21ee9ebdb4b1c4; fma.rn.f64 %r94,%r46,%r93,0dbe927e4f809c52ad; fma.rn.f64 %r95,%r46,%r94,0d3efa01a019cb1590; fma.rn.f64 %r96,%r46,%r95,0dbf56c16c16c15177; fma.rn.f64 %r97,%r46,%r96,0d3fa555555555554c; mul.f64 %r52,%r97,%r46; bra $L7; $L1: .loc 1 94 0 mov.f64 %value,%r58; st.param.f64 [%value_out],%value; ret; } /330 0 0 0 644 25571 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2 .visible .func (.param .u32 %value_out) __kernel_rem_pio2 (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); .file 1 "../../../../../../newlib/libm/math/k_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: init_jk .const .align 4 .u32 init_jk[4] = {2,3,4,6 }; // BEGIN VAR DEF: PIo2 .const .align 8 .u64 PIo2[8] = {4609753056584663040,4500296887714185216,4393339057296375808,4285399695318056960,4174867106174599168,4069606033725587456,3955147982449410048,3848874662444400640 }; // BEGIN GLOBAL FUNCTION DEF: __kernel_rem_pio2 .visible .func (.param .u32 %value_out) __kernel_rem_pio2 (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,560; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r261; .reg .u32 %r262; .reg .u32 %r263; .reg .u32 %r264; .reg .u32 %r265; .reg .u32 %r267; .reg .u32 %r273; .reg .u32 %r275; .reg .u32 %r277; .reg .f64 %r295; .reg .u32 %r299; .reg .u32 %r307; .reg .f64 %r313; .reg .f64 %r316; .reg .f64 %r317; .reg .u64 %r329; .reg .u32 %r330; .reg .u64 %r337; .reg .u64 %r338; .reg .u64 %r340; .reg .u32 %r341; .reg .f64 %r342; .reg .u64 %r343; .reg .f64 %r344; .reg .u32 %r348; .reg .u32 %r350; .reg .u32 %r351; .reg .f64 %r353; .reg .f64 %r354; .reg .u32 %r355; .reg .u32 %r357; .reg .u32 %r359; .reg .u64 %r360; .reg .f64 %r362; .reg .u32 %r364; .reg .u64 %r368; .reg .u32 %r369; .reg .f64 %r370; .reg .f64 %r371; .reg .f64 %r372; .reg .f64 %r374; .reg .u32 %r375; .reg .f64 %r376; .reg .f64 %r377; .reg .f64 %r378; .reg .f64 %r379; .reg .f64 %r381; .reg .f64 %r383; .reg .u32 %r385; .reg .u64 %r386; .reg .u32 %r388; .reg .u32 %r390; .reg .u64 %r395; .reg .u64 %r397; .reg .u32 %r399; .reg .u64 %r400; .reg .u64 %r401; .reg .u64 %r408; .reg .u64 %r415; .reg .u64 %r416; .reg .f64 %r419; .reg .u64 %r420; .reg .u64 %r421; .reg .f64 %r422; .reg .f64 %r423; .reg .u64 %r424; .reg .f64 %r427; .reg .u32 %r430; .reg .u64 %r431; .reg .u64 %r432; .reg .u64 %r433; .reg .u32 %r436; .reg .u64 %r437; .reg .u64 %r439; .reg .u32 %r441; .reg .u64 %r442; .reg .u64 %r443; .reg .u64 %r444; .reg .u64 %r446; .reg .u64 %r455; .reg .u64 %r456; .reg .u64 %r462; .reg .u64 %r463; .reg .u64 %r474; .reg .u64 %r476; .reg .u64 %r477; .reg .u64 %r482; .reg .u32 %r483; .reg .u64 %r487; .reg .u32 %r490; .reg .u32 %r496; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r504; .reg .u64 %r506; .reg .u64 %r514; .reg .u64 %r515; .reg .u64 %r527; .reg .u64 %r532; .reg .u64 %r534; .reg .u64 %r536; .reg .u64 %r537; .reg .u64 %r540; .reg .u64 %r550; .reg .u64 %r551; .reg .u64 %r552; .reg .u64 %r554; .reg .u64 %r562; .reg .u64 %r563; .reg .u64 %r564; .reg .u32 %r565; .reg .u32 %r570; .reg .u64 %r571; .reg .u64 %r572; .reg .u32 %r581; .reg .u64 %r584; .reg .u64 %r585; .reg .u32 %r586; .reg .u32 %r587; .reg .u32 %r588; .reg .u64 %r589; .reg .u64 %r590; .reg .u64 %r591; .reg .u64 %r592; .reg .u64 %r593; .reg .u32 %r594; .reg .u32 %r595; .reg .u32 %r597; .reg .u32 %r598; .reg .u32 %r599; .reg .pred %r600; .reg .u64 %r601; .reg .u64 %r602; .reg .u32 %r603; .reg .pred %r604; .reg .u32 %r605; .reg .pred %r606; .reg .u64 %r609; .reg .u64 %r610; .reg .f64 %r615; .reg .f64 %r616; .reg .pred %r617; .reg .pred %r618; .reg .u32 %r621; .reg .u64 %r622; .reg .u64 %r623; .reg .u64 %r624; .reg .u64 %r625; .reg .u64 %r626; .reg .u64 %r628; .reg .u64 %r629; .reg .u32 %r631; .reg .u64 %r632; .reg .u64 %r634; .reg .u64 %r636; .reg .u64 %r637; .reg .f64 %r638; .reg .u32 %r639; .reg .f64 %r641; .reg .u32 %r642; .reg .f64 %r643; .reg .pred %r644; .reg .f64 %r647; .reg .f64 %r649; .reg .f64 %r650; .reg .f64 %r652; .reg .u64 %r654; .reg .u64 %r655; .reg .u64 %r656; .reg .u64 %r657; .reg .u32 %r658; .reg .u32 %r659; .reg .u32 %r664; .reg .u32 %r665; .reg .u32 %r667; .reg .u64 %r668; .reg .u64 %r669; .reg .u64 %r670; .reg .u32 %r672; .reg .pred %r673; .reg .pred %r674; .reg .pred %r676; .reg .pred %r677; .reg .pred %r679; .reg .pred %r680; .reg .u64 %r681; .reg .u64 %r682; .reg .u64 %r683; .reg .u32 %r685; .reg .u32 %r686; .reg .pred %r687; .reg .u64 %r688; .reg .u64 %r689; .reg .u64 %r690; .reg .u32 %r694; .reg .u32 %r695; .reg .u64 %r696; .reg .u64 %r697; .reg .u64 %r698; .reg .u64 %r701; .reg .u64 %r702; .reg .u32 %r703; .reg .u64 %r704; .reg .u32 %r705; .reg .u32 %r706; .reg .pred %r707; .reg .u64 %r708; .reg .u64 %r709; .reg .u64 %r713; .reg .u64 %r714; .reg .u64 %r715; .reg .u64 %r716; .reg .u32 %r721; .reg .u32 %r722; .reg .u64 %r723; .reg .u64 %r724; .reg .u64 %r725; .reg .u64 %r726; .reg .u32 %r731; .reg .u32 %r732; .reg .pred %r733; .reg .f64 %r734; .reg .pred %r735; .reg .f64 %r738; .reg .pred %r739; .reg .pred %r740; .reg .u64 %r745; .reg .u32 %r746; .reg .u32 %r747; .reg .u64 %r748; .reg .u64 %r749; .reg .u32 %r750; .reg .pred %r751; .reg .pred %r752; .reg .u32 %r758; .reg .pred %r759; .reg .u32 %r760; .reg .pred %r761; .reg .pred %r762; .reg .u64 %r763; .reg .u64 %r764; .reg .u64 %r765; .reg .u64 %r767; .reg .u64 %r768; .reg .u64 %r769; .reg .u32 %r770; .reg .u64 %r773; .reg .u64 %r774; .reg .f64 %r775; .reg .pred %r776; .reg .pred %r777; .reg .u64 %r779; .reg .u64 %r780; .reg .u32 %r782; .reg .pred %r783; .reg .u32 %r785; .reg .u64 %r786; .reg .u64 %r787; .reg .u32 %r788; .reg .pred %r789; .reg .u32 %r792; .reg .f64 %r793; .reg .pred %r794; .reg .f64 %r795; .reg .u64 %r797; .reg .u64 %r798; .reg .f64 %r800; .reg .f64 %r802; .reg .u32 %r803; .reg .u64 %r804; .reg .u64 %r805; .reg .u64 %r806; .reg .u64 %r809; .reg .u64 %r810; .reg .u32 %r812; .reg .f64 %r813; .reg .f64 %r815; .reg .pred %r816; .reg .f64 %r822; .reg .u32 %r823; .reg .f64 %r824; .reg .pred %r825; .reg .f64 %r826; .reg .pred %r827; .reg .pred %r828; .reg .pred %r829; .reg .pred %r831; .reg .pred %r832; .reg .pred %r833; .reg .pred %r834; .reg .pred %r835; .reg .pred %r836; .reg .f64 %r841; .reg .pred %r842; .reg .pred %r843; .reg .u64 %r844; .reg .u64 %r845; .reg .f64 %r851; .reg .pred %r852; .reg .f64 %r854; .reg .f64 %r855; .reg .pred %r856; .reg .f64 %r858; .reg .pred %r859; .reg .u64 %r862; .reg .u64 %r863; .reg .u64 %r869; .reg .u64 %r871; .reg .u64 %r872; .reg .u64 %r874; .reg .u64 %r875; .reg .u64 %r876; .reg .u64 %r877; .reg .f64 %r878; .reg .f64 %r879; .reg .pred %r880; .reg .pred %r881; .reg .u64 %r883; .reg .u64 %r884; .reg .u32 %r889; .reg .u64 %r890; .reg .u64 %r891; .reg .u64 %r893; .reg .u64 %r894; .reg .u64 %r895; .reg .u64 %r896; .reg .f64 %r897; .reg .f64 %r898; .reg .pred %r899; .reg .u64 %r901; .reg .f64 %r902; .reg .pred %r903; .reg .pred %r904; .reg .f64 %r905; .reg .f64 %r906; .reg .f64 %r907; .reg .u32 %r908; .reg .pred %r909; .reg .f64 %r910; .reg .pred %r911; .reg .pred %r912; .reg .pred %r913; .reg .pred %r914; .reg .f64 %r915; .reg .pred %r916; .reg .u64 %r917; .reg .u32 %r918; .reg .pred %r919; .reg .pred %r921; .reg .u32 %r922; .reg .pred %r923; .reg .u64 %r924; .reg .pred %r925; .reg .pred %r926; .reg .u64 %r928; .reg .u64 %r929; .reg .u64 %r930; .reg .u64 %r931; .reg .f64 %r932; .reg .u64 %r933; .reg .pred %r934; .reg .pred %r935; .reg .pred %r936; .reg .u64 %r937; .reg .u32 %r938; .reg .u64 %r939; .reg .u64 %r940; .reg .u64 %r941; .reg .u64 %r942; .reg .u64 %r943; .reg .pred %r944; .reg .u64 %r945; .reg .u64 %r946; .reg .u64 %r947; .reg .f64 %r948; mov.u64 %r584,%ar0; mov.u64 %r585,%ar1; mov.u32 %r586,%ar2; mov.u32 %r587,%ar3; mov.u32 %r588,%ar4; mov.u64 %r589,%ar5; .loc 1 176 0 cvta.const.u64 %r590,init_jk; cvt.s64.s32 %r591,%r588; shl.b64 %r592,%r591,2; add.u64 %r593,%r590,%r592; ld.u32 %r348,[%r593]; .loc 1 180 0 add.u32 %r918,%r587,-1; .loc 1 181 0 add.u32 %r594,%r586,-3; div.s32 %r350,%r594,24; max.s32 %r390,%r350,0; .loc 1 182 0 add.u32 %r595,%r390,1; shl.b32 %r597,%r595,2; sub.u32 %r598,%r595,%r597; shl.b32 %r599,%r598,3; add.u32 %r264,%r599,%r586; .loc 1 185 0 sub.u32 %r385,%r390,%r918; add.u32 %r351,%r348,%r918; .loc 1 186 0 setp.lt.s32 %r600,%r351,0; @ %r600 bra $L2; add.u64 %r571,%frame,320; cvt.s64.s32 %r601,%r385; shl.b64 %r602,%r601,2; add.u64 %r572,%r589,%r602; add.u32 %r603,%r385,%r351; add.u32 %r581,%r603,1; mov.f64 %r948,0d0000000000000000; $L4: setp.lt.s32 %r604,%r385,0; @ %r604 bra $L71; ld.u32 %r605,[%r572]; cvt.rn.f64.s32 %r344,%r605; bra $L3; $L71: mov.f64 %r344,%r948; $L3: st.f64 [%r571],%r344; add.u32 %r385,%r385,1; add.u64 %r571,%r571,8; add.u64 %r572,%r572,4; setp.ne.u32 %r606,%r385,%r581; @ %r606 bra $L4; $L2: .loc 1 189 0 setp.lt.s32 %r926,%r348,0; @ %r926 bra $L5; mov.u64 %r564,%frame; mov.u32 %r565,%r918; add.u32 %r570,%r348,%r587; cvt.u64.u32 %r609,%r918; shl.b64 %r562,%r609,3; setp.ge.s32 %r925,%r918,0; add.u64 %r945,%frame,320; add.u64 %r946,%frame,312; sub.u64 %r947,%r946,%r562; bra $L6; $L8: mov.u64 %r551,%r584; cvt.s64.s32 %r610,%r565; shl.b64 %r554,%r610,3; add.u64 %r552,%r945,%r554; add.u64 %r563,%r947,%r554; .loc 1 190 0 mov.f64 %r383,0d0000000000000000; $L7: ld.f64 %r615,[%r551]; ld.f64 %r616,[%r552]; fma.rn.f64 %r383,%r615,%r616,%r383; add.u64 %r551,%r551,8; add.u64 %r552,%r552,-8; setp.ne.u64 %r617,%r552,%r563; @ %r617 bra $L7; $L9: st.f64 [%r564],%r383; add.u64 %r564,%r564,8; add.u32 %r565,%r565,1; .loc 1 189 0 setp.eq.u32 %r618,%r565,%r570; @ %r618 bra $L5; $L6: .loc 1 190 0 @ %r925 bra $L8; mov.f64 %r383,0d0000000000000000; bra $L9; $L5: add.u64 %r917,%frame,480; add.u32 %r621,%r348,-2; cvt.s64.s32 %r622,%r621; shl.b64 %r623,%r622,2; add.u64 %r498,%r917,%r623; add.u64 %r624,%r584,8; cvt.u64.u32 %r625,%r918; shl.b64 %r626,%r625,3; add.u64 %r474,%r624,%r626; .loc 1 176 0 mov.u32 %r307,%r348; setp.le.s32 %r919,%r264,0; add.u64 %r933,%frame,-8; .loc 1 227 0 setp.eq.u32 %r934,%r264,1; setp.eq.u32 %r935,%r264,2; .loc 1 213 0 setp.ne.u32 %r936,%r264,0; add.u64 %r937,%frame,476; .loc 1 245 0 add.u32 %r938,%r348,-1; cvt.s64.s32 %r939,%r938; shl.b64 %r940,%r939,2; add.u64 %r941,%frame,%r940; add.u64 %r942,%r941,480; add.u64 %r943,%frame,320; setp.lt.s32 %r944,%r918,0; $L10: .loc 1 196 0 cvt.s64.s32 %r924,%r307; shl.b64 %r628,%r924,3; add.u64 %r629,%frame,%r628; ld.f64 %r317,[%r629]; setp.le.s32 %r921,%r307,0; @ %r921 bra $L11; mov.u64 %r536,%r917; add.u32 %r631,%r307,-1; cvt.s64.s32 %r632,%r631; shl.b64 %r540,%r632,3; add.u64 %r537,%frame,%r540; add.u64 %r634,%r933,%r540; cvt.u64.u32 %r636,%r631; shl.b64 %r637,%r636,3; sub.u64 %r550,%r634,%r637; $L12: .loc 1 197 0 mul.f64 %r638,%r317,0d3e70000000000000; cvt.rzi.s32.f64 %r639,%r638; cvt.rn.f64.s32 %r381,%r639; .loc 1 198 0 fma.rn.f64 %r641,%r381,0dc170000000000000,%r317; cvt.rzi.s32.f64 %r642,%r641; st.u32 [%r536],%r642; .loc 1 199 0 ld.f64 %r643,[%r537]; add.f64 %r317,%r381,%r643; add.u64 %r536,%r536,4; add.u64 %r537,%r537,-8; .loc 1 196 0 setp.ne.u64 %r644,%r537,%r550; @ %r644 bra $L12; $L11: .loc 1 203 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r317; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r264; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r647,[%value_in]; } .loc 1 204 0 mul.f64 %r649,%r647,0d3fc0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r649; call (%value_in),floor,(%out_arg1); ld.param.f64 %r650,[%value_in]; } fma.rn.f64 %r354,%r650,0dc020000000000000,%r647; .loc 1 205 0 cvt.rzi.s32.f64 %r330,%r354; .loc 1 206 0 cvt.rn.f64.s32 %r652,%r330; sub.f64 %r342,%r354,%r652; .loc 1 208 0 @ %r919 bra $L13; .loc 1 209 0 add.u32 %r261,%r307,-1; cvt.s64.s32 %r654,%r261; shl.b64 %r655,%r654,2; add.u64 %r656,%frame,%r655; add.u64 %r657,%r656,480; ld.u32 %r262,[%r657]; mov.u32 %r658,24; sub.u32 %r263,%r658,%r264; shr.s32 %r355,%r262,%r263; add.u32 %r330,%r330,%r355; .loc 1 210 0 shl.b32 %r659,%r355,%r263; sub.u32 %r267,%r262,%r659; st.u32 [%r657],%r267; .loc 1 211 0 mov.u32 %r665,23; sub.u32 %r664,%r665,%r264; shr.s32 %r341,%r267,%r664; bra $L14; $L13: .loc 1 213 0 @ %r936 bra $L15; add.u32 %r667,%r307,-1; cvt.s64.s32 %r668,%r667; shl.b64 %r669,%r668,2; add.u64 %r670,%frame,%r669; ld.u32 %r672,[%r670+480]; shr.s32 %r341,%r672,23; bra $L14; $L15: .loc 1 214 0 setp.ge.f64 %r673,%r342,0d3fe0000000000000; @ %r673 bra $L16; .loc 1 207 0 mov.u32 %r341,0; bra $L17; $L14: .loc 1 216 0 setp.le.s32 %r674,%r341,0; @ %r674 bra $L17; .loc 1 217 0 add.u32 %r330,%r330,1; .loc 1 218 0 @ ! %r921 bra $L68; bra $L72; $L81: .loc 1 214 0 mov.u32 %r341,2; $L68: .loc 1 219 0 ld.u32 %r357,[%frame+480]; .loc 1 221 0 setp.ne.u32 %r676,%r357,0; @ %r676 bra $L73; .loc 1 218 0 setp.eq.u32 %r677,%r307,1; @ %r677 bra $L18; add.u64 %r534,%frame,484; mov.u32 %r399,1; bra $L20; $L21: add.u64 %r534,%r534,4; mov.u32 %r399,%r430; setp.eq.u32 %r679,%r307,%r399; @ %r679 bra $L18; $L20: .loc 1 219 0 ld.u32 %r357,[%r534]; add.u32 %r430,%r399,1; .loc 1 221 0 setp.eq.u32 %r680,%r357,0; @ %r680 bra $L21; bra $L19; $L73: mov.u32 %r430,1; mov.u32 %r399,0; $L19: .loc 1 222 0 cvt.s64.s32 %r681,%r399; shl.b64 %r682,%r681,2; add.u64 %r683,%frame,%r682; mov.u32 %r686,16777216; sub.u32 %r685,%r686,%r357; st.u32 [%r683+480],%r685; .loc 1 218 0 setp.le.s32 %r687,%r307,%r430; @ %r687 bra $L74; .loc 1 219 0 cvt.s64.s32 %r688,%r430; shl.b64 %r689,%r688,2; add.u64 %r690,%frame,%r689; ld.u32 %r388,[%r690+480]; add.u64 %r515,%r917,%r689; add.u32 %r694,%r307,-1; sub.u32 %r695,%r694,%r430; cvt.u64.u32 %r696,%r695; add.u64 %r697,%r696,%r688; shl.b64 %r698,%r697,2; add.u64 %r527,%r917,%r698; neg.s64 %r701,%r688; shl.b64 %r702,%r701,2; add.u32 %r703,%r430,1; cvt.u64.u32 %r704,%r703; shl.b64 %r532,%r704,2; .loc 1 224 0 mov.u32 %r706,16777215; $L22: sub.u32 %r705,%r706,%r388; st.u32 [%r515],%r705; .loc 1 218 0 setp.eq.u64 %r707,%r515,%r527; @ %r707 bra $L75; .loc 1 219 0 add.u64 %r708,%r515,%r702; add.u64 %r709,%r708,%r532; ld.u32 %r388,[%r709]; add.u64 %r515,%r515,4; bra $L22; $L72: .loc 1 217 0 mov.u32 %r357,0; bra $L18; $L74: .loc 1 222 0 mov.u32 %r357,1; bra $L18; $L75: mov.u32 %r357,1; $L18: .loc 1 226 0 @ %r919 bra $L23; .loc 1 227 0 @ %r934 bra $L24; @ %r935 bra $L25; bra $L23; $L24: .loc 1 229 0 add.u32 %r273,%r307,-1; cvt.s64.s32 %r713,%r273; shl.b64 %r714,%r713,2; add.u64 %r715,%frame,%r714; add.u64 %r716,%r715,480; ld.u32 %r722,[%r716]; and.b32 %r721,%r722,8388607; st.u32 [%r716],%r721; bra $L23; $L25: .loc 1 231 0 add.u32 %r277,%r307,-1; cvt.s64.s32 %r723,%r277; shl.b64 %r724,%r723,2; add.u64 %r725,%frame,%r724; add.u64 %r726,%r725,480; ld.u32 %r732,[%r726]; and.b32 %r731,%r732,4194303; st.u32 [%r726],%r731; $L23: .loc 1 234 0 setp.ne.u32 %r733,%r341,2; @ %r733 bra $L17; .loc 1 235 0 mov.f64 %r734,0d3ff0000000000000; sub.f64 %r342,%r734,%r342; .loc 1 236 0 setp.eq.u32 %r735,%r357,0; @ %r735 bra $L17; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r734; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r264; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r738,[%value_in]; } sub.f64 %r342,%r342,%r738; $L17: .loc 1 241 0 setp.neu.f64 %r739,%r342,0d0000000000000000; @ %r739 bra $L26; .loc 1 243 0 add.u32 %r369,%r307,-1; setp.gt.s32 %r740,%r348,%r369; @ %r740 bra $L27; cvt.s64.s32 %r928,%r369; shl.b64 %r506,%r928,2; add.u64 %r504,%r917,%r506; add.u64 %r745,%r937,%r506; not.b32 %r746,%r348; add.u32 %r747,%r746,%r307; cvt.u64.u32 %r748,%r747; shl.b64 %r749,%r748,2; sub.u64 %r514,%r745,%r749; .loc 1 242 0 mov.u32 %r364,0; $L28: .loc 1 243 0 ld.u32 %r750,[%r504]; or.b32 %r364,%r364,%r750; add.u64 %r504,%r504,-4; setp.ne.u64 %r751,%r504,%r514; @ %r751 bra $L28; .loc 1 244 0 setp.ne.u32 %r752,%r364,0; @ %r752 bra $L29; $L27: .loc 1 245 0 ld.u32 %r758,[%r942]; setp.ne.u32 %r759,%r758,0; @ %r759 bra $L76; mov.u64 %r497,%r498; mov.u32 %r275,1; $L31: add.u32 %r275,%r275,1; add.u64 %r497,%r497,-4; ld.u32 %r760,[%r497+4]; setp.eq.u32 %r761,%r760,0; @ %r761 bra $L31; bra $L30; $L76: mov.u32 %r275,1; $L30: .loc 1 247 0 add.u32 %r359,%r307,1; add.u32 %r307,%r307,%r275; setp.gt.s32 %r762,%r359,%r307; @ %r762 bra $L10; cvt.s64.s32 %r477,%r359; cvt.s64.s32 %r763,%r390; add.u64 %r764,%r763,%r477; shl.b64 %r765,%r764,2; add.u64 %r476,%r589,%r765; add.u32 %r483,%r918,%r359; cvt.s64.s32 %r767,%r483; shl.b64 %r768,%r767,3; add.u64 %r482,%r943,%r768; shl.b64 %r769,%r477,3; add.u64 %r487,%frame,%r769; add.u32 %r490,%r483,-1; add.u32 %r496,%r307,%r918; $L35: .loc 1 248 0 ld.u32 %r770,[%r476]; cvt.rn.f64.s32 %r427,%r770; st.f64 [%r482],%r427; .loc 1 249 0 @ %r944 bra $L77; cvt.s64.s32 %r773,%r490; shl.b64 %r774,%r773,3; add.u64 %r463,%r943,%r774; mov.u64 %r462,%r584; mov.f64 %r362,0d0000000000000000; $L34: ld.f64 %r775,[%r462]; fma.rn.f64 %r362,%r775,%r427,%r362; add.u64 %r462,%r462,8; setp.eq.u64 %r776,%r462,%r474; @ %r776 bra $L33; ld.f64 %r427,[%r463]; add.u64 %r463,%r463,-8; bra $L34; $L77: mov.f64 %r362,0d0000000000000000; $L33: .loc 1 250 0 st.f64 [%r487],%r362; add.u64 %r476,%r476,4; add.u64 %r482,%r482,8; add.u64 %r487,%r487,8; add.u32 %r490,%r490,1; .loc 1 247 0 setp.ne.u32 %r777,%r490,%r496; @ %r777 bra $L35; bra $L10; $L29: .loc 1 259 0 add.u32 %r264,%r264,-24; .loc 1 260 0 shl.b64 %r779,%r928,2; add.u64 %r780,%frame,%r779; ld.u32 %r782,[%r780+480]; setp.ne.u32 %r783,%r782,0; @ %r783 bra $L36; add.u32 %r785,%r307,-2; cvt.s64.s32 %r786,%r785; shl.b64 %r787,%r786,2; add.u64 %r456,%r917,%r787; $L37: add.u32 %r369,%r369,-1; add.u32 %r264,%r264,-24; add.u64 %r456,%r456,-4; ld.u32 %r788,[%r456+4]; setp.eq.u32 %r789,%r788,0; @ %r789 bra $L37; bra $L36; $L26: .loc 1 262 0 neg.s32 %r792,%r264; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r342; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r792; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r793,[%value_in]; } .loc 1 263 0 setp.ge.f64 %r794,%r793,0d4170000000000000; @ ! %r794 bra $L115; .loc 1 264 0 mul.f64 %r795,%r793,0d3e70000000000000; cvt.rzi.s32.f64 %r299,%r795; .loc 1 265 0 shl.b64 %r797,%r924,2; add.u64 %r798,%frame,%r797; .loc 1 264 0 cvt.rn.f64.s32 %r800,%r299; .loc 1 265 0 fma.rn.f64 %r802,%r800,0dc170000000000000,%r793; cvt.rzi.s32.f64 %r803,%r802; st.u32 [%r798+480],%r803; .loc 1 266 0 add.u32 %r369,%r307,1; add.u32 %r264,%r264,24; .loc 1 267 0 cvt.s64.s32 %r804,%r369; shl.b64 %r805,%r804,2; add.u64 %r806,%frame,%r805; st.u32 [%r806+480],%r299; bra $L36; $L115: .loc 1 268 0 shl.b64 %r809,%r924,2; add.u64 %r810,%frame,%r809; cvt.rzi.s32.f64 %r812,%r793; st.u32 [%r810+480],%r812; mov.u32 %r369,%r307; $L36: .loc 1 272 0 mov.f64 %r813,0d3ff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r813; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r264; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r815,[%value_in]; } mov.f64 %r379,%r815; .loc 1 273 0 setp.lt.s32 %r816,%r369,0; @ %r816 bra $L40; cvt.s64.s32 %r443,%r369; shl.b64 %r444,%r443,2; add.u64 %r442,%r917,%r444; shl.b64 %r930,%r443,3; add.u64 %r439,%frame,%r930; add.u64 %r455,%frame,476; mov.u64 %r446,%r439; $L41: .loc 1 274 0 ld.u32 %r823,[%r442]; cvt.rn.f64.s32 %r822,%r823; mul.f64 %r824,%r822,%r379; st.f64 [%r446],%r824; mul.f64 %r379,%r379,0d3e70000000000000; add.u64 %r442,%r442,-4; add.u64 %r446,%r446,-8; .loc 1 273 0 setp.ne.u64 %r825,%r442,%r455; @ %r825 bra $L41; add.u64 %r931,%frame,160; add.u32 %r441,%r369,1; mov.u64 %r437,%r931; mov.u32 %r436,0; .loc 1 279 0 mov.f64 %r932,0d3ff921fb40000000; bra $L42; $L44: ld.f64 %r826,[%r432]; fma.rn.f64 %r378,%r826,%r419,%r378; add.u32 %r265,%r265,1; setp.lt.s32 %r827,%r348,%r265; @ %r827 bra $L43; add.u64 %r432,%r432,8; add.u64 %r433,%r433,8; setp.gt.s32 %r828,%r265,%r436; @ %r828 bra $L43; ld.f64 %r419,[%r433]; bra $L44; $L78: mov.f64 %r378,0d0000000000000000; $L43: .loc 1 280 0 st.f64 [%r437],%r378; add.u32 %r436,%r436,1; add.u64 %r437,%r437,8; add.u64 %r439,%r439,-8; .loc 1 278 0 setp.eq.u32 %r829,%r436,%r441; @ %r829 bra $L45; $L42: .loc 1 279 0 @ %r926 bra $L78; cvta.const.u64 %r433,PIo2; mov.u64 %r432,%r439; mov.f64 %r419,%r932; mov.f64 %r378,0d0000000000000000; mov.u32 %r265,0; bra $L44; $L40: .loc 1 284 0 setp.gt.s32 %r831,%r588,2; @ %r831 bra $L47; setp.gt.s32 %r832,%r588,0; @ %r832 bra $L48; setp.eq.u32 %r833,%r588,0; @ %r833 bra $L79; bra $L51; $L47: setp.eq.u32 %r834,%r588,3; @ ! %r834 bra $L51; $L50: .loc 1 300 0 setp.gt.s32 %r835,%r369,0; @ %r835 bra $L52; .loc 1 310 0 mov.f64 %r370,0d0000000000000000; bra $L53; $L48: .loc 1 293 0 setp.ge.s32 %r836,%r369,0; @ %r836 bra $L54; .loc 1 292 0 mov.f64 %r376,0d0000000000000000; bra $L55; $L56: add.u64 %r408,%r931,%r930; add.u64 %r401,%r931,-8; .loc 1 284 0 mov.f64 %r377,0d0000000000000000; $L57: .loc 1 287 0 ld.f64 %r841,[%r408]; add.f64 %r377,%r377,%r841; add.u64 %r408,%r408,-8; setp.ne.u64 %r842,%r401,%r408; @ %r842 bra $L57; bra $L49; $L79: .loc 1 286 0 mov.f64 %r377,0d0000000000000000; $L49: .loc 1 288 0 setp.eq.u32 %r843,%r341,0; @ %r843 bra $L58; neg.f64 %r377,%r377; $L58: st.f64 [%r585],%r377; .loc 1 289 0 bra $L51; $L54: cvt.s64.s32 %r844,%r369; shl.b64 %r395,%r844,3; add.u64 %r845,%frame,160; add.u64 %r397,%r845,%r395; add.u64 %r386,%frame,152; .loc 1 292 0 mov.f64 %r376,0d0000000000000000; $L59: .loc 1 293 0 ld.f64 %r851,[%r397]; add.f64 %r376,%r376,%r851; add.u64 %r397,%r397,-8; setp.ne.u64 %r852,%r386,%r397; @ %r852 bra $L59; $L55: .loc 1 294 0 setp.eq.u32 %r923,%r341,0; @ %r923 bra $L60; neg.f64 %r854,%r376; st.f64 [%r585],%r854; .loc 1 295 0 ld.f64 %r855,[%frame+160]; sub.f64 %r374,%r855,%r376; .loc 1 296 0 setp.le.s32 %r856,%r369,0; @ %r856 bra $L61; $L70: add.u64 %r400,%frame,168; .loc 1 292 0 mov.u32 %r375,1; $L62: .loc 1 296 0 ld.f64 %r858,[%r400]; add.f64 %r374,%r374,%r858; add.u32 %r375,%r375,1; add.u64 %r400,%r400,8; setp.ge.s32 %r859,%r369,%r375; @ %r859 bra $L62; .loc 1 297 0 @ %r923 bra $L63; $L61: neg.f64 %r374,%r374; $L63: st.f64 [%r585+8],%r374; .loc 1 298 0 bra $L51; $L52: cvt.s64.s32 %r928,%r369; shl.b64 %r862,%r928,3; add.u64 %r863,%frame,%r862; ld.f64 %r295,[%r863+160]; add.u32 %r922,%r369,-1; cvt.s64.s32 %r416,%r922; shl.b64 %r415,%r416,3; add.u64 %r931,%frame,160; add.u64 %r420,%r931,%r415; add.u64 %r929,%frame,152; add.u64 %r869,%r929,%r415; cvt.u64.u32 %r871,%r922; shl.b64 %r872,%r871,3; sub.u64 %r431,%r869,%r872; neg.s64 %r874,%r416; shl.b64 %r875,%r874,3; add.u64 %r368,%r415,8; $L64: .loc 1 301 0 ld.f64 %r313,[%r420]; add.f64 %r372,%r313,%r295; .loc 1 302 0 add.u64 %r876,%r875,%r420; add.u64 %r877,%r876,%r368; sub.f64 %r878,%r313,%r372; add.f64 %r879,%r878,%r295; st.f64 [%r877],%r879; .loc 1 303 0 st.f64 [%r420],%r372; add.u64 %r420,%r420,-8; mov.f64 %r295,%r372; .loc 1 300 0 setp.ne.u64 %r880,%r420,%r431; @ %r880 bra $L64; .loc 1 305 0 setp.le.s32 %r881,%r369,1; @ %r881 bra $L80; shl.b64 %r883,%r928,3; add.u64 %r884,%frame,%r883; ld.f64 %r353,[%r884+160]; cvt.s64.s32 %r338,%r922; shl.b64 %r337,%r338,3; add.u64 %r340,%r931,%r337; add.u32 %r889,%r369,-2; cvt.u64.u32 %r890,%r889; shl.b64 %r424,%r890,3; add.u64 %r891,%r929,%r337; sub.u64 %r421,%r891,%r424; neg.s64 %r893,%r338; shl.b64 %r894,%r893,3; add.u64 %r329,%r337,8; $L65: .loc 1 306 0 ld.f64 %r316,[%r340]; add.f64 %r371,%r316,%r353; .loc 1 307 0 add.u64 %r895,%r894,%r340; add.u64 %r896,%r895,%r329; sub.f64 %r897,%r316,%r371; add.f64 %r898,%r897,%r353; st.f64 [%r896],%r898; .loc 1 308 0 st.f64 [%r340],%r371; add.u64 %r340,%r340,-8; mov.f64 %r353,%r371; .loc 1 305 0 setp.ne.u64 %r899,%r340,%r421; @ %r899 bra $L65; add.u64 %r360,%r931,%r329; add.u64 %r901,%r929,%r329; sub.u64 %r343,%r901,%r424; .loc 1 310 0 mov.f64 %r370,0d0000000000000000; $L66: ld.f64 %r902,[%r360]; add.f64 %r370,%r370,%r902; add.u64 %r360,%r360,-8; setp.ne.u64 %r903,%r343,%r360; @ %r903 bra $L66; bra $L53; $L80: mov.f64 %r370,0d0000000000000000; $L53: ld.f64 %r422,[%frame+160]; ld.f64 %r423,[%frame+168]; .loc 1 311 0 setp.ne.u32 %r904,%r341,0; @ %r904 bra $L67; .loc 1 312 0 st.f64 [%r585],%r422; st.f64 [%r585+8],%r423; st.f64 [%r585+16],%r370; bra $L51; $L67: .loc 1 314 0 neg.f64 %r905,%r422; st.f64 [%r585],%r905; neg.f64 %r906,%r423; st.f64 [%r585+8],%r906; neg.f64 %r907,%r370; st.f64 [%r585+16],%r907; $L51: .loc 1 317 0 and.b32 %r908,%r330,7; bra $L116; $L16: .loc 1 217 0 add.u32 %r330,%r330,1; .loc 1 218 0 setp.gt.s32 %r909,%r307,0; @ %r909 bra $L81; .loc 1 235 0 mov.f64 %r910,0d3ff0000000000000; sub.f64 %r342,%r910,%r342; mov.u32 %r341,2; bra $L17; $L45: .loc 1 284 0 setp.gt.s32 %r911,%r588,2; @ %r911 bra $L69; setp.gt.s32 %r912,%r588,0; @ %r912 bra $L48; setp.eq.u32 %r913,%r588,0; @ %r913 bra $L56; bra $L51; $L69: setp.eq.u32 %r914,%r588,3; @ %r914 bra $L50; bra $L51; $L60: .loc 1 294 0 st.f64 [%r585],%r376; .loc 1 295 0 ld.f64 %r915,[%frame+160]; sub.f64 %r374,%r915,%r376; .loc 1 296 0 setp.gt.s32 %r916,%r369,0; @ %r916 bra $L70; bra $L63; $L116: .loc 1 318 0 mov.u32 %value,%r908; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-k_sin.o/ 0 0 0 644 2106 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .visible .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libm/math/k_sin.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_sin .visible .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r31; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .u32 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; mov.f64 %r43,%ar0; mov.f64 %r44,%ar1; mov.u32 %r45,%ar2; .loc 1 68 0 mov.b64 %r46,%r43; shr.u64 %r47,%r46,32; cvt.u32.u64 %r31,%r47; .loc 1 69 0 and.b32 %r48,%r31,2147483647; .loc 1 70 0 setp.gt.s32 %r49,%r48,1044381695; @ %r49 bra $L2; .loc 1 71 0 cvt.rzi.s32.f64 %r50,%r43; setp.eq.u32 %r51,%r50,0; @ %r51 bra $L5; $L2: .loc 1 72 0 mul.f64 %r33,%r43,%r43; .loc 1 73 0 mul.f64 %r34,%r43,%r33; .loc 1 74 0 fma.rn.f64 %r52,%r33,0d3de5d93a5acfd57c,0dbe5ae5e68a2b9ceb; fma.rn.f64 %r53,%r52,%r33,0d3ec71de357b1fe7d; fma.rn.f64 %r54,%r53,%r33,0dbf2a01a019c161d5; fma.rn.f64 %r35,%r54,%r33,0d3f8111111110f8a6; .loc 1 75 0 setp.ne.u32 %r55,%r45,0; @ %r55 bra $L4; fma.rn.f64 %r56,%r33,%r35,0dbfc5555555555549; fma.rn.f64 %r42,%r56,%r34,%r43; bra $L1; $L4: .loc 1 76 0 mul.f64 %r57,%r34,%r35; neg.f64 %r58,%r57; fma.rn.f64 %r59,%r44,0d3fe0000000000000,%r58; neg.f64 %r60,%r44; fma.rn.f64 %r61,%r59,%r33,%r60; fma.rn.f64 %r62,%r34,0d3fc5555555555549,%r61; sub.f64 %r42,%r43,%r62; bra $L1; $L5: .loc 1 71 0 mov.f64 %r42,%r43; $L1: .loc 1 77 0 mov.f64 %value,%r42; st.param.f64 [%value_out],%value; ret; } /350 0 0 0 644 70152 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __kernel_standard .visible .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libm/math/k_standard.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {97,99,111,115,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {97,99,111,115,102,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[5] = {97,115,105,110,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[6] = {97,115,105,110,102,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[6] = {97,116,97,110,50,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[7] = {97,116,97,110,50,102,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[6] = {104,121,112,111,116,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[7] = {104,121,112,111,116,102,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[5] = {99,111,115,104,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[6] = {99,111,115,104,102,0 }; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[4] = {101,120,112,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[5] = {101,120,112,102,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[3] = {121,48,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[4] = {121,48,102,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[3] = {121,49,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[4] = {121,49,102,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[3] = {121,110,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[4] = {121,110,102,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[7] = {108,103,97,109,109,97,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[8] = {108,103,97,109,109,97,102,0 }; // BEGIN VAR DEF: $LC33 .const .align 1 .u8 $LC33[11] = {114,101,109,97,105,110,100,101,114,102,0 }; // BEGIN VAR DEF: $LC34 .const .align 1 .u8 $LC34[6] = {97,99,111,115,104,0 }; // BEGIN VAR DEF: $LC35 .const .align 1 .u8 $LC35[7] = {97,99,111,115,104,102,0 }; // BEGIN VAR DEF: $LC36 .const .align 1 .u8 $LC36[6] = {97,116,97,110,104,0 }; // BEGIN VAR DEF: $LC37 .const .align 1 .u8 $LC37[7] = {97,116,97,110,104,102,0 }; // BEGIN VAR DEF: $LC38 .const .align 1 .u8 $LC38[6] = {115,99,97,108,98,0 }; // BEGIN VAR DEF: $LC39 .const .align 1 .u8 $LC39[7] = {115,99,97,108,98,102,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[5] = {102,109,111,100,0 }; // BEGIN VAR DEF: $LC31 .const .align 1 .u8 $LC31[6] = {102,109,111,100,102,0 }; // BEGIN VAR DEF: $LC32 .const .align 1 .u8 $LC32[10] = {114,101,109,97,105,110,100,101,114,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[6] = {115,105,110,104,102,0 }; // BEGIN VAR DEF: $LC40 .const .align 1 .u8 $LC40[3] = {106,48,0 }; // BEGIN VAR DEF: $LC41 .const .align 1 .u8 $LC41[4] = {106,48,102,0 }; // BEGIN VAR DEF: $LC42 .const .align 1 .u8 $LC42[3] = {106,49,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[4] = {108,111,103,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[5] = {108,111,103,102,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[6] = {108,111,103,49,48,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[7] = {108,111,103,49,48,102,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[4] = {112,111,119,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[5] = {112,111,119,102,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[5] = {115,105,110,104,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[5] = {115,113,114,116,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[6] = {115,113,114,116,102,0 }; // BEGIN VAR DEF: $LC43 .const .align 1 .u8 $LC43[4] = {106,49,102,0 }; // BEGIN VAR DEF: $LC44 .const .align 1 .u8 $LC44[3] = {106,110,0 }; // BEGIN VAR DEF: $LC45 .const .align 1 .u8 $LC45[4] = {106,110,102,0 }; // BEGIN VAR DEF: $LC46 .const .align 1 .u8 $LC46[6] = {103,97,109,109,97,0 }; // BEGIN VAR DEF: $LC47 .const .align 1 .u8 $LC47[7] = {103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: __kernel_standard .visible .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .u32 %r38; .reg .u32 %r42; .reg .u32 %r50; .reg .u32 %r54; .reg .u32 %r58; .reg .u32 %r62; .reg .u32 %r66; .reg .u32 %r70; .reg .u32 %r74; .reg .u32 %r78; .reg .u32 %r82; .reg .u32 %r86; .reg .u32 %r90; .reg .u32 %r94; .reg .u32 %r101; .reg .u32 %r111; .reg .u32 %r115; .reg .u32 %r120; .reg .u32 %r124; .reg .u32 %r129; .reg .u32 %r187; .reg .u32 %r191; .reg .u32 %r201; .reg .u64 %r202; .reg .u64 %r203; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u64 %r211; .reg .u64 %r212; .reg .u64 %r213; .reg .u64 %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .u64 %r217; .reg .u64 %r218; .reg .u64 %r219; .reg .u64 %r220; .reg .u64 %r221; .reg .u64 %r222; .reg .u64 %r223; .reg .u64 %r224; .reg .u64 %r225; .reg .u64 %r226; .reg .f64 %r227; .reg .f64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .f64 %r236; .reg .u64 %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u64 %r245; .reg .u64 %r246; .reg .u32 %r247; .reg .f64 %r248; .reg .u32 %r249; .reg .f64 %r250; .reg .f64 %r251; .reg .f64 %r252; .reg .u32 %r253; .reg .u32 %r254; .reg .pred %r255; .reg .pred %r256; .reg .pred %r257; .reg .pred %r258; .reg .pred %r259; .reg .pred %r260; .reg .pred %r261; .reg .pred %r262; .reg .pred %r263; .reg .pred %r264; .reg .pred %r265; .reg .pred %r266; .reg .pred %r267; .reg .pred %r268; .reg .pred %r269; .reg .pred %r270; .reg .pred %r271; .reg .pred %r272; .reg .pred %r273; .reg .pred %r274; .reg .pred %r275; .reg .pred %r276; .reg .pred %r277; .reg .pred %r278; .reg .pred %r279; .reg .pred %r280; .reg .pred %r281; .reg .pred %r282; .reg .pred %r283; .reg .pred %r284; .reg .pred %r285; .reg .pred %r286; .reg .pred %r287; .reg .pred %r288; .reg .pred %r289; .reg .pred %r290; .reg .pred %r291; .reg .pred %r292; .reg .pred %r293; .reg .pred %r294; .reg .pred %r295; .reg .pred %r296; .reg .pred %r297; .reg .pred %r298; .reg .pred %r299; .reg .pred %r300; .reg .pred %r301; .reg .pred %r302; .reg .pred %r303; .reg .pred %r304; .reg .pred %r305; .reg .pred %r306; .reg .pred %r307; .reg .pred %r308; .reg .pred %r309; .reg .pred %r310; .reg .pred %r311; .reg .pred %r312; .reg .pred %r313; .reg .pred %r314; .reg .pred %r315; .reg .pred %r316; .reg .pred %r317; .reg .pred %r318; .reg .pred %r319; .reg .pred %r320; .reg .pred %r321; .reg .pred %r322; .reg .pred %r323; .reg .pred %r324; .reg .pred %r325; .reg .pred %r326; .reg .pred %r327; .reg .pred %r328; .reg .pred %r329; .reg .pred %r330; .reg .pred %r331; .reg .pred %r332; .reg .pred %r333; .reg .pred %r334; .reg .pred %r335; .reg .pred %r336; .reg .pred %r337; .reg .pred %r338; .reg .pred %r339; .reg .pred %r340; .reg .pred %r341; .reg .pred %r342; .reg .pred %r343; .reg .pred %r344; .reg .pred %r345; .reg .pred %r346; .reg .pred %r347; .reg .pred %r348; .reg .pred %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .pred %r353; .reg .pred %r354; .reg .pred %r355; .reg .pred %r356; .reg .pred %r357; .reg .pred %r358; .reg .pred %r359; .reg .pred %r360; .reg .u32 %r361; .reg .pred %r362; .reg .f64 %r363; .reg .u32 %r364; .reg .pred %r365; .reg .u64 %r366; .reg .u32 %r367; .reg .u32 %r369; .reg .pred %r370; .reg .u64 %r371; .reg .u32 %r372; .reg .u32 %r373; .reg .pred %r374; .reg .f64 %r375; .reg .u32 %r376; .reg .pred %r377; .reg .u64 %r378; .reg .u32 %r379; .reg .u32 %r381; .reg .pred %r382; .reg .u64 %r383; .reg .u32 %r384; .reg .u32 %r385; .reg .pred %r386; .reg .f64 %r387; .reg .u32 %r388; .reg .pred %r389; .reg .u64 %r390; .reg .u32 %r391; .reg .u32 %r393; .reg .pred %r394; .reg .u64 %r395; .reg .u32 %r396; .reg .u32 %r397; .reg .pred %r398; .reg .pred %r399; .reg .f64 %r400; .reg .f64 %r401; .reg .pred %r402; .reg .u64 %r403; .reg .u32 %r404; .reg .u32 %r406; .reg .pred %r407; .reg .u64 %r408; .reg .u32 %r409; .reg .u32 %r410; .reg .pred %r411; .reg .pred %r412; .reg .f64 %r413; .reg .f64 %r414; .reg .pred %r415; .reg .u64 %r416; .reg .u32 %r417; .reg .u32 %r419; .reg .pred %r420; .reg .u64 %r421; .reg .u32 %r422; .reg .u32 %r423; .reg .pred %r424; .reg .pred %r425; .reg .f64 %r426; .reg .f64 %r427; .reg .pred %r428; .reg .u64 %r429; .reg .u32 %r430; .reg .u32 %r432; .reg .pred %r433; .reg .u64 %r434; .reg .u32 %r435; .reg .u32 %r436; .reg .pred %r437; .reg .f64 %r438; .reg .u32 %r439; .reg .pred %r440; .reg .u64 %r441; .reg .u32 %r442; .reg .u32 %r444; .reg .pred %r445; .reg .u64 %r446; .reg .u32 %r447; .reg .u32 %r448; .reg .pred %r449; .reg .pred %r450; .reg .f64 %r451; .reg .f64 %r452; .reg .pred %r453; .reg .u64 %r454; .reg .u32 %r455; .reg .u32 %r457; .reg .pred %r458; .reg .u64 %r459; .reg .u32 %r460; .reg .u32 %r461; .reg .pred %r462; .reg .pred %r463; .reg .f64 %r464; .reg .f64 %r465; .reg .pred %r466; .reg .u64 %r467; .reg .u32 %r468; .reg .u32 %r470; .reg .pred %r471; .reg .u64 %r472; .reg .u32 %r473; .reg .u32 %r474; .reg .pred %r475; .reg .pred %r476; .reg .f64 %r477; .reg .f64 %r478; .reg .pred %r479; .reg .u64 %r480; .reg .u32 %r481; .reg .u32 %r483; .reg .pred %r484; .reg .u64 %r485; .reg .u32 %r486; .reg .u32 %r487; .reg .pred %r488; .reg .pred %r489; .reg .f64 %r490; .reg .f64 %r491; .reg .pred %r492; .reg .u64 %r493; .reg .u32 %r494; .reg .u32 %r496; .reg .pred %r497; .reg .u64 %r498; .reg .u32 %r499; .reg .u32 %r500; .reg .pred %r501; .reg .pred %r502; .reg .f64 %r503; .reg .f64 %r504; .reg .pred %r505; .reg .u64 %r506; .reg .u32 %r507; .reg .u32 %r509; .reg .pred %r510; .reg .u64 %r511; .reg .u32 %r512; .reg .u32 %r513; .reg .pred %r514; .reg .pred %r515; .reg .f64 %r516; .reg .f64 %r517; .reg .pred %r518; .reg .u64 %r519; .reg .u32 %r520; .reg .u32 %r522; .reg .pred %r523; .reg .u64 %r524; .reg .u32 %r525; .reg .u32 %r526; .reg .pred %r527; .reg .pred %r528; .reg .f64 %r529; .reg .f64 %r530; .reg .pred %r531; .reg .u64 %r532; .reg .u32 %r533; .reg .u32 %r535; .reg .pred %r536; .reg .u64 %r537; .reg .u32 %r538; .reg .u32 %r539; .reg .pred %r540; .reg .pred %r541; .reg .f64 %r542; .reg .f64 %r543; .reg .pred %r544; .reg .u64 %r545; .reg .u32 %r546; .reg .u32 %r548; .reg .pred %r549; .reg .u64 %r550; .reg .u32 %r551; .reg .u32 %r552; .reg .pred %r553; .reg .pred %r554; .reg .f64 %r555; .reg .f64 %r556; .reg .pred %r557; .reg .u64 %r558; .reg .u32 %r559; .reg .u32 %r561; .reg .pred %r562; .reg .u64 %r563; .reg .u32 %r564; .reg .u32 %r565; .reg .pred %r566; .reg .pred %r567; .reg .f64 %r568; .reg .f64 %r569; .reg .pred %r570; .reg .u64 %r571; .reg .u32 %r572; .reg .u32 %r574; .reg .pred %r575; .reg .u64 %r576; .reg .u32 %r577; .reg .u32 %r578; .reg .pred %r579; .reg .pred %r580; .reg .f64 %r581; .reg .f64 %r582; .reg .pred %r583; .reg .u64 %r584; .reg .u32 %r585; .reg .u32 %r587; .reg .pred %r588; .reg .u64 %r589; .reg .u32 %r590; .reg .u32 %r591; .reg .pred %r592; .reg .pred %r593; .reg .f64 %r594; .reg .f64 %r595; .reg .pred %r596; .reg .u64 %r597; .reg .u32 %r598; .reg .u32 %r600; .reg .pred %r601; .reg .u64 %r602; .reg .u32 %r603; .reg .u32 %r604; .reg .pred %r605; .reg .f64 %r606; .reg .u32 %r607; .reg .pred %r608; .reg .u32 %r610; .reg .pred %r611; .reg .u64 %r612; .reg .u32 %r613; .reg .u32 %r614; .reg .pred %r615; .reg .pred %r616; .reg .f64 %r617; .reg .pred %r618; .reg .f64 %r620; .reg .pred %r621; .reg .f64 %r622; .reg .f64 %r623; .reg .pred %r624; .reg .f64 %r626; .reg .pred %r627; .reg .f64 %r628; .reg .pred %r629; .reg .u64 %r630; .reg .u32 %r631; .reg .u32 %r633; .reg .pred %r634; .reg .u64 %r635; .reg .u32 %r636; .reg .u32 %r637; .reg .pred %r638; .reg .f64 %r639; .reg .u32 %r640; .reg .pred %r641; .reg .u64 %r642; .reg .u32 %r643; .reg .u32 %r645; .reg .pred %r646; .reg .u64 %r647; .reg .u32 %r648; .reg .u32 %r649; .reg .pred %r650; .reg .pred %r651; .reg .f64 %r652; .reg .f64 %r653; .reg .pred %r654; .reg .u64 %r655; .reg .u32 %r656; .reg .u32 %r658; .reg .pred %r659; .reg .u64 %r660; .reg .u32 %r661; .reg .u32 %r662; .reg .pred %r663; .reg .pred %r664; .reg .f64 %r665; .reg .f64 %r666; .reg .f64 %r667; .reg .pred %r668; .reg .u64 %r669; .reg .u32 %r670; .reg .u32 %r672; .reg .pred %r673; .reg .u64 %r674; .reg .u32 %r675; .reg .u32 %r676; .reg .pred %r677; .reg .pred %r678; .reg .pred %r679; .reg .pred %r680; .reg .pred %r681; .reg .u64 %r682; .reg .u32 %r683; .reg .u32 %r685; .reg .pred %r686; .reg .u64 %r687; .reg .u32 %r688; .reg .u32 %r689; .reg .pred %r690; .reg .pred %r691; .reg .f64 %r692; .reg .f64 %r693; .reg .f64 %r694; .reg .pred %r695; .reg .u64 %r696; .reg .u32 %r697; .reg .u32 %r699; .reg .pred %r700; .reg .u64 %r701; .reg .u32 %r702; .reg .u32 %r703; .reg .pred %r704; .reg .pred %r705; .reg .f64 %r706; .reg .f64 %r707; .reg .pred %r708; .reg .u64 %r709; .reg .u32 %r710; .reg .u32 %r712; .reg .pred %r713; .reg .u64 %r714; .reg .u32 %r715; .reg .u32 %r716; .reg .pred %r717; .reg .f64 %r718; .reg .f64 %r719; .reg .u32 %r720; .reg .pred %r721; .reg .u64 %r722; .reg .u32 %r723; .reg .u32 %r725; .reg .pred %r726; .reg .u64 %r727; .reg .u32 %r728; .reg .u32 %r729; .reg .pred %r730; .reg .f64 %r731; .reg .f64 %r732; .reg .u32 %r733; .reg .pred %r734; .reg .u64 %r735; .reg .u32 %r736; .reg .u32 %r738; .reg .pred %r739; .reg .u64 %r740; .reg .u32 %r741; .reg .u32 %r742; .reg .pred %r743; .reg .f64 %r744; .reg .f64 %r745; .reg .u32 %r746; .reg .pred %r747; .reg .u64 %r748; .reg .u32 %r749; .reg .u32 %r751; .reg .pred %r752; .reg .u64 %r753; .reg .u32 %r754; .reg .u32 %r755; .reg .pred %r756; .reg .f64 %r757; .reg .u32 %r758; .reg .pred %r759; .reg .u64 %r760; .reg .u32 %r761; .reg .u32 %r763; .reg .pred %r764; .reg .u64 %r765; .reg .u32 %r766; .reg .u32 %r767; .reg .pred %r768; .reg .pred %r769; .reg .u32 %r770; .reg .pred %r771; .reg .u64 %r772; .reg .u32 %r773; .reg .u32 %r775; .reg .pred %r776; .reg .u64 %r777; .reg .u32 %r778; .reg .u32 %r779; .reg .pred %r780; .reg .f64 %r781; .reg .f64 %r783; .reg .u32 %r784; .reg .pred %r785; .reg .u64 %r786; .reg .u32 %r787; .reg .u32 %r789; .reg .pred %r790; .reg .u64 %r791; .reg .u32 %r792; .reg .u32 %r793; .reg .pred %r794; .reg .f64 %r795; .reg .u32 %r796; .reg .pred %r797; .reg .u64 %r798; .reg .u32 %r799; .reg .u32 %r801; .reg .pred %r802; .reg .u64 %r803; .reg .u32 %r804; .reg .u32 %r805; .reg .pred %r806; .reg .f64 %r807; .reg .u32 %r808; .reg .pred %r809; .reg .u64 %r810; .reg .u32 %r811; .reg .u32 %r813; .reg .pred %r814; .reg .u64 %r815; .reg .u32 %r816; .reg .u32 %r817; .reg .pred %r818; .reg .f64 %r819; .reg .u32 %r820; .reg .pred %r821; .reg .u64 %r822; .reg .u32 %r823; .reg .u32 %r825; .reg .pred %r826; .reg .u64 %r827; .reg .u32 %r828; .reg .u32 %r829; .reg .pred %r830; .reg .f64 %r831; .reg .u32 %r832; .reg .pred %r833; .reg .u64 %r834; .reg .u32 %r835; .reg .u32 %r837; .reg .pred %r838; .reg .u64 %r839; .reg .u32 %r840; .reg .u32 %r841; .reg .pred %r842; .reg .f64 %r843; .reg .u32 %r844; .reg .pred %r845; .reg .u64 %r846; .reg .u32 %r847; .reg .u32 %r849; .reg .pred %r850; .reg .u64 %r851; .reg .u32 %r852; .reg .u32 %r853; .reg .pred %r854; .reg .f64 %r855; .reg .u32 %r856; .reg .pred %r857; .reg .u64 %r858; .reg .u32 %r859; .reg .u32 %r861; .reg .pred %r862; .reg .u64 %r863; .reg .u32 %r864; .reg .u32 %r865; .reg .pred %r866; .reg .pred %r867; .reg .f64 %r868; .reg .f64 %r869; .reg .pred %r870; .reg .u64 %r871; .reg .u32 %r872; .reg .u32 %r874; .reg .pred %r875; .reg .u64 %r876; .reg .u32 %r877; .reg .u32 %r878; .reg .pred %r879; .reg .pred %r880; .reg .f64 %r881; .reg .f64 %r882; .reg .pred %r883; .reg .u64 %r884; .reg .u32 %r885; .reg .u32 %r887; .reg .pred %r888; .reg .u64 %r889; .reg .u32 %r890; .reg .u32 %r891; .reg .pred %r892; .reg .u32 %r894; .reg .u32 %r895; .reg .u32 %r897; .reg .u32 %r898; .reg .u16 %r899; .reg .u16 %r900; .reg .u16 %r901; .reg .u32 %r902; .reg .u16 %r903; .reg .pred %r904; .reg .u32 %r906; .reg .pred %r907; .reg .u64 %r908; .reg .u32 %r909; .reg .pred %r910; .reg .u64 %r911; mov.f64 %r251,%ar0; mov.f64 %r252,%ar1; mov.u32 %r253,%ar2; .loc 1 99 0 st.f64 [%frame+16],%r251; .loc 1 100 0 st.f64 [%frame+24],%r252; .loc 1 101 0 mov.u32 %r254,0; st.u32 [%frame+40],%r254; .loc 1 102 0 setp.eq.u32 %r255,%r253,42; @ %r255 bra $L3; setp.gt.s32 %r256,%r253,42; @ %r256 bra $L4; setp.eq.u32 %r257,%r253,21; @ %r257 bra $L5; setp.gt.s32 %r258,%r253,21; @ %r258 bra $L6; setp.eq.u32 %r259,%r253,10; @ %r259 bra $L7; setp.gt.s32 %r260,%r253,10; @ %r260 bra $L8; setp.eq.u32 %r261,%r253,5; @ %r261 bra $L9; setp.gt.s32 %r262,%r253,5; @ %r262 bra $L10; setp.eq.u32 %r263,%r253,2; @ %r263 bra $L11; setp.gt.s32 %r264,%r253,2; @ %r264 bra $L12; setp.eq.u32 %r265,%r253,1; @ %r265 bra $L13; bra $L505; $L12: setp.eq.u32 %r266,%r253,3; @ %r266 bra $L14; setp.eq.u32 %r267,%r253,4; @ %r267 bra $L15; bra $L505; $L10: setp.eq.u32 %r268,%r253,7; @ %r268 bra $L16; setp.lt.s32 %r269,%r253,7; @ %r269 bra $L17; setp.eq.u32 %r270,%r253,8; @ %r270 bra $L18; setp.eq.u32 %r271,%r253,9; @ %r271 bra $L19; bra $L505; $L8: setp.eq.u32 %r272,%r253,15; @ %r272 bra $L20; setp.gt.s32 %r273,%r253,15; @ %r273 bra $L21; setp.eq.u32 %r274,%r253,12; @ %r274 bra $L22; setp.lt.s32 %r275,%r253,12; @ %r275 bra $L23; setp.eq.u32 %r276,%r253,13; @ %r276 bra $L24; setp.eq.u32 %r277,%r253,14; @ %r277 bra $L25; bra $L505; $L21: setp.eq.u32 %r278,%r253,18; @ %r278 bra $L26; setp.gt.s32 %r279,%r253,18; @ %r279 bra $L27; setp.eq.u32 %r280,%r253,16; @ %r280 bra $L28; setp.eq.u32 %r281,%r253,17; @ %r281 bra $L29; bra $L505; $L27: setp.eq.u32 %r282,%r253,19; @ %r282 bra $L30; setp.eq.u32 %r283,%r253,20; @ %r283 bra $L31; bra $L505; $L6: setp.eq.u32 %r284,%r253,31; @ %r284 bra $L32; setp.gt.s32 %r285,%r253,31; @ %r285 bra $L33; setp.eq.u32 %r286,%r253,26; @ %r286 bra $L34; setp.gt.s32 %r287,%r253,26; @ %r287 bra $L35; setp.eq.u32 %r288,%r253,23; @ %r288 bra $L36; setp.lt.s32 %r289,%r253,23; @ %r289 bra $L37; setp.eq.u32 %r290,%r253,24; @ %r290 bra $L38; setp.eq.u32 %r291,%r253,25; @ %r291 bra $L39; bra $L505; $L35: setp.eq.u32 %r292,%r253,28; @ %r292 bra $L40; setp.lt.s32 %r293,%r253,28; @ %r293 bra $L41; setp.eq.u32 %r294,%r253,29; @ %r294 bra $L42; setp.eq.u32 %r295,%r253,30; @ %r295 bra $L43; bra $L505; $L33: setp.eq.u32 %r296,%r253,36; @ %r296 bra $L44; setp.gt.s32 %r297,%r253,36; @ %r297 bra $L45; setp.eq.u32 %r298,%r253,33; @ %r298 bra $L46; setp.lt.s32 %r299,%r253,33; @ %r299 bra $L47; setp.eq.u32 %r300,%r253,34; @ %r300 bra $L48; setp.eq.u32 %r301,%r253,35; @ %r301 bra $L49; bra $L505; $L45: setp.eq.u32 %r302,%r253,39; @ %r302 bra $L50; setp.gt.s32 %r303,%r253,39; @ %r303 bra $L51; setp.eq.u32 %r304,%r253,37; @ %r304 bra $L52; setp.eq.u32 %r305,%r253,38; @ %r305 bra $L53; bra $L505; $L51: setp.eq.u32 %r306,%r253,40; @ %r306 bra $L54; setp.eq.u32 %r307,%r253,41; @ %r307 bra $L55; bra $L505; $L4: setp.eq.u32 %r308,%r253,121; @ %r308 bra $L5; setp.gt.s32 %r309,%r253,121; @ %r309 bra $L56; setp.eq.u32 %r310,%r253,110; @ %r310 bra $L7; setp.gt.s32 %r311,%r253,110; @ %r311 bra $L57; setp.eq.u32 %r312,%r253,105; @ %r312 bra $L9; setp.gt.s32 %r313,%r253,105; @ %r313 bra $L58; setp.eq.u32 %r314,%r253,102; @ %r314 bra $L11; setp.gt.s32 %r315,%r253,102; @ %r315 bra $L59; setp.eq.u32 %r316,%r253,101; @ %r316 bra $L13; bra $L505; $L59: setp.eq.u32 %r317,%r253,103; @ %r317 bra $L14; setp.eq.u32 %r318,%r253,104; @ %r318 bra $L15; bra $L505; $L58: setp.eq.u32 %r319,%r253,107; @ %r319 bra $L16; setp.lt.s32 %r320,%r253,107; @ %r320 bra $L17; setp.eq.u32 %r321,%r253,108; @ %r321 bra $L18; setp.eq.u32 %r322,%r253,109; @ %r322 bra $L19; bra $L505; $L57: setp.eq.u32 %r323,%r253,115; @ %r323 bra $L20; setp.gt.s32 %r324,%r253,115; @ %r324 bra $L60; setp.eq.u32 %r325,%r253,112; @ %r325 bra $L22; setp.lt.s32 %r326,%r253,112; @ %r326 bra $L23; setp.eq.u32 %r327,%r253,113; @ %r327 bra $L24; setp.eq.u32 %r328,%r253,114; @ %r328 bra $L25; bra $L505; $L60: setp.eq.u32 %r329,%r253,118; @ %r329 bra $L26; setp.gt.s32 %r330,%r253,118; @ %r330 bra $L61; setp.eq.u32 %r331,%r253,116; @ %r331 bra $L28; setp.eq.u32 %r332,%r253,117; @ %r332 bra $L29; bra $L505; $L61: setp.eq.u32 %r333,%r253,119; @ %r333 bra $L30; setp.eq.u32 %r334,%r253,120; @ %r334 bra $L31; bra $L505; $L56: setp.eq.u32 %r335,%r253,132; @ %r335 bra $L47; setp.gt.s32 %r336,%r253,132; @ %r336 bra $L62; setp.eq.u32 %r337,%r253,126; @ %r337 bra $L34; setp.gt.s32 %r338,%r253,126; @ %r338 bra $L63; setp.eq.u32 %r339,%r253,123; @ %r339 bra $L36; setp.lt.s32 %r340,%r253,123; @ %r340 bra $L37; setp.eq.u32 %r341,%r253,124; @ %r341 bra $L38; setp.eq.u32 %r342,%r253,125; @ %r342 bra $L39; bra $L505; $L63: setp.eq.u32 %r343,%r253,129; @ %r343 bra $L42; setp.gt.s32 %r344,%r253,129; @ %r344 bra $L64; setp.eq.u32 %r345,%r253,127; @ %r345 bra $L41; setp.eq.u32 %r346,%r253,128; @ %r346 bra $L40; bra $L505; $L64: setp.eq.u32 %r347,%r253,130; @ %r347 bra $L43; setp.eq.u32 %r348,%r253,131; @ %r348 bra $L32; bra $L505; $L62: setp.eq.u32 %r349,%r253,137; @ %r349 bra $L52; setp.gt.s32 %r350,%r253,137; @ %r350 bra $L65; setp.eq.u32 %r351,%r253,134; @ %r351 bra $L48; setp.lt.s32 %r352,%r253,134; @ %r352 bra $L46; setp.eq.u32 %r353,%r253,135; @ %r353 bra $L49; setp.eq.u32 %r354,%r253,136; @ %r354 bra $L44; bra $L505; $L65: setp.eq.u32 %r355,%r253,140; @ %r355 bra $L54; setp.gt.s32 %r356,%r253,140; @ %r356 bra $L66; setp.eq.u32 %r357,%r253,138; @ %r357 bra $L53; setp.eq.u32 %r358,%r253,139; @ %r358 bra $L50; bra $L505; $L66: setp.eq.u32 %r359,%r253,141; @ %r359 bra $L55; setp.eq.u32 %r360,%r253,142; @ %r360 bra $L3; bra $L505; $L13: .loc 1 106 0 mov.u32 %r361,1; st.u32 [%frame],%r361; .loc 1 107 0 setp.gt.s32 %r362,%r253,99; @ %r362 bra $L230; cvta.const.u64 %r202,$LC0; bra $L67; $L230: cvta.const.u64 %r202,$LC1; $L67: st.u64 [%frame+8],%r202; .loc 1 108 0 mov.f64 %r363,0d0000000000000000; st.f64 [%frame+32],%r363; .loc 1 109 0 ld.global.u32 %r364,[__fdlib_version]; setp.ne.u32 %r365,%r364,2; @ %r365 bra $L68; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r366,[%value_in]; } mov.u32 %r367,33; st.u32 [%r366],%r367; ld.u32 %r249,[%frame+40]; bra $L2; $L68: .loc 1 111 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r369,[%value_in]; } setp.eq.u32 %r370,%r369,0; @ %r370 bra $L69; ld.u32 %r249,[%frame+40]; bra $L2; $L69: .loc 1 115 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r371,[%value_in]; } mov.u32 %r372,33; st.u32 [%r371],%r372; ld.u32 %r249,[%frame+40]; bra $L2; $L11: .loc 1 121 0 mov.u32 %r373,1; st.u32 [%frame],%r373; .loc 1 122 0 setp.gt.s32 %r374,%r253,99; @ %r374 bra $L231; cvta.const.u64 %r203,$LC2; bra $L70; $L231: cvta.const.u64 %r203,$LC3; $L70: st.u64 [%frame+8],%r203; .loc 1 123 0 mov.f64 %r375,0d0000000000000000; st.f64 [%frame+32],%r375; .loc 1 124 0 ld.global.u32 %r376,[__fdlib_version]; setp.ne.u32 %r377,%r376,2; @ %r377 bra $L71; .loc 1 125 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r378,[%value_in]; } mov.u32 %r379,33; st.u32 [%r378],%r379; ld.u32 %r249,[%frame+40]; bra $L2; $L71: .loc 1 126 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r381,[%value_in]; } setp.eq.u32 %r382,%r381,0; @ %r382 bra $L72; ld.u32 %r249,[%frame+40]; bra $L2; $L72: .loc 1 130 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r383,[%value_in]; } mov.u32 %r384,33; st.u32 [%r383],%r384; ld.u32 %r249,[%frame+40]; bra $L2; $L14: .loc 1 136 0 st.f64 [%frame+16],%r252; .loc 1 137 0 st.f64 [%frame+24],%r251; .loc 1 138 0 mov.u32 %r385,1; st.u32 [%frame],%r385; .loc 1 139 0 setp.gt.s32 %r386,%r253,99; @ %r386 bra $L232; cvta.const.u64 %r204,$LC4; bra $L73; $L232: cvta.const.u64 %r204,$LC5; $L73: st.u64 [%frame+8],%r204; .loc 1 140 0 mov.f64 %r387,0d0000000000000000; st.f64 [%frame+32],%r387; .loc 1 141 0 ld.global.u32 %r388,[__fdlib_version]; setp.ne.u32 %r389,%r388,2; @ %r389 bra $L74; .loc 1 142 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r390,[%value_in]; } mov.u32 %r391,33; st.u32 [%r390],%r391; ld.u32 %r249,[%frame+40]; bra $L2; $L74: .loc 1 143 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r393,[%value_in]; } setp.eq.u32 %r394,%r393,0; @ %r394 bra $L75; ld.u32 %r249,[%frame+40]; bra $L2; $L75: .loc 1 147 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r395,[%value_in]; } mov.u32 %r396,33; st.u32 [%r395],%r396; ld.u32 %r249,[%frame+40]; bra $L2; $L15: .loc 1 153 0 mov.u32 %r397,3; st.u32 [%frame],%r397; .loc 1 154 0 setp.gt.s32 %r398,%r253,99; @ %r398 bra $L233; cvta.const.u64 %r205,$LC6; bra $L76; $L233: cvta.const.u64 %r205,$LC7; $L76: st.u64 [%frame+8],%r205; .loc 1 155 0 ld.global.u32 %r34,[__fdlib_version]; setp.ne.u32 %r399,%r34,0; @ %r399 bra $L77; .loc 1 156 0 mov.f64 %r400,0d47efffffe0000000; st.f64 [%frame+32],%r400; bra $L78; $L77: .loc 1 158 0 mov.f64 %r401,0d7ff0000000000000; st.f64 [%frame+32],%r401; .loc 1 159 0 setp.ne.u32 %r402,%r34,2; @ %r402 bra $L78; .loc 1 160 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r403,[%value_in]; } mov.u32 %r404,34; st.u32 [%r403],%r404; ld.u32 %r249,[%frame+40]; bra $L2; $L78: .loc 1 161 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r406,[%value_in]; } setp.eq.u32 %r407,%r406,0; @ %r407 bra $L79; ld.u32 %r249,[%frame+40]; bra $L2; $L79: .loc 1 162 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r408,[%value_in]; } mov.u32 %r409,34; st.u32 [%r408],%r409; ld.u32 %r249,[%frame+40]; bra $L2; $L9: .loc 1 168 0 mov.u32 %r410,3; st.u32 [%frame],%r410; .loc 1 169 0 setp.gt.s32 %r411,%r253,99; @ %r411 bra $L234; cvta.const.u64 %r206,$LC8; bra $L80; $L234: cvta.const.u64 %r206,$LC9; $L80: st.u64 [%frame+8],%r206; .loc 1 170 0 ld.global.u32 %r38,[__fdlib_version]; setp.ne.u32 %r412,%r38,0; @ %r412 bra $L81; .loc 1 171 0 mov.f64 %r413,0d47efffffe0000000; st.f64 [%frame+32],%r413; bra $L82; $L81: .loc 1 173 0 mov.f64 %r414,0d7ff0000000000000; st.f64 [%frame+32],%r414; .loc 1 174 0 setp.ne.u32 %r415,%r38,2; @ %r415 bra $L82; .loc 1 175 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r416,[%value_in]; } mov.u32 %r417,34; st.u32 [%r416],%r417; ld.u32 %r249,[%frame+40]; bra $L2; $L82: .loc 1 176 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r419,[%value_in]; } setp.eq.u32 %r420,%r419,0; @ %r420 bra $L83; ld.u32 %r249,[%frame+40]; bra $L2; $L83: .loc 1 177 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r421,[%value_in]; } mov.u32 %r422,34; st.u32 [%r421],%r422; ld.u32 %r249,[%frame+40]; bra $L2; $L17: .loc 1 183 0 mov.u32 %r423,3; st.u32 [%frame],%r423; .loc 1 184 0 setp.gt.s32 %r424,%r253,99; @ %r424 bra $L235; cvta.const.u64 %r207,$LC10; bra $L84; $L235: cvta.const.u64 %r207,$LC11; $L84: st.u64 [%frame+8],%r207; .loc 1 185 0 ld.global.u32 %r42,[__fdlib_version]; setp.ne.u32 %r425,%r42,0; @ %r425 bra $L85; .loc 1 186 0 mov.f64 %r426,0d47efffffe0000000; st.f64 [%frame+32],%r426; bra $L86; $L85: .loc 1 188 0 mov.f64 %r427,0d7ff0000000000000; st.f64 [%frame+32],%r427; .loc 1 189 0 setp.ne.u32 %r428,%r42,2; @ %r428 bra $L86; .loc 1 190 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r429,[%value_in]; } mov.u32 %r430,34; st.u32 [%r429],%r430; ld.u32 %r249,[%frame+40]; bra $L2; $L86: .loc 1 191 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r432,[%value_in]; } setp.eq.u32 %r433,%r432,0; @ %r433 bra $L87; ld.u32 %r249,[%frame+40]; bra $L2; $L87: .loc 1 192 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r434,[%value_in]; } mov.u32 %r435,34; st.u32 [%r434],%r435; ld.u32 %r249,[%frame+40]; bra $L2; $L16: .loc 1 198 0 mov.u32 %r436,4; st.u32 [%frame],%r436; .loc 1 199 0 setp.gt.s32 %r437,%r253,99; @ %r437 bra $L236; cvta.const.u64 %r208,$LC10; bra $L88; $L236: cvta.const.u64 %r208,$LC11; $L88: st.u64 [%frame+8],%r208; .loc 1 200 0 mov.f64 %r438,0d0000000000000000; st.f64 [%frame+32],%r438; .loc 1 201 0 ld.global.u32 %r439,[__fdlib_version]; setp.ne.u32 %r440,%r439,2; @ %r440 bra $L89; .loc 1 202 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r441,[%value_in]; } mov.u32 %r442,34; st.u32 [%r441],%r442; ld.u32 %r249,[%frame+40]; bra $L2; $L89: .loc 1 203 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r444,[%value_in]; } setp.eq.u32 %r445,%r444,0; @ %r445 bra $L90; ld.u32 %r249,[%frame+40]; bra $L2; $L90: .loc 1 204 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r446,[%value_in]; } mov.u32 %r447,34; st.u32 [%r446],%r447; ld.u32 %r249,[%frame+40]; bra $L2; $L18: .loc 1 210 0 mov.u32 %r448,1; st.u32 [%frame],%r448; .loc 1 211 0 setp.gt.s32 %r449,%r253,99; @ %r449 bra $L237; cvta.const.u64 %r209,$LC12; bra $L91; $L237: cvta.const.u64 %r209,$LC13; $L91: st.u64 [%frame+8],%r209; .loc 1 212 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r450,%r50,0; @ %r450 bra $L92; .loc 1 213 0 mov.f64 %r451,0dc7efffffe0000000; st.f64 [%frame+32],%r451; bra $L93; $L92: .loc 1 215 0 mov.f64 %r452,0dfff0000000000000; st.f64 [%frame+32],%r452; .loc 1 216 0 setp.ne.u32 %r453,%r50,2; @ %r453 bra $L93; .loc 1 217 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r454,[%value_in]; } mov.u32 %r455,33; st.u32 [%r454],%r455; ld.u32 %r249,[%frame+40]; bra $L2; $L93: .loc 1 218 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r457,[%value_in]; } setp.eq.u32 %r458,%r457,0; @ %r458 bra $L94; ld.u32 %r249,[%frame+40]; bra $L2; $L94: .loc 1 222 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r459,[%value_in]; } mov.u32 %r460,33; st.u32 [%r459],%r460; ld.u32 %r249,[%frame+40]; bra $L2; $L19: .loc 1 228 0 mov.u32 %r461,1; st.u32 [%frame],%r461; .loc 1 229 0 setp.gt.s32 %r462,%r253,99; @ %r462 bra $L238; cvta.const.u64 %r210,$LC12; bra $L95; $L238: cvta.const.u64 %r210,$LC13; $L95: st.u64 [%frame+8],%r210; .loc 1 230 0 ld.global.u32 %r54,[__fdlib_version]; setp.ne.u32 %r463,%r54,0; @ %r463 bra $L96; .loc 1 231 0 mov.f64 %r464,0dc7efffffe0000000; st.f64 [%frame+32],%r464; bra $L97; $L96: .loc 1 233 0 mov.f64 %r465,0dfff0000000000000; st.f64 [%frame+32],%r465; .loc 1 234 0 setp.ne.u32 %r466,%r54,2; @ %r466 bra $L97; .loc 1 235 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r467,[%value_in]; } mov.u32 %r468,33; st.u32 [%r467],%r468; ld.u32 %r249,[%frame+40]; bra $L2; $L97: .loc 1 236 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r470,[%value_in]; } setp.eq.u32 %r471,%r470,0; @ %r471 bra $L98; ld.u32 %r249,[%frame+40]; bra $L2; $L98: .loc 1 240 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r472,[%value_in]; } mov.u32 %r473,33; st.u32 [%r472],%r473; ld.u32 %r249,[%frame+40]; bra $L2; $L7: .loc 1 246 0 mov.u32 %r474,1; st.u32 [%frame],%r474; .loc 1 247 0 setp.gt.s32 %r475,%r253,99; @ %r475 bra $L239; cvta.const.u64 %r211,$LC14; bra $L99; $L239: cvta.const.u64 %r211,$LC15; $L99: st.u64 [%frame+8],%r211; .loc 1 248 0 ld.global.u32 %r58,[__fdlib_version]; setp.ne.u32 %r476,%r58,0; @ %r476 bra $L100; .loc 1 249 0 mov.f64 %r477,0dc7efffffe0000000; st.f64 [%frame+32],%r477; bra $L101; $L100: .loc 1 251 0 mov.f64 %r478,0dfff0000000000000; st.f64 [%frame+32],%r478; .loc 1 252 0 setp.ne.u32 %r479,%r58,2; @ %r479 bra $L101; .loc 1 253 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r480,[%value_in]; } mov.u32 %r481,33; st.u32 [%r480],%r481; ld.u32 %r249,[%frame+40]; bra $L2; $L101: .loc 1 254 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r483,[%value_in]; } setp.eq.u32 %r484,%r483,0; @ %r484 bra $L102; ld.u32 %r249,[%frame+40]; bra $L2; $L102: .loc 1 258 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r485,[%value_in]; } mov.u32 %r486,33; st.u32 [%r485],%r486; ld.u32 %r249,[%frame+40]; bra $L2; $L23: .loc 1 264 0 mov.u32 %r487,1; st.u32 [%frame],%r487; .loc 1 265 0 setp.gt.s32 %r488,%r253,99; @ %r488 bra $L240; cvta.const.u64 %r212,$LC14; bra $L103; $L240: cvta.const.u64 %r212,$LC15; $L103: st.u64 [%frame+8],%r212; .loc 1 266 0 ld.global.u32 %r62,[__fdlib_version]; setp.ne.u32 %r489,%r62,0; @ %r489 bra $L104; .loc 1 267 0 mov.f64 %r490,0dc7efffffe0000000; st.f64 [%frame+32],%r490; bra $L105; $L104: .loc 1 269 0 mov.f64 %r491,0dfff0000000000000; st.f64 [%frame+32],%r491; .loc 1 270 0 setp.ne.u32 %r492,%r62,2; @ %r492 bra $L105; .loc 1 271 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r493,[%value_in]; } mov.u32 %r494,33; st.u32 [%r493],%r494; ld.u32 %r249,[%frame+40]; bra $L2; $L105: .loc 1 272 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r496,[%value_in]; } setp.eq.u32 %r497,%r496,0; @ %r497 bra $L106; ld.u32 %r249,[%frame+40]; bra $L2; $L106: .loc 1 276 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r498,[%value_in]; } mov.u32 %r499,33; st.u32 [%r498],%r499; ld.u32 %r249,[%frame+40]; bra $L2; $L22: .loc 1 282 0 mov.u32 %r500,1; st.u32 [%frame],%r500; .loc 1 283 0 setp.gt.s32 %r501,%r253,99; @ %r501 bra $L241; cvta.const.u64 %r213,$LC16; bra $L107; $L241: cvta.const.u64 %r213,$LC17; $L107: st.u64 [%frame+8],%r213; .loc 1 284 0 ld.global.u32 %r66,[__fdlib_version]; setp.ne.u32 %r502,%r66,0; @ %r502 bra $L108; .loc 1 285 0 mov.f64 %r503,0dc7efffffe0000000; st.f64 [%frame+32],%r503; bra $L109; $L108: .loc 1 287 0 mov.f64 %r504,0dfff0000000000000; st.f64 [%frame+32],%r504; .loc 1 288 0 setp.ne.u32 %r505,%r66,2; @ %r505 bra $L109; .loc 1 289 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r506,[%value_in]; } mov.u32 %r507,33; st.u32 [%r506],%r507; ld.u32 %r249,[%frame+40]; bra $L2; $L109: .loc 1 290 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r509,[%value_in]; } setp.eq.u32 %r510,%r509,0; @ %r510 bra $L110; ld.u32 %r249,[%frame+40]; bra $L2; $L110: .loc 1 294 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r511,[%value_in]; } mov.u32 %r512,33; st.u32 [%r511],%r512; ld.u32 %r249,[%frame+40]; bra $L2; $L24: .loc 1 300 0 mov.u32 %r513,1; st.u32 [%frame],%r513; .loc 1 301 0 setp.gt.s32 %r514,%r253,99; @ %r514 bra $L242; cvta.const.u64 %r214,$LC16; bra $L111; $L242: cvta.const.u64 %r214,$LC17; $L111: st.u64 [%frame+8],%r214; .loc 1 302 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r515,%r70,0; @ %r515 bra $L112; .loc 1 303 0 mov.f64 %r516,0dc7efffffe0000000; st.f64 [%frame+32],%r516; bra $L113; $L112: .loc 1 305 0 mov.f64 %r517,0dfff0000000000000; st.f64 [%frame+32],%r517; .loc 1 306 0 setp.ne.u32 %r518,%r70,2; @ %r518 bra $L113; .loc 1 307 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r519,[%value_in]; } mov.u32 %r520,33; st.u32 [%r519],%r520; ld.u32 %r249,[%frame+40]; bra $L2; $L113: .loc 1 308 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r522,[%value_in]; } setp.eq.u32 %r523,%r522,0; @ %r523 bra $L114; ld.u32 %r249,[%frame+40]; bra $L2; $L114: .loc 1 312 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r524,[%value_in]; } mov.u32 %r525,33; st.u32 [%r524],%r525; ld.u32 %r249,[%frame+40]; bra $L2; $L25: .loc 1 318 0 mov.u32 %r526,3; st.u32 [%frame],%r526; .loc 1 319 0 setp.gt.s32 %r527,%r253,99; @ %r527 bra $L243; cvta.const.u64 %r215,$LC18; bra $L115; $L243: cvta.const.u64 %r215,$LC19; $L115: st.u64 [%frame+8],%r215; .loc 1 320 0 ld.global.u32 %r74,[__fdlib_version]; setp.ne.u32 %r528,%r74,0; @ %r528 bra $L116; .loc 1 321 0 mov.f64 %r529,0d47efffffe0000000; st.f64 [%frame+32],%r529; bra $L117; $L116: .loc 1 323 0 mov.f64 %r530,0d7ff0000000000000; st.f64 [%frame+32],%r530; .loc 1 324 0 setp.ne.u32 %r531,%r74,2; @ %r531 bra $L117; .loc 1 325 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r532,[%value_in]; } mov.u32 %r533,34; st.u32 [%r532],%r533; ld.u32 %r249,[%frame+40]; bra $L2; $L117: .loc 1 326 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r535,[%value_in]; } setp.eq.u32 %r536,%r535,0; @ %r536 bra $L118; ld.u32 %r249,[%frame+40]; bra $L2; $L118: .loc 1 327 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r537,[%value_in]; } mov.u32 %r538,34; st.u32 [%r537],%r538; ld.u32 %r249,[%frame+40]; bra $L2; $L20: .loc 1 333 0 mov.u32 %r539,2; st.u32 [%frame],%r539; .loc 1 334 0 setp.gt.s32 %r540,%r253,99; @ %r540 bra $L244; cvta.const.u64 %r216,$LC18; bra $L119; $L244: cvta.const.u64 %r216,$LC19; $L119: st.u64 [%frame+8],%r216; .loc 1 335 0 ld.global.u32 %r78,[__fdlib_version]; setp.ne.u32 %r541,%r78,0; @ %r541 bra $L120; .loc 1 336 0 mov.f64 %r542,0d47efffffe0000000; st.f64 [%frame+32],%r542; bra $L121; $L120: .loc 1 338 0 mov.f64 %r543,0d7ff0000000000000; st.f64 [%frame+32],%r543; .loc 1 339 0 setp.ne.u32 %r544,%r78,2; @ %r544 bra $L121; .loc 1 340 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r545,[%value_in]; } mov.u32 %r546,33; st.u32 [%r545],%r546; ld.u32 %r249,[%frame+40]; bra $L2; $L121: .loc 1 341 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r548,[%value_in]; } setp.eq.u32 %r549,%r548,0; @ %r549 bra $L122; ld.u32 %r249,[%frame+40]; bra $L2; $L122: .loc 1 345 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r550,[%value_in]; } mov.u32 %r551,33; st.u32 [%r550],%r551; ld.u32 %r249,[%frame+40]; bra $L2; $L28: .loc 1 351 0 mov.u32 %r552,2; st.u32 [%frame],%r552; .loc 1 352 0 setp.gt.s32 %r553,%r253,99; @ %r553 bra $L245; cvta.const.u64 %r217,$LC20; bra $L123; $L245: cvta.const.u64 %r217,$LC21; $L123: st.u64 [%frame+8],%r217; .loc 1 353 0 ld.global.u32 %r82,[__fdlib_version]; setp.ne.u32 %r554,%r82,0; @ %r554 bra $L124; .loc 1 354 0 mov.f64 %r555,0dc7efffffe0000000; st.f64 [%frame+32],%r555; bra $L125; $L124: .loc 1 356 0 mov.f64 %r556,0dfff0000000000000; st.f64 [%frame+32],%r556; .loc 1 357 0 setp.ne.u32 %r557,%r82,2; @ %r557 bra $L125; .loc 1 358 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r558,[%value_in]; } mov.u32 %r559,34; st.u32 [%r558],%r559; ld.u32 %r249,[%frame+40]; bra $L2; $L125: .loc 1 359 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r561,[%value_in]; } setp.eq.u32 %r562,%r561,0; @ %r562 bra $L126; ld.u32 %r249,[%frame+40]; bra $L2; $L126: .loc 1 363 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r563,[%value_in]; } mov.u32 %r564,33; st.u32 [%r563],%r564; ld.u32 %r249,[%frame+40]; bra $L2; $L29: .loc 1 369 0 mov.u32 %r565,1; st.u32 [%frame],%r565; .loc 1 370 0 setp.gt.s32 %r566,%r253,99; @ %r566 bra $L246; cvta.const.u64 %r218,$LC20; bra $L127; $L246: cvta.const.u64 %r218,$LC21; $L127: st.u64 [%frame+8],%r218; .loc 1 371 0 ld.global.u32 %r86,[__fdlib_version]; setp.ne.u32 %r567,%r86,0; @ %r567 bra $L128; .loc 1 372 0 mov.f64 %r568,0dc7efffffe0000000; st.f64 [%frame+32],%r568; bra $L129; $L128: .loc 1 374 0 mov.f64 %r569,0dfff0000000000000; st.f64 [%frame+32],%r569; .loc 1 375 0 setp.ne.u32 %r570,%r86,2; @ %r570 bra $L129; .loc 1 376 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r571,[%value_in]; } mov.u32 %r572,33; st.u32 [%r571],%r572; ld.u32 %r249,[%frame+40]; bra $L2; $L129: .loc 1 377 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r574,[%value_in]; } setp.eq.u32 %r575,%r574,0; @ %r575 bra $L130; ld.u32 %r249,[%frame+40]; bra $L2; $L130: .loc 1 381 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r576,[%value_in]; } mov.u32 %r577,33; st.u32 [%r576],%r577; ld.u32 %r249,[%frame+40]; bra $L2; $L26: .loc 1 387 0 mov.u32 %r578,2; st.u32 [%frame],%r578; .loc 1 388 0 setp.gt.s32 %r579,%r253,99; @ %r579 bra $L247; cvta.const.u64 %r219,$LC22; bra $L131; $L247: cvta.const.u64 %r219,$LC23; $L131: st.u64 [%frame+8],%r219; .loc 1 389 0 ld.global.u32 %r90,[__fdlib_version]; setp.ne.u32 %r580,%r90,0; @ %r580 bra $L132; .loc 1 390 0 mov.f64 %r581,0dc7efffffe0000000; st.f64 [%frame+32],%r581; bra $L133; $L132: .loc 1 392 0 mov.f64 %r582,0dfff0000000000000; st.f64 [%frame+32],%r582; .loc 1 393 0 setp.ne.u32 %r583,%r90,2; @ %r583 bra $L133; .loc 1 394 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r584,[%value_in]; } mov.u32 %r585,34; st.u32 [%r584],%r585; ld.u32 %r249,[%frame+40]; bra $L2; $L133: .loc 1 395 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r587,[%value_in]; } setp.eq.u32 %r588,%r587,0; @ %r588 bra $L134; ld.u32 %r249,[%frame+40]; bra $L2; $L134: .loc 1 399 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r589,[%value_in]; } mov.u32 %r590,33; st.u32 [%r589],%r590; ld.u32 %r249,[%frame+40]; bra $L2; $L30: .loc 1 405 0 mov.u32 %r591,1; st.u32 [%frame],%r591; .loc 1 406 0 setp.gt.s32 %r592,%r253,99; @ %r592 bra $L248; cvta.const.u64 %r220,$LC22; bra $L135; $L248: cvta.const.u64 %r220,$LC23; $L135: st.u64 [%frame+8],%r220; .loc 1 407 0 ld.global.u32 %r94,[__fdlib_version]; setp.ne.u32 %r593,%r94,0; @ %r593 bra $L136; .loc 1 408 0 mov.f64 %r594,0dc7efffffe0000000; st.f64 [%frame+32],%r594; bra $L137; $L136: .loc 1 410 0 mov.f64 %r595,0dfff0000000000000; st.f64 [%frame+32],%r595; .loc 1 411 0 setp.ne.u32 %r596,%r94,2; @ %r596 bra $L137; .loc 1 412 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r597,[%value_in]; } mov.u32 %r598,33; st.u32 [%r597],%r598; ld.u32 %r249,[%frame+40]; bra $L2; $L137: .loc 1 413 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r600,[%value_in]; } setp.eq.u32 %r601,%r600,0; @ %r601 bra $L138; ld.u32 %r249,[%frame+40]; bra $L2; $L138: .loc 1 417 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r602,[%value_in]; } mov.u32 %r603,33; st.u32 [%r602],%r603; ld.u32 %r249,[%frame+40]; bra $L2; $L31: .loc 1 424 0 mov.u32 %r604,1; st.u32 [%frame],%r604; .loc 1 425 0 setp.gt.s32 %r605,%r253,99; @ %r605 bra $L249; cvta.const.u64 %r221,$LC24; bra $L139; $L249: cvta.const.u64 %r221,$LC25; $L139: st.u64 [%frame+8],%r221; .loc 1 426 0 mov.f64 %r606,0d0000000000000000; st.f64 [%frame+32],%r606; .loc 1 427 0 ld.global.u32 %r607,[__fdlib_version]; setp.eq.u32 %r608,%r607,0; @ %r608 bra $L140; $L226: .loc 1 102 0 mov.f64 %r250,0d3ff0000000000000; bra $L1; $L140: .loc 1 428 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r610,[%value_in]; } setp.eq.u32 %r611,%r610,0; @ %r611 bra $L142; ld.u32 %r249,[%frame+40]; bra $L2; $L142: .loc 1 430 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r612,[%value_in]; } mov.u32 %r613,33; st.u32 [%r612],%r613; ld.u32 %r249,[%frame+40]; bra $L2; $L5: .loc 1 436 0 mov.u32 %r614,3; st.u32 [%frame],%r614; .loc 1 437 0 setp.gt.s32 %r615,%r253,99; @ %r615 bra $L250; cvta.const.u64 %r222,$LC24; bra $L143; $L250: cvta.const.u64 %r222,$LC25; $L143: st.u64 [%frame+8],%r222; .loc 1 438 0 ld.global.u32 %r101,[__fdlib_version]; mul.f64 %r248,%r252,0d3fe0000000000000; setp.ne.u32 %r616,%r101,0; @ %r616 bra $L144; .loc 1 439 0 mov.f64 %r617,0d47efffffe0000000; st.f64 [%frame+32],%r617; .loc 1 441 0 setp.lt.f64 %r618,%r251,0d0000000000000000; @ ! %r618 bra $L145; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r248; call (%value_in),rint,(%out_arg1); ld.param.f64 %r620,[%value_in]; } setp.neu.f64 %r621,%r620,%r248; @ %r621 bra $L147; ld.global.u32 %r101,[__fdlib_version]; bra $L148; $L147: mov.f64 %r622,0dc7efffffe0000000; st.f64 [%frame+32],%r622; ld.global.u32 %r101,[__fdlib_version]; bra $L148; $L144: .loc 1 443 0 mov.f64 %r623,0d7ff0000000000000; st.f64 [%frame+32],%r623; .loc 1 445 0 setp.lt.f64 %r624,%r251,0d0000000000000000; @ ! %r624 bra $L148; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r248; call (%value_in),rint,(%out_arg1); ld.param.f64 %r626,[%value_in]; } setp.neu.f64 %r627,%r626,%r248; @ %r627 bra $L150; ld.global.u32 %r101,[__fdlib_version]; bra $L148; $L150: mov.f64 %r628,0dfff0000000000000; st.f64 [%frame+32],%r628; ld.global.u32 %r101,[__fdlib_version]; $L148: .loc 1 447 0 setp.ne.u32 %r629,%r101,2; @ %r629 bra $L145; .loc 1 448 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r630,[%value_in]; } mov.u32 %r631,34; st.u32 [%r630],%r631; ld.u32 %r249,[%frame+40]; bra $L2; $L145: .loc 1 449 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r633,[%value_in]; } setp.eq.u32 %r634,%r633,0; @ %r634 bra $L151; ld.u32 %r249,[%frame+40]; bra $L2; $L151: .loc 1 450 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r635,[%value_in]; } mov.u32 %r636,34; st.u32 [%r635],%r636; ld.u32 %r249,[%frame+40]; bra $L2; $L37: .loc 1 456 0 mov.u32 %r637,4; st.u32 [%frame],%r637; .loc 1 457 0 setp.gt.s32 %r638,%r253,99; @ %r638 bra $L251; cvta.const.u64 %r223,$LC24; bra $L152; $L251: cvta.const.u64 %r223,$LC25; $L152: st.u64 [%frame+8],%r223; .loc 1 458 0 mov.f64 %r639,0d0000000000000000; st.f64 [%frame+32],%r639; .loc 1 459 0 ld.global.u32 %r640,[__fdlib_version]; setp.ne.u32 %r641,%r640,2; @ %r641 bra $L153; .loc 1 460 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r642,[%value_in]; } mov.u32 %r643,34; st.u32 [%r642],%r643; ld.u32 %r249,[%frame+40]; bra $L2; $L153: .loc 1 461 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r645,[%value_in]; } setp.eq.u32 %r646,%r645,0; @ %r646 bra $L154; ld.u32 %r249,[%frame+40]; bra $L2; $L154: .loc 1 462 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r647,[%value_in]; } mov.u32 %r648,34; st.u32 [%r647],%r648; ld.u32 %r249,[%frame+40]; bra $L2; $L36: .loc 1 468 0 mov.u32 %r649,1; st.u32 [%frame],%r649; .loc 1 469 0 setp.gt.s32 %r650,%r253,99; @ %r650 bra $L252; cvta.const.u64 %r224,$LC24; bra $L155; $L252: cvta.const.u64 %r224,$LC25; $L155: st.u64 [%frame+8],%r224; .loc 1 470 0 ld.global.u32 %r111,[__fdlib_version]; setp.ne.u32 %r651,%r111,0; @ %r651 bra $L156; .loc 1 471 0 mov.f64 %r652,0d0000000000000000; st.f64 [%frame+32],%r652; bra $L157; $L156: .loc 1 473 0 mov.f64 %r653,0dfff0000000000000; st.f64 [%frame+32],%r653; .loc 1 474 0 setp.ne.u32 %r654,%r111,2; @ %r654 bra $L157; .loc 1 475 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r655,[%value_in]; } mov.u32 %r656,33; st.u32 [%r655],%r656; ld.u32 %r249,[%frame+40]; bra $L2; $L157: .loc 1 476 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r658,[%value_in]; } setp.eq.u32 %r659,%r658,0; @ %r659 bra $L158; ld.u32 %r249,[%frame+40]; bra $L2; $L158: .loc 1 480 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r660,[%value_in]; } mov.u32 %r661,33; st.u32 [%r660],%r661; ld.u32 %r249,[%frame+40]; bra $L2; $L38: .loc 1 486 0 mov.u32 %r662,1; st.u32 [%frame],%r662; .loc 1 487 0 setp.gt.s32 %r663,%r253,99; @ %r663 bra $L253; cvta.const.u64 %r225,$LC24; bra $L159; $L253: cvta.const.u64 %r225,$LC25; $L159: st.u64 [%frame+8],%r225; .loc 1 488 0 ld.global.u32 %r115,[__fdlib_version]; setp.ne.u32 %r664,%r115,0; @ %r664 bra $L160; .loc 1 489 0 mov.f64 %r665,0d0000000000000000; st.f64 [%frame+32],%r665; bra $L161; $L160: .loc 1 491 0 mov.f64 %r667,0d0000000000000000; div.rn.f64 %r666,%r667,0d0000000000000000; st.f64 [%frame+32],%r666; .loc 1 492 0 setp.ne.u32 %r668,%r115,2; @ %r668 bra $L161; .loc 1 493 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r669,[%value_in]; } mov.u32 %r670,33; st.u32 [%r669],%r670; ld.u32 %r249,[%frame+40]; bra $L2; $L161: .loc 1 494 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r672,[%value_in]; } setp.eq.u32 %r673,%r672,0; @ %r673 bra $L162; ld.u32 %r249,[%frame+40]; bra $L2; $L162: .loc 1 498 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r674,[%value_in]; } mov.u32 %r675,33; st.u32 [%r674],%r675; ld.u32 %r249,[%frame+40]; bra $L2; $L39: .loc 1 504 0 mov.u32 %r676,3; st.u32 [%frame],%r676; .loc 1 505 0 setp.gt.s32 %r677,%r253,99; @ %r677 bra $L254; cvta.const.u64 %r226,$LC26; bra $L163; $L254: cvta.const.u64 %r226,$LC27; $L163: st.u64 [%frame+8],%r226; .loc 1 506 0 ld.global.u32 %r120,[__fdlib_version]; setp.ne.u32 %r678,%r120,0; @ %r678 bra $L164; .loc 1 507 0 setp.gt.f64 %r679,%r251,0d0000000000000000; selp.f64 %r227,0d47efffffe0000000,0dc7efffffe0000000,%r679; st.f64 [%frame+32],%r227; bra $L167; $L164: .loc 1 509 0 setp.gt.f64 %r680,%r251,0d0000000000000000; selp.f64 %r228,0d7ff0000000000000,0dfff0000000000000,%r680; st.f64 [%frame+32],%r228; .loc 1 510 0 setp.ne.u32 %r681,%r120,2; @ %r681 bra $L167; .loc 1 511 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r682,[%value_in]; } mov.u32 %r683,34; st.u32 [%r682],%r683; ld.u32 %r249,[%frame+40]; bra $L2; $L167: .loc 1 512 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r685,[%value_in]; } setp.eq.u32 %r686,%r685,0; @ %r686 bra $L170; ld.u32 %r249,[%frame+40]; bra $L2; $L170: .loc 1 513 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r687,[%value_in]; } mov.u32 %r688,34; st.u32 [%r687],%r688; ld.u32 %r249,[%frame+40]; bra $L2; $L34: .loc 1 519 0 mov.u32 %r689,1; st.u32 [%frame],%r689; .loc 1 520 0 setp.gt.s32 %r690,%r253,99; @ %r690 bra $L257; cvta.const.u64 %r229,$LC28; bra $L171; $L257: cvta.const.u64 %r229,$LC29; $L171: st.u64 [%frame+8],%r229; .loc 1 521 0 ld.global.u32 %r124,[__fdlib_version]; setp.ne.u32 %r691,%r124,0; @ %r691 bra $L172; .loc 1 522 0 mov.f64 %r692,0d0000000000000000; st.f64 [%frame+32],%r692; bra $L173; $L172: .loc 1 524 0 mov.f64 %r694,0d0000000000000000; div.rn.f64 %r693,%r694,0d0000000000000000; st.f64 [%frame+32],%r693; .loc 1 525 0 setp.ne.u32 %r695,%r124,2; @ %r695 bra $L173; .loc 1 526 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r696,[%value_in]; } mov.u32 %r697,33; st.u32 [%r696],%r697; ld.u32 %r249,[%frame+40]; bra $L2; $L173: .loc 1 527 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r699,[%value_in]; } setp.eq.u32 %r700,%r699,0; @ %r700 bra $L174; ld.u32 %r249,[%frame+40]; bra $L2; $L174: .loc 1 531 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r701,[%value_in]; } mov.u32 %r702,33; st.u32 [%r701],%r702; ld.u32 %r249,[%frame+40]; bra $L2; $L41: .loc 1 537 0 mov.u32 %r703,1; st.u32 [%frame],%r703; .loc 1 538 0 setp.gt.s32 %r704,%r253,99; @ %r704 bra $L258; cvta.const.u64 %r230,$LC30; bra $L175; $L258: cvta.const.u64 %r230,$LC31; $L175: st.u64 [%frame+8],%r230; .loc 1 539 0 ld.global.u32 %r129,[__fdlib_version]; setp.ne.u32 %r705,%r129,0; @ %r705 bra $L176; .loc 1 540 0 st.f64 [%frame+32],%r251; bra $L177; $L176: .loc 1 542 0 mov.f64 %r707,0d0000000000000000; div.rn.f64 %r706,%r707,0d0000000000000000; st.f64 [%frame+32],%r706; .loc 1 543 0 setp.ne.u32 %r708,%r129,2; @ %r708 bra $L177; .loc 1 544 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r709,[%value_in]; } mov.u32 %r710,33; st.u32 [%r709],%r710; ld.u32 %r249,[%frame+40]; bra $L2; $L177: .loc 1 545 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r712,[%value_in]; } setp.eq.u32 %r713,%r712,0; @ %r713 bra $L178; ld.u32 %r249,[%frame+40]; bra $L2; $L178: .loc 1 549 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r714,[%value_in]; } mov.u32 %r715,33; st.u32 [%r714],%r715; ld.u32 %r249,[%frame+40]; bra $L2; $L40: .loc 1 555 0 mov.u32 %r716,1; st.u32 [%frame],%r716; .loc 1 556 0 setp.gt.s32 %r717,%r253,99; @ %r717 bra $L259; cvta.const.u64 %r231,$LC32; bra $L179; $L259: cvta.const.u64 %r231,$LC33; $L179: st.u64 [%frame+8],%r231; .loc 1 557 0 mov.f64 %r719,0d0000000000000000; div.rn.f64 %r718,%r719,0d0000000000000000; st.f64 [%frame+32],%r718; .loc 1 558 0 ld.global.u32 %r720,[__fdlib_version]; setp.ne.u32 %r721,%r720,2; @ %r721 bra $L180; .loc 1 559 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r722,[%value_in]; } mov.u32 %r723,33; st.u32 [%r722],%r723; ld.u32 %r249,[%frame+40]; bra $L2; $L180: .loc 1 560 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r725,[%value_in]; } setp.eq.u32 %r726,%r725,0; @ %r726 bra $L181; ld.u32 %r249,[%frame+40]; bra $L2; $L181: .loc 1 564 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r727,[%value_in]; } mov.u32 %r728,33; st.u32 [%r727],%r728; ld.u32 %r249,[%frame+40]; bra $L2; $L42: .loc 1 570 0 mov.u32 %r729,1; st.u32 [%frame],%r729; .loc 1 571 0 setp.gt.s32 %r730,%r253,99; @ %r730 bra $L260; cvta.const.u64 %r232,$LC34; bra $L182; $L260: cvta.const.u64 %r232,$LC35; $L182: st.u64 [%frame+8],%r232; .loc 1 572 0 mov.f64 %r732,0d0000000000000000; div.rn.f64 %r731,%r732,0d0000000000000000; st.f64 [%frame+32],%r731; .loc 1 573 0 ld.global.u32 %r733,[__fdlib_version]; setp.ne.u32 %r734,%r733,2; @ %r734 bra $L183; .loc 1 574 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r735,[%value_in]; } mov.u32 %r736,33; st.u32 [%r735],%r736; ld.u32 %r249,[%frame+40]; bra $L2; $L183: .loc 1 575 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r738,[%value_in]; } setp.eq.u32 %r739,%r738,0; @ %r739 bra $L184; ld.u32 %r249,[%frame+40]; bra $L2; $L184: .loc 1 579 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r740,[%value_in]; } mov.u32 %r741,33; st.u32 [%r740],%r741; ld.u32 %r249,[%frame+40]; bra $L2; $L43: .loc 1 585 0 mov.u32 %r742,1; st.u32 [%frame],%r742; .loc 1 586 0 setp.gt.s32 %r743,%r253,99; @ %r743 bra $L261; cvta.const.u64 %r233,$LC36; bra $L185; $L261: cvta.const.u64 %r233,$LC37; $L185: st.u64 [%frame+8],%r233; .loc 1 587 0 mov.f64 %r745,0d0000000000000000; div.rn.f64 %r744,%r745,0d0000000000000000; st.f64 [%frame+32],%r744; .loc 1 588 0 ld.global.u32 %r746,[__fdlib_version]; setp.ne.u32 %r747,%r746,2; @ %r747 bra $L186; .loc 1 589 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r748,[%value_in]; } mov.u32 %r749,33; st.u32 [%r748],%r749; ld.u32 %r249,[%frame+40]; bra $L2; $L186: .loc 1 590 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r751,[%value_in]; } setp.eq.u32 %r752,%r751,0; @ %r752 bra $L187; ld.u32 %r249,[%frame+40]; bra $L2; $L187: .loc 1 594 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r753,[%value_in]; } mov.u32 %r754,33; st.u32 [%r753],%r754; ld.u32 %r249,[%frame+40]; bra $L2; $L32: .loc 1 600 0 mov.u32 %r755,2; st.u32 [%frame],%r755; .loc 1 601 0 setp.gt.s32 %r756,%r253,99; @ %r756 bra $L262; cvta.const.u64 %r234,$LC36; bra $L188; $L262: cvta.const.u64 %r234,$LC37; $L188: st.u64 [%frame+8],%r234; .loc 1 602 0 div.rn.f64 %r757,%r251,0d0000000000000000; st.f64 [%frame+32],%r757; .loc 1 603 0 ld.global.u32 %r758,[__fdlib_version]; setp.ne.u32 %r759,%r758,2; @ %r759 bra $L189; .loc 1 604 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r760,[%value_in]; } mov.u32 %r761,33; st.u32 [%r760],%r761; ld.u32 %r249,[%frame+40]; bra $L2; $L189: .loc 1 605 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r763,[%value_in]; } setp.eq.u32 %r764,%r763,0; @ %r764 bra $L190; ld.u32 %r249,[%frame+40]; bra $L2; $L190: .loc 1 609 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r765,[%value_in]; } mov.u32 %r766,33; st.u32 [%r765],%r766; ld.u32 %r249,[%frame+40]; bra $L2; $L47: .loc 1 615 0 mov.u32 %r767,3; st.u32 [%frame],%r767; .loc 1 616 0 setp.gt.s32 %r768,%r253,99; @ %r768 bra $L263; cvta.const.u64 %r235,$LC38; bra $L191; $L263: cvta.const.u64 %r235,$LC39; $L191: st.u64 [%frame+8],%r235; .loc 1 617 0 setp.gt.f64 %r769,%r251,0d0000000000000000; selp.f64 %r236,0d7ff0000000000000,0dfff0000000000000,%r769; st.f64 [%frame+32],%r236; .loc 1 618 0 ld.global.u32 %r770,[__fdlib_version]; setp.ne.u32 %r771,%r770,2; @ %r771 bra $L194; .loc 1 619 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r772,[%value_in]; } mov.u32 %r773,34; st.u32 [%r772],%r773; ld.u32 %r249,[%frame+40]; bra $L2; $L194: .loc 1 620 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r775,[%value_in]; } setp.eq.u32 %r776,%r775,0; @ %r776 bra $L195; ld.u32 %r249,[%frame+40]; bra $L2; $L195: .loc 1 621 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r777,[%value_in]; } mov.u32 %r778,34; st.u32 [%r777],%r778; ld.u32 %r249,[%frame+40]; bra $L2; $L46: .loc 1 627 0 mov.u32 %r779,4; st.u32 [%frame],%r779; .loc 1 628 0 setp.gt.s32 %r780,%r253,99; @ %r780 bra $L265; cvta.const.u64 %r237,$LC38; bra $L196; $L265: cvta.const.u64 %r237,$LC39; $L196: st.u64 [%frame+8],%r237; .loc 1 629 0 mov.f64 %r781,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r781; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r251; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r783,[%value_in]; } st.f64 [%frame+32],%r783; .loc 1 630 0 ld.global.u32 %r784,[__fdlib_version]; setp.ne.u32 %r785,%r784,2; @ %r785 bra $L197; .loc 1 631 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r786,[%value_in]; } mov.u32 %r787,34; st.u32 [%r786],%r787; ld.u32 %r249,[%frame+40]; bra $L2; $L197: .loc 1 632 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r789,[%value_in]; } setp.eq.u32 %r790,%r789,0; @ %r790 bra $L198; ld.u32 %r249,[%frame+40]; bra $L2; $L198: .loc 1 633 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r791,[%value_in]; } mov.u32 %r792,34; st.u32 [%r791],%r792; ld.u32 %r249,[%frame+40]; bra $L2; $L48: .loc 1 639 0 mov.u32 %r793,5; st.u32 [%frame],%r793; .loc 1 640 0 setp.gt.s32 %r794,%r253,99; @ %r794 bra $L266; cvta.const.u64 %r238,$LC40; bra $L199; $L266: cvta.const.u64 %r238,$LC41; $L199: st.u64 [%frame+8],%r238; .loc 1 641 0 mov.f64 %r795,0d0000000000000000; st.f64 [%frame+32],%r795; .loc 1 642 0 ld.global.u32 %r796,[__fdlib_version]; setp.ne.u32 %r797,%r796,2; @ %r797 bra $L200; .loc 1 643 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r798,[%value_in]; } mov.u32 %r799,34; st.u32 [%r798],%r799; ld.u32 %r249,[%frame+40]; bra $L2; $L200: .loc 1 644 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r801,[%value_in]; } setp.eq.u32 %r802,%r801,0; @ %r802 bra $L201; ld.u32 %r249,[%frame+40]; bra $L2; $L201: .loc 1 649 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r803,[%value_in]; } mov.u32 %r804,34; st.u32 [%r803],%r804; ld.u32 %r249,[%frame+40]; bra $L2; $L49: .loc 1 655 0 mov.u32 %r805,5; st.u32 [%frame],%r805; .loc 1 656 0 setp.gt.s32 %r806,%r253,99; @ %r806 bra $L267; cvta.const.u64 %r239,$LC12; bra $L202; $L267: cvta.const.u64 %r239,$LC13; $L202: st.u64 [%frame+8],%r239; .loc 1 657 0 mov.f64 %r807,0d0000000000000000; st.f64 [%frame+32],%r807; .loc 1 658 0 ld.global.u32 %r808,[__fdlib_version]; setp.ne.u32 %r809,%r808,2; @ %r809 bra $L203; .loc 1 659 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r810,[%value_in]; } mov.u32 %r811,34; st.u32 [%r810],%r811; ld.u32 %r249,[%frame+40]; bra $L2; $L203: .loc 1 660 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r813,[%value_in]; } setp.eq.u32 %r814,%r813,0; @ %r814 bra $L204; ld.u32 %r249,[%frame+40]; bra $L2; $L204: .loc 1 665 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r815,[%value_in]; } mov.u32 %r816,34; st.u32 [%r815],%r816; ld.u32 %r249,[%frame+40]; bra $L2; $L44: .loc 1 671 0 mov.u32 %r817,5; st.u32 [%frame],%r817; .loc 1 672 0 setp.gt.s32 %r818,%r253,99; @ %r818 bra $L268; cvta.const.u64 %r240,$LC42; bra $L205; $L268: cvta.const.u64 %r240,$LC43; $L205: st.u64 [%frame+8],%r240; .loc 1 673 0 mov.f64 %r819,0d0000000000000000; st.f64 [%frame+32],%r819; .loc 1 674 0 ld.global.u32 %r820,[__fdlib_version]; setp.ne.u32 %r821,%r820,2; @ %r821 bra $L206; .loc 1 675 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r822,[%value_in]; } mov.u32 %r823,34; st.u32 [%r822],%r823; ld.u32 %r249,[%frame+40]; bra $L2; $L206: .loc 1 676 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r825,[%value_in]; } setp.eq.u32 %r826,%r825,0; @ %r826 bra $L207; ld.u32 %r249,[%frame+40]; bra $L2; $L207: .loc 1 681 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r827,[%value_in]; } mov.u32 %r828,34; st.u32 [%r827],%r828; ld.u32 %r249,[%frame+40]; bra $L2; $L52: .loc 1 687 0 mov.u32 %r829,5; st.u32 [%frame],%r829; .loc 1 688 0 setp.gt.s32 %r830,%r253,99; @ %r830 bra $L269; cvta.const.u64 %r241,$LC14; bra $L208; $L269: cvta.const.u64 %r241,$LC15; $L208: st.u64 [%frame+8],%r241; .loc 1 689 0 mov.f64 %r831,0d0000000000000000; st.f64 [%frame+32],%r831; .loc 1 690 0 ld.global.u32 %r832,[__fdlib_version]; setp.ne.u32 %r833,%r832,2; @ %r833 bra $L209; .loc 1 691 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r834,[%value_in]; } mov.u32 %r835,34; st.u32 [%r834],%r835; ld.u32 %r249,[%frame+40]; bra $L2; $L209: .loc 1 692 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r837,[%value_in]; } setp.eq.u32 %r838,%r837,0; @ %r838 bra $L210; ld.u32 %r249,[%frame+40]; bra $L2; $L210: .loc 1 697 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r839,[%value_in]; } mov.u32 %r840,34; st.u32 [%r839],%r840; ld.u32 %r249,[%frame+40]; bra $L2; $L53: .loc 1 703 0 mov.u32 %r841,5; st.u32 [%frame],%r841; .loc 1 704 0 setp.gt.s32 %r842,%r253,99; @ %r842 bra $L270; cvta.const.u64 %r242,$LC44; bra $L211; $L270: cvta.const.u64 %r242,$LC45; $L211: st.u64 [%frame+8],%r242; .loc 1 705 0 mov.f64 %r843,0d0000000000000000; st.f64 [%frame+32],%r843; .loc 1 706 0 ld.global.u32 %r844,[__fdlib_version]; setp.ne.u32 %r845,%r844,2; @ %r845 bra $L212; .loc 1 707 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r846,[%value_in]; } mov.u32 %r847,34; st.u32 [%r846],%r847; ld.u32 %r249,[%frame+40]; bra $L2; $L212: .loc 1 708 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r849,[%value_in]; } setp.eq.u32 %r850,%r849,0; @ %r850 bra $L213; ld.u32 %r249,[%frame+40]; bra $L2; $L213: .loc 1 713 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r851,[%value_in]; } mov.u32 %r852,34; st.u32 [%r851],%r852; ld.u32 %r249,[%frame+40]; bra $L2; $L50: .loc 1 719 0 mov.u32 %r853,5; st.u32 [%frame],%r853; .loc 1 720 0 setp.gt.s32 %r854,%r253,99; @ %r854 bra $L271; cvta.const.u64 %r243,$LC16; bra $L214; $L271: cvta.const.u64 %r243,$LC17; $L214: st.u64 [%frame+8],%r243; .loc 1 721 0 mov.f64 %r855,0d0000000000000000; st.f64 [%frame+32],%r855; .loc 1 722 0 ld.global.u32 %r856,[__fdlib_version]; setp.ne.u32 %r857,%r856,2; @ %r857 bra $L215; .loc 1 723 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r858,[%value_in]; } mov.u32 %r859,34; st.u32 [%r858],%r859; ld.u32 %r249,[%frame+40]; bra $L2; $L215: .loc 1 724 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r861,[%value_in]; } setp.eq.u32 %r862,%r861,0; @ %r862 bra $L216; ld.u32 %r249,[%frame+40]; bra $L2; $L216: .loc 1 729 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r863,[%value_in]; } mov.u32 %r864,34; st.u32 [%r863],%r864; ld.u32 %r249,[%frame+40]; bra $L2; $L54: .loc 1 735 0 mov.u32 %r865,3; st.u32 [%frame],%r865; .loc 1 736 0 setp.gt.s32 %r866,%r253,99; @ %r866 bra $L272; cvta.const.u64 %r244,$LC46; bra $L217; $L272: cvta.const.u64 %r244,$LC47; $L217: st.u64 [%frame+8],%r244; .loc 1 737 0 ld.global.u32 %r187,[__fdlib_version]; setp.ne.u32 %r867,%r187,0; @ %r867 bra $L218; .loc 1 738 0 mov.f64 %r868,0d47efffffe0000000; st.f64 [%frame+32],%r868; bra $L219; $L218: .loc 1 740 0 mov.f64 %r869,0d7ff0000000000000; st.f64 [%frame+32],%r869; .loc 1 741 0 setp.ne.u32 %r870,%r187,2; @ %r870 bra $L219; .loc 1 742 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r871,[%value_in]; } mov.u32 %r872,34; st.u32 [%r871],%r872; ld.u32 %r249,[%frame+40]; bra $L2; $L219: .loc 1 743 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r874,[%value_in]; } setp.eq.u32 %r875,%r874,0; @ %r875 bra $L220; ld.u32 %r249,[%frame+40]; bra $L2; $L220: .loc 1 744 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r876,[%value_in]; } mov.u32 %r877,34; st.u32 [%r876],%r877; ld.u32 %r249,[%frame+40]; bra $L2; $L55: .loc 1 750 0 mov.u32 %r878,2; st.u32 [%frame],%r878; .loc 1 751 0 setp.gt.s32 %r879,%r253,99; @ %r879 bra $L273; cvta.const.u64 %r245,$LC46; bra $L221; $L273: cvta.const.u64 %r245,$LC47; $L221: st.u64 [%frame+8],%r245; .loc 1 752 0 ld.global.u32 %r191,[__fdlib_version]; setp.ne.u32 %r880,%r191,0; @ %r880 bra $L222; .loc 1 753 0 mov.f64 %r881,0d47efffffe0000000; st.f64 [%frame+32],%r881; bra $L223; $L222: .loc 1 755 0 mov.f64 %r882,0d7ff0000000000000; st.f64 [%frame+32],%r882; .loc 1 756 0 setp.ne.u32 %r883,%r191,2; @ %r883 bra $L223; .loc 1 757 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r884,[%value_in]; } mov.u32 %r885,33; st.u32 [%r884],%r885; ld.u32 %r249,[%frame+40]; bra $L2; $L223: .loc 1 758 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r887,[%value_in]; } setp.eq.u32 %r888,%r887,0; @ %r888 bra $L224; ld.u32 %r249,[%frame+40]; bra $L2; $L224: .loc 1 762 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r889,[%value_in]; } mov.u32 %r890,33; st.u32 [%r889],%r890; ld.u32 %r249,[%frame+40]; bra $L2; $L3: .loc 1 769 0 mov.u32 %r891,1; st.u32 [%frame],%r891; .loc 1 770 0 setp.gt.s32 %r892,%r253,99; @ %r892 bra $L274; cvta.const.u64 %r246,$LC24; bra $L225; $L274: cvta.const.u64 %r246,$LC25; $L225: st.u64 [%frame+8],%r246; .loc 1 771 0 st.f64 [%frame+32],%r251; .loc 1 772 0 ld.global.u32 %r247,[__fdlib_version]; set.u32.eq.u32 %r894,%r247,-1; neg.s32 %r895,%r894; set.u32.eq.u32 %r897,%r247,2; neg.s32 %r898,%r897; cvt.u16.u32 %r900,%r895; cvt.u16.u32 %r901,%r898; or.b16 %r899,%r900,%r901; cvt.u32.u16 %r902,%r899; cvt.u16.u8 %r903,%r902; setp.ne.u16 %r904,%r903,0; @ %r904 bra $L226; .loc 1 774 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r906,[%value_in]; } setp.eq.u32 %r907,%r906,0; @ %r907 bra $L227; ld.u32 %r249,[%frame+40]; bra $L2; $L227: .loc 1 775 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r908,[%value_in]; } mov.u32 %r909,33; st.u32 [%r908],%r909; ld.u32 %r249,[%frame+40]; $L2: .loc 1 779 0 setp.ne.u32 %r910,%r249,0; @ %r910 bra $L228; $L505: ld.f64 %r250,[%frame+32]; bra $L1; $L228: .loc 1 780 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r911,[%value_in]; } ld.u32 %r201,[%frame+40]; st.u32 [%r911],%r201; ld.f64 %r250,[%frame+32]; $L1: .loc 1 782 0 mov.f64 %value,%r250; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-k_tan.o/ 0 0 0 644 4965 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_tan .visible .func (.param .f64 %value_out) __kernel_tan (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libm/math/k_tan.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __kernel_tan .visible .func (.param .f64 %value_out) __kernel_tan (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .f64 %r39; .reg .u32 %r52; .reg .u32 %r53; .reg .f64 %r54; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r65; .reg .f64 %r66; .reg .f64 %r68; .reg .u64 %r71; .reg .u64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .pred %r79; .reg .u32 %r80; .reg .pred %r81; .reg .u32 %r82; .reg .u32 %r84; .reg .u32 %r85; .reg .u32 %r86; .reg .pred %r87; .reg .f64 %r89; .reg .f64 %r90; .reg .pred %r91; .reg .f64 %r92; .reg .pred %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .f64 %r107; .reg .f64 %r108; .reg .f64 %r110; .reg .f64 %r111; .reg .f64 %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .f64 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .f64 %r121; .reg .pred %r122; .reg .u64 %r123; .reg .f64 %r124; .reg .u64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .pred %r131; mov.f64 %r74,%ar0; mov.f64 %r75,%ar1; mov.u32 %r76,%ar2; .loc 1 85 0 mov.b64 %r77,%r74; shr.u64 %r78,%r77,32; cvt.u32.u64 %r52,%r78; .loc 1 86 0 and.b32 %r53,%r52,2147483647; .loc 1 87 0 setp.gt.s32 %r79,%r53,1043333119; @ %r79 bra $L2; .loc 1 88 0 cvt.rzi.s32.f64 %r80,%r74; setp.ne.u32 %r81,%r80,0; @ ! %r81 bra $L13; setp.le.s32 %r131,%r53,1072010279; bra $L3; $L13: .loc 1 91 0 add.u32 %r82,%r76,1; cvt.u32.u64 %r85,%r77; or.b32 %r84,%r82,%r85; or.b32 %r86,%r84,%r53; setp.ne.u32 %r87,%r86,0; @ %r87 bra $L4; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r89,[%value_in]; } mov.f64 %r90,0d3ff0000000000000; div.rn.f64 %r73,%r90,%r89; bra $L1; $L4: .loc 1 92 0 setp.eq.u32 %r91,%r76,1; @ %r91 bra $L8; mov.f64 %r92,0dbff0000000000000; div.rn.f64 %r73,%r92,%r74; bra $L1; $L2: .loc 1 95 0 setp.le.s32 %r131,%r53,1072010279; @ %r131 bra $L3; .loc 1 96 0 setp.ge.s32 %r94,%r52,0; @ %r94 bra $L6; neg.f64 %r74,%r74; neg.f64 %r75,%r75; $L6: .loc 1 97 0 mov.f64 %r95,0d3fe921fb54442d18; sub.f64 %r54,%r95,%r74; .loc 1 98 0 mov.f64 %r97,0d3c81a62633145c07; sub.f64 %r96,%r97,%r75; .loc 1 99 0 add.f64 %r74,%r96,%r54; mov.f64 %r75,0d0000000000000000; $L3: .loc 1 101 0 mul.f64 %r57,%r74,%r74; .loc 1 102 0 mul.f64 %r58,%r57,%r57; .loc 1 109 0 mul.f64 %r60,%r74,%r57; .loc 1 108 0 fma.rn.f64 %r98,%r58,0d3efb2a7074bf7ad4,0d3f12b80f32f0a7e9; fma.rn.f64 %r99,%r98,%r58,0d3f3026f71a8d1068; fma.rn.f64 %r100,%r99,%r58,0d3f57dbc8fee08315; fma.rn.f64 %r101,%r100,%r58,0d3f8226e3e96e8493; fma.rn.f64 %r102,%r101,%r58,0d3faba1ba1bb341fe; .loc 1 107 0 fma.rn.f64 %r103,%r58,0dbef375cbdb605373,0d3f147e88a03792a6; fma.rn.f64 %r104,%r103,%r58,0d3f4344d8f2f26501; fma.rn.f64 %r105,%r104,%r58,0d3f6d6d22c9560328; fma.rn.f64 %r106,%r105,%r58,0d3f9664f48406d637; fma.rn.f64 %r107,%r106,%r58,0d3fc111111110fe7a; .loc 1 110 0 fma.rn.f64 %r108,%r102,%r57,%r107; fma.rn.f64 %r39,%r108,%r60,%r75; fma.rn.f64 %r61,%r39,%r57,%r75; .loc 1 111 0 fma.rn.f64 %r62,%r60,0d3fd5555555555563,%r61; .loc 1 112 0 add.f64 %r73,%r74,%r62; .loc 1 113 0 @ %r131 bra $L7; .loc 1 114 0 cvt.rn.f64.s32 %r68,%r76; .loc 1 115 0 mul.f64 %r110,%r73,%r73; add.f64 %r111,%r73,%r68; div.rn.f64 %r112,%r110,%r111; sub.f64 %r113,%r112,%r62; sub.f64 %r114,%r74,%r113; fma.rn.f64 %r116,%r114,0dc000000000000000,%r68; shr.s32 %r117,%r52,30; and.b32 %r118,%r117,2; mov.u32 %r120,1; sub.u32 %r119,%r120,%r118; cvt.rn.f64.s32 %r121,%r119; mul.f64 %r73,%r116,%r121; bra $L1; $L7: .loc 1 117 0 setp.eq.u32 %r122,%r76,1; @ %r122 bra $L1; .loc 1 123 0 mov.b64 %r71,%r73; and.b64 %r123,%r71,-4294967296; mov.b64 %r63,%r123; .loc 1 125 0 mov.f64 %r124,0dbff0000000000000; div.rn.f64 %r65,%r124,%r73; .loc 1 126 0 mov.b64 %r72,%r65; and.b64 %r125,%r72,-4294967296; mov.b64 %r66,%r125; .loc 1 124 0 sub.f64 %r126,%r63,%r74; sub.f64 %r127,%r62,%r126; .loc 1 127 0 fma.rn.f64 %r128,%r63,%r66,0d3ff0000000000000; .loc 1 128 0 fma.rn.f64 %r129,%r127,%r66,%r128; fma.rn.f64 %r73,%r129,%r65,%r66; bra $L1; $L8: .loc 1 92 0 mov.f64 %r73,%r74; $L1: .loc 1 130 0 mov.f64 %value,%r73; st.param.f64 [%value_out],%value; ret; } lib_a-kf_cos.o/ 0 0 0 644 2827 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .visible .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/kf_cos.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_cosf .visible .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .f32 %r45; .reg .f32 %r51; .reg .f32 %r53; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .pred %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .pred %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .pred %r74; .reg .u32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r84; .reg .f32 %r85; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; mov.f32 %r57,%ar0; mov.f32 %r58,%ar1; .loc 1 40 0 mov.b32 %r36,%r57; .loc 1 41 0 and.b32 %r37,%r36,2147483647; .loc 1 42 0 setp.gt.s32 %r59,%r37,838860799; @ %r59 bra $L2; .loc 1 43 0 cvt.rzi.s32.f32 %r60,%r57; setp.eq.u32 %r61,%r60,0; @ ! %r61 bra $L10; bra $L8; $L2: .loc 1 45 0 mul.f32 %r45,%r57,%r57; .loc 1 46 0 fma.rn.f32 %r62,%r45,0fad47d74e,0f310f74f6; fma.rn.f32 %r63,%r62,%r45,0fb493f27c; fma.rn.f32 %r64,%r63,%r45,0f37d00d01; fma.rn.f32 %r65,%r64,%r45,0fbab60b61; fma.rn.f32 %r66,%r65,%r45,0f3d2aaaab; mul.f32 %r51,%r66,%r45; .loc 1 47 0 setp.gt.s32 %r67,%r37,1050253721; @ %r67 bra $L5; $L7: .loc 1 48 0 mul.f32 %r68,%r57,%r58; neg.f32 %r69,%r68; fma.rn.f32 %r70,%r45,%r51,%r69; neg.f32 %r71,%r70; fma.rn.f32 %r72,%r45,0f3f000000,%r71; mov.f32 %r73,0f3f800000; sub.f32 %r56,%r73,%r72; bra $L1; $L5: .loc 1 50 0 setp.gt.s32 %r74,%r37,1061683200; @ %r74 bra $L9; .loc 1 53 0 add.u32 %r75,%r37,-16777216; mov.b32 %r35,%r75; mov.f32 %r76,0f3f800000; sub.f32 %r53,%r76,%r35; bra $L6; $L9: mov.f32 %r53,0f3f380000; .loc 1 51 0 mov.f32 %r35,0f3e900000; $L6: .loc 1 55 0 neg.f32 %r77,%r35; fma.rn.f32 %r78,%r45,0f3f000000,%r77; .loc 1 57 0 mul.f32 %r79,%r57,%r58; neg.f32 %r80,%r79; fma.rn.f32 %r81,%r45,%r51,%r80; sub.f32 %r82,%r78,%r81; sub.f32 %r56,%r53,%r82; bra $L1; $L8: .loc 1 43 0 mov.f32 %r56,0f3f800000; bra $L1; $L10: .loc 1 45 0 mul.f32 %r45,%r57,%r57; .loc 1 46 0 fma.rn.f32 %r84,%r45,0fad47d74e,0f310f74f6; fma.rn.f32 %r85,%r45,%r84,0fb493f27c; fma.rn.f32 %r86,%r45,%r85,0f37d00d01; fma.rn.f32 %r87,%r45,%r86,0fbab60b61; fma.rn.f32 %r88,%r45,%r87,0f3d2aaaab; mul.f32 %r51,%r88,%r45; bra $L7; $L1: .loc 1 59 0 mov.f32 %value,%r56; st.param.f32 [%value_out],%value; ret; } /370 0 0 0 644 25271 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_rem_pio2f .visible .func (.param .u32 %value_out) __kernel_rem_pio2f (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); .file 1 "../../../../../../newlib/libm/math/kf_rem_pio2.c" // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: init_jk .const .align 4 .u32 init_jk[3] = {4,7,9 }; // BEGIN VAR DEF: PIo2 .const .align 4 .u32 PIo2[11] = {1070137344,972029952,937033728,866254848,780402688,726663168,667025408,584056832,532938752,465960960,390332416 }; // BEGIN GLOBAL FUNCTION DEF: __kernel_rem_pio2f .visible .func (.param .u32 %value_out) __kernel_rem_pio2f (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,320; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r249; .reg .u32 %r250; .reg .u32 %r251; .reg .u32 %r252; .reg .u32 %r253; .reg .u32 %r255; .reg .u32 %r261; .reg .u32 %r263; .reg .u32 %r265; .reg .f32 %r283; .reg .u32 %r296; .reg .f32 %r302; .reg .f32 %r305; .reg .f32 %r306; .reg .u64 %r318; .reg .u32 %r319; .reg .u64 %r326; .reg .u64 %r327; .reg .u64 %r329; .reg .u32 %r330; .reg .f32 %r331; .reg .u64 %r332; .reg .f32 %r333; .reg .u32 %r337; .reg .u32 %r340; .reg .f32 %r342; .reg .f32 %r343; .reg .u32 %r344; .reg .u32 %r346; .reg .u32 %r348; .reg .u64 %r349; .reg .f32 %r351; .reg .u32 %r353; .reg .f32 %r356; .reg .u64 %r357; .reg .u32 %r358; .reg .f32 %r359; .reg .f32 %r360; .reg .f32 %r361; .reg .f32 %r363; .reg .u32 %r364; .reg .f32 %r365; .reg .f32 %r366; .reg .f32 %r367; .reg .f32 %r368; .reg .f32 %r370; .reg .f32 %r372; .reg .u32 %r374; .reg .u64 %r375; .reg .u32 %r377; .reg .u32 %r379; .reg .u64 %r384; .reg .u64 %r386; .reg .u32 %r388; .reg .u64 %r389; .reg .u64 %r390; .reg .u64 %r396; .reg .u64 %r403; .reg .u64 %r404; .reg .f32 %r407; .reg .u64 %r408; .reg .u64 %r409; .reg .f32 %r410; .reg .f32 %r411; .reg .u64 %r412; .reg .f32 %r415; .reg .u32 %r418; .reg .u64 %r419; .reg .u64 %r420; .reg .u64 %r421; .reg .u32 %r424; .reg .u64 %r425; .reg .u64 %r427; .reg .u32 %r429; .reg .u64 %r430; .reg .u64 %r432; .reg .u64 %r434; .reg .u64 %r442; .reg .u64 %r443; .reg .u64 %r449; .reg .u64 %r450; .reg .u64 %r461; .reg .u64 %r463; .reg .u64 %r464; .reg .u64 %r469; .reg .u32 %r470; .reg .u64 %r474; .reg .u32 %r477; .reg .u32 %r483; .reg .u64 %r484; .reg .u64 %r485; .reg .u64 %r491; .reg .u64 %r493; .reg .u64 %r501; .reg .u64 %r502; .reg .u64 %r514; .reg .u64 %r519; .reg .u64 %r521; .reg .u64 %r523; .reg .u64 %r524; .reg .u64 %r527; .reg .u64 %r537; .reg .u64 %r538; .reg .u64 %r539; .reg .u64 %r541; .reg .u64 %r549; .reg .u64 %r550; .reg .u64 %r551; .reg .u32 %r552; .reg .u32 %r557; .reg .u64 %r558; .reg .u64 %r559; .reg .u32 %r568; .reg .u64 %r571; .reg .u64 %r572; .reg .u32 %r573; .reg .u32 %r574; .reg .u32 %r575; .reg .u64 %r576; .reg .u64 %r577; .reg .u64 %r578; .reg .u64 %r579; .reg .u64 %r580; .reg .u32 %r581; .reg .u32 %r584; .reg .u32 %r585; .reg .u32 %r586; .reg .u32 %r587; .reg .u32 %r588; .reg .u32 %r589; .reg .pred %r590; .reg .u64 %r591; .reg .u64 %r592; .reg .u32 %r593; .reg .pred %r594; .reg .u32 %r595; .reg .pred %r596; .reg .u64 %r599; .reg .u64 %r600; .reg .f32 %r605; .reg .f32 %r606; .reg .pred %r607; .reg .pred %r608; .reg .u32 %r611; .reg .u64 %r612; .reg .u64 %r613; .reg .u64 %r614; .reg .u64 %r615; .reg .u64 %r616; .reg .u64 %r618; .reg .u64 %r619; .reg .u32 %r621; .reg .u64 %r622; .reg .u64 %r624; .reg .u64 %r626; .reg .u64 %r627; .reg .f32 %r628; .reg .u32 %r629; .reg .f32 %r631; .reg .u32 %r632; .reg .f32 %r633; .reg .pred %r634; .reg .f32 %r637; .reg .f32 %r639; .reg .f32 %r640; .reg .f32 %r642; .reg .u64 %r644; .reg .u64 %r645; .reg .u64 %r646; .reg .u64 %r647; .reg .u32 %r648; .reg .u32 %r649; .reg .u32 %r654; .reg .u32 %r655; .reg .u32 %r657; .reg .u64 %r658; .reg .u64 %r659; .reg .u64 %r660; .reg .u32 %r662; .reg .pred %r663; .reg .pred %r664; .reg .pred %r666; .reg .pred %r667; .reg .pred %r669; .reg .pred %r670; .reg .u64 %r671; .reg .u64 %r672; .reg .u64 %r673; .reg .u32 %r675; .reg .u32 %r676; .reg .pred %r677; .reg .u64 %r678; .reg .u64 %r679; .reg .u64 %r680; .reg .u32 %r684; .reg .u32 %r685; .reg .u64 %r686; .reg .u64 %r687; .reg .u64 %r688; .reg .u64 %r691; .reg .u64 %r692; .reg .u32 %r693; .reg .u64 %r694; .reg .u32 %r695; .reg .u32 %r696; .reg .pred %r697; .reg .u64 %r698; .reg .u64 %r699; .reg .u64 %r703; .reg .u64 %r704; .reg .u64 %r705; .reg .u64 %r706; .reg .u32 %r711; .reg .u32 %r712; .reg .u64 %r713; .reg .u64 %r714; .reg .u64 %r715; .reg .u64 %r716; .reg .u32 %r721; .reg .u32 %r722; .reg .pred %r723; .reg .f32 %r724; .reg .pred %r725; .reg .f32 %r728; .reg .pred %r729; .reg .pred %r730; .reg .u64 %r735; .reg .u32 %r736; .reg .u32 %r737; .reg .u64 %r738; .reg .u64 %r739; .reg .u32 %r740; .reg .pred %r741; .reg .pred %r742; .reg .u32 %r748; .reg .pred %r749; .reg .u32 %r750; .reg .pred %r751; .reg .pred %r752; .reg .u64 %r753; .reg .u64 %r754; .reg .u64 %r755; .reg .u64 %r757; .reg .u64 %r758; .reg .u64 %r759; .reg .u32 %r760; .reg .u64 %r763; .reg .u64 %r764; .reg .f32 %r765; .reg .pred %r766; .reg .pred %r767; .reg .u64 %r769; .reg .u64 %r770; .reg .u32 %r772; .reg .pred %r773; .reg .u32 %r775; .reg .u64 %r776; .reg .u64 %r777; .reg .u32 %r778; .reg .pred %r779; .reg .u32 %r782; .reg .f32 %r783; .reg .pred %r784; .reg .f32 %r785; .reg .u32 %r786; .reg .u64 %r788; .reg .u64 %r789; .reg .f32 %r792; .reg .u32 %r793; .reg .u64 %r794; .reg .u64 %r795; .reg .u64 %r796; .reg .u32 %r798; .reg .u64 %r800; .reg .u64 %r801; .reg .u32 %r803; .reg .f32 %r804; .reg .f32 %r806; .reg .pred %r807; .reg .u64 %r808; .reg .f32 %r814; .reg .u32 %r815; .reg .f32 %r816; .reg .pred %r817; .reg .f32 %r818; .reg .pred %r819; .reg .pred %r820; .reg .pred %r821; .reg .pred %r823; .reg .pred %r824; .reg .pred %r825; .reg .pred %r826; .reg .pred %r827; .reg .pred %r828; .reg .f32 %r832; .reg .pred %r833; .reg .pred %r834; .reg .u64 %r835; .reg .u64 %r836; .reg .f32 %r842; .reg .pred %r843; .reg .f32 %r845; .reg .f32 %r846; .reg .pred %r847; .reg .f32 %r849; .reg .pred %r850; .reg .u64 %r853; .reg .u64 %r854; .reg .u64 %r860; .reg .u64 %r862; .reg .u64 %r863; .reg .u64 %r865; .reg .u64 %r866; .reg .u64 %r867; .reg .u64 %r868; .reg .f32 %r869; .reg .f32 %r870; .reg .pred %r871; .reg .pred %r872; .reg .u64 %r874; .reg .u64 %r875; .reg .u32 %r880; .reg .u64 %r881; .reg .u64 %r882; .reg .u64 %r884; .reg .u64 %r885; .reg .u64 %r886; .reg .u64 %r887; .reg .f32 %r888; .reg .f32 %r889; .reg .pred %r890; .reg .u64 %r892; .reg .f32 %r893; .reg .pred %r894; .reg .pred %r895; .reg .f32 %r896; .reg .f32 %r897; .reg .f32 %r898; .reg .u32 %r899; .reg .pred %r900; .reg .f32 %r901; .reg .pred %r902; .reg .pred %r903; .reg .pred %r904; .reg .pred %r905; .reg .f32 %r906; .reg .pred %r907; .reg .u32 %r908; .reg .u64 %r909; .reg .pred %r910; .reg .pred %r911; .reg .u64 %r912; .reg .u32 %r913; .reg .pred %r914; .reg .pred %r915; .reg .pred %r916; .reg .u64 %r918; .reg .u64 %r919; .reg .u64 %r921; .reg .f32 %r922; .reg .u64 %r923; .reg .pred %r924; .reg .pred %r925; .reg .pred %r926; .reg .u64 %r927; .reg .u32 %r928; .reg .u64 %r929; .reg .u64 %r930; .reg .u64 %r931; .reg .u64 %r932; .reg .u64 %r933; .reg .pred %r934; .reg .u64 %r935; .reg .u64 %r936; .reg .u64 %r937; .reg .f32 %r938; mov.u64 %r571,%ar0; mov.u64 %r572,%ar1; mov.u32 %r573,%ar2; mov.u32 %r574,%ar3; mov.u32 %r575,%ar4; mov.u64 %r576,%ar5; .loc 1 66 0 cvta.const.u64 %r577,init_jk; cvt.s64.s32 %r578,%r575; shl.b64 %r579,%r578,2; add.u64 %r580,%r577,%r579; ld.u32 %r337,[%r580]; .loc 1 70 0 add.u32 %r908,%r574,-1; .loc 1 71 0 add.u32 %r581,%r573,-3; shr.s32 %r584,%r581,31; and.b32 %r585,%r584,7; add.u32 %r586,%r585,%r581; shr.s32 %r587,%r586,3; max.s32 %r379,%r587,0; .loc 1 72 0 add.u32 %r588,%r379,1; shl.b32 %r589,%r588,3; sub.u32 %r252,%r573,%r589; .loc 1 75 0 sub.u32 %r374,%r379,%r908; add.u32 %r340,%r337,%r908; .loc 1 76 0 setp.lt.s32 %r590,%r340,0; @ %r590 bra $L2; add.u64 %r558,%frame,160; cvt.s64.s32 %r591,%r374; shl.b64 %r592,%r591,2; add.u64 %r559,%r576,%r592; add.u32 %r593,%r374,%r340; add.u32 %r568,%r593,1; mov.f32 %r938,0f00000000; $L4: setp.lt.s32 %r594,%r374,0; @ %r594 bra $L71; ld.u32 %r595,[%r559]; cvt.rn.f32.s32 %r333,%r595; bra $L3; $L71: mov.f32 %r333,%r938; $L3: st.f32 [%r558],%r333; add.u32 %r374,%r374,1; add.u64 %r558,%r558,4; add.u64 %r559,%r559,4; setp.ne.u32 %r596,%r374,%r568; @ %r596 bra $L4; $L2: .loc 1 79 0 setp.lt.s32 %r916,%r337,0; @ %r916 bra $L5; mov.u64 %r551,%frame; mov.u32 %r552,%r908; add.u32 %r557,%r337,%r574; cvt.u64.u32 %r599,%r908; shl.b64 %r549,%r599,2; setp.ge.s32 %r915,%r908,0; add.u64 %r935,%frame,160; add.u64 %r936,%frame,156; sub.u64 %r937,%r936,%r549; bra $L6; $L8: mov.u64 %r538,%r571; cvt.s64.s32 %r600,%r552; shl.b64 %r541,%r600,2; add.u64 %r539,%r935,%r541; add.u64 %r550,%r937,%r541; .loc 1 80 0 mov.f32 %r372,0f00000000; $L7: ld.f32 %r605,[%r538]; ld.f32 %r606,[%r539]; fma.rn.f32 %r372,%r605,%r606,%r372; add.u64 %r538,%r538,4; add.u64 %r539,%r539,-4; setp.ne.u64 %r607,%r539,%r550; @ %r607 bra $L7; $L9: st.f32 [%r551],%r372; add.u64 %r551,%r551,4; add.u32 %r552,%r552,1; .loc 1 79 0 setp.eq.u32 %r608,%r552,%r557; @ %r608 bra $L5; $L6: .loc 1 80 0 @ %r915 bra $L8; mov.f32 %r372,0f00000000; bra $L9; $L5: add.u64 %r921,%frame,240; add.u32 %r611,%r337,-2; cvt.s64.s32 %r612,%r611; shl.b64 %r613,%r612,2; add.u64 %r485,%r921,%r613; add.u64 %r614,%r571,4; cvt.u64.u32 %r615,%r908; shl.b64 %r616,%r615,2; add.u64 %r461,%r614,%r616; .loc 1 66 0 mov.u32 %r296,%r337; setp.le.s32 %r910,%r252,0; add.u64 %r923,%frame,-4; .loc 1 117 0 setp.eq.u32 %r924,%r252,1; setp.eq.u32 %r925,%r252,2; .loc 1 103 0 setp.ne.u32 %r926,%r252,0; add.u64 %r927,%frame,236; .loc 1 135 0 add.u32 %r928,%r337,-1; cvt.s64.s32 %r929,%r928; shl.b64 %r930,%r929,2; add.u64 %r931,%frame,%r930; add.u64 %r932,%r931,240; add.u64 %r933,%frame,160; setp.lt.s32 %r934,%r908,0; $L10: .loc 1 86 0 cvt.s64.s32 %r909,%r296; shl.b64 %r618,%r909,2; add.u64 %r619,%frame,%r618; ld.f32 %r306,[%r619]; setp.le.s32 %r911,%r296,0; @ %r911 bra $L11; mov.u64 %r523,%r921; add.u32 %r621,%r296,-1; cvt.s64.s32 %r622,%r621; shl.b64 %r527,%r622,2; add.u64 %r524,%frame,%r527; add.u64 %r624,%r923,%r527; cvt.u64.u32 %r626,%r621; shl.b64 %r627,%r626,2; sub.u64 %r537,%r624,%r627; $L12: .loc 1 87 0 mul.f32 %r628,%r306,0f3b800000; cvt.rzi.s32.f32 %r629,%r628; cvt.rn.f32.s32 %r370,%r629; .loc 1 88 0 fma.rn.f32 %r631,%r370,0fc3800000,%r306; cvt.rzi.s32.f32 %r632,%r631; st.u32 [%r523],%r632; .loc 1 89 0 ld.f32 %r633,[%r524]; add.f32 %r306,%r370,%r633; add.u64 %r523,%r523,4; add.u64 %r524,%r524,-4; .loc 1 86 0 setp.ne.u64 %r634,%r524,%r537; @ %r634 bra $L12; $L11: .loc 1 93 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r306; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r252; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r637,[%value_in]; } .loc 1 94 0 mul.f32 %r639,%r637,0f3e000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r639; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r640,[%value_in]; } fma.rn.f32 %r343,%r640,0fc1000000,%r637; .loc 1 95 0 cvt.rzi.s32.f32 %r319,%r343; .loc 1 96 0 cvt.rn.f32.s32 %r642,%r319; sub.f32 %r331,%r343,%r642; .loc 1 98 0 @ %r910 bra $L13; .loc 1 99 0 add.u32 %r249,%r296,-1; cvt.s64.s32 %r644,%r249; shl.b64 %r645,%r644,2; add.u64 %r646,%frame,%r645; add.u64 %r647,%r646,240; ld.u32 %r250,[%r647]; mov.u32 %r648,8; sub.u32 %r251,%r648,%r252; shr.s32 %r344,%r250,%r251; add.u32 %r319,%r319,%r344; .loc 1 100 0 shl.b32 %r649,%r344,%r251; sub.u32 %r255,%r250,%r649; st.u32 [%r647],%r255; .loc 1 101 0 mov.u32 %r655,7; sub.u32 %r654,%r655,%r252; shr.s32 %r330,%r255,%r654; bra $L14; $L13: .loc 1 103 0 @ %r926 bra $L15; add.u32 %r657,%r296,-1; cvt.s64.s32 %r658,%r657; shl.b64 %r659,%r658,2; add.u64 %r660,%frame,%r659; ld.u32 %r662,[%r660+240]; shr.s32 %r330,%r662,8; bra $L14; $L15: .loc 1 104 0 setp.ge.f32 %r663,%r331,0f3f000000; @ %r663 bra $L16; .loc 1 97 0 mov.u32 %r330,0; bra $L17; $L14: .loc 1 106 0 setp.le.s32 %r664,%r330,0; @ %r664 bra $L17; .loc 1 107 0 add.u32 %r319,%r319,1; .loc 1 108 0 @ ! %r911 bra $L68; bra $L72; $L81: .loc 1 104 0 mov.u32 %r330,2; $L68: .loc 1 109 0 ld.u32 %r346,[%frame+240]; .loc 1 111 0 setp.ne.u32 %r666,%r346,0; @ %r666 bra $L73; .loc 1 108 0 setp.eq.u32 %r667,%r296,1; @ %r667 bra $L18; add.u64 %r521,%frame,244; mov.u32 %r388,1; bra $L20; $L21: add.u64 %r521,%r521,4; mov.u32 %r388,%r418; setp.eq.u32 %r669,%r296,%r388; @ %r669 bra $L18; $L20: .loc 1 109 0 ld.u32 %r346,[%r521]; add.u32 %r418,%r388,1; .loc 1 111 0 setp.eq.u32 %r670,%r346,0; @ %r670 bra $L21; bra $L19; $L73: mov.u32 %r418,1; mov.u32 %r388,0; $L19: .loc 1 112 0 cvt.s64.s32 %r671,%r388; shl.b64 %r672,%r671,2; add.u64 %r673,%frame,%r672; mov.u32 %r676,256; sub.u32 %r675,%r676,%r346; st.u32 [%r673+240],%r675; .loc 1 108 0 setp.le.s32 %r677,%r296,%r418; @ %r677 bra $L74; .loc 1 109 0 cvt.s64.s32 %r678,%r418; shl.b64 %r679,%r678,2; add.u64 %r680,%frame,%r679; ld.u32 %r377,[%r680+240]; add.u64 %r502,%r921,%r679; add.u32 %r684,%r296,-1; sub.u32 %r685,%r684,%r418; cvt.u64.u32 %r686,%r685; add.u64 %r687,%r686,%r678; shl.b64 %r688,%r687,2; add.u64 %r514,%r921,%r688; neg.s64 %r691,%r678; shl.b64 %r692,%r691,2; add.u32 %r693,%r418,1; cvt.u64.u32 %r694,%r693; shl.b64 %r519,%r694,2; .loc 1 114 0 mov.u32 %r696,255; $L22: sub.u32 %r695,%r696,%r377; st.u32 [%r502],%r695; .loc 1 108 0 setp.eq.u64 %r697,%r502,%r514; @ %r697 bra $L75; .loc 1 109 0 add.u64 %r698,%r502,%r692; add.u64 %r699,%r698,%r519; ld.u32 %r377,[%r699]; add.u64 %r502,%r502,4; bra $L22; $L72: .loc 1 107 0 mov.u32 %r346,0; bra $L18; $L74: .loc 1 112 0 mov.u32 %r346,1; bra $L18; $L75: mov.u32 %r346,1; $L18: .loc 1 116 0 @ %r910 bra $L23; .loc 1 117 0 @ %r924 bra $L24; @ %r925 bra $L25; bra $L23; $L24: .loc 1 119 0 add.u32 %r261,%r296,-1; cvt.s64.s32 %r703,%r261; shl.b64 %r704,%r703,2; add.u64 %r705,%frame,%r704; add.u64 %r706,%r705,240; ld.u32 %r712,[%r706]; and.b32 %r711,%r712,127; st.u32 [%r706],%r711; bra $L23; $L25: .loc 1 121 0 add.u32 %r265,%r296,-1; cvt.s64.s32 %r713,%r265; shl.b64 %r714,%r713,2; add.u64 %r715,%frame,%r714; add.u64 %r716,%r715,240; ld.u32 %r722,[%r716]; and.b32 %r721,%r722,63; st.u32 [%r716],%r721; $L23: .loc 1 124 0 setp.ne.u32 %r723,%r330,2; @ %r723 bra $L17; .loc 1 125 0 mov.f32 %r724,0f3f800000; sub.f32 %r331,%r724,%r331; .loc 1 126 0 setp.eq.u32 %r725,%r346,0; @ %r725 bra $L17; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r724; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r252; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r728,[%value_in]; } sub.f32 %r331,%r331,%r728; $L17: .loc 1 131 0 setp.neu.f32 %r729,%r331,0f00000000; @ %r729 bra $L26; .loc 1 133 0 add.u32 %r358,%r296,-1; setp.gt.s32 %r730,%r337,%r358; @ %r730 bra $L27; cvt.s64.s32 %r912,%r358; shl.b64 %r493,%r912,2; add.u64 %r491,%r921,%r493; add.u64 %r735,%r927,%r493; not.b32 %r736,%r337; add.u32 %r737,%r736,%r296; cvt.u64.u32 %r738,%r737; shl.b64 %r739,%r738,2; sub.u64 %r501,%r735,%r739; .loc 1 132 0 mov.u32 %r353,0; $L28: .loc 1 133 0 ld.u32 %r740,[%r491]; or.b32 %r353,%r353,%r740; add.u64 %r491,%r491,-4; setp.ne.u64 %r741,%r491,%r501; @ %r741 bra $L28; .loc 1 134 0 setp.ne.u32 %r742,%r353,0; @ %r742 bra $L29; $L27: .loc 1 135 0 ld.u32 %r748,[%r932]; setp.ne.u32 %r749,%r748,0; @ %r749 bra $L76; mov.u64 %r484,%r485; mov.u32 %r263,1; $L31: add.u32 %r263,%r263,1; add.u64 %r484,%r484,-4; ld.u32 %r750,[%r484+4]; setp.eq.u32 %r751,%r750,0; @ %r751 bra $L31; bra $L30; $L76: mov.u32 %r263,1; $L30: .loc 1 137 0 add.u32 %r348,%r296,1; add.u32 %r296,%r296,%r263; setp.gt.s32 %r752,%r348,%r296; @ %r752 bra $L10; cvt.s64.s32 %r464,%r348; cvt.s64.s32 %r753,%r379; add.u64 %r754,%r753,%r464; shl.b64 %r755,%r754,2; add.u64 %r463,%r576,%r755; add.u32 %r470,%r908,%r348; cvt.s64.s32 %r757,%r470; shl.b64 %r758,%r757,2; add.u64 %r469,%r933,%r758; shl.b64 %r759,%r464,2; add.u64 %r474,%frame,%r759; add.u32 %r477,%r470,-1; add.u32 %r483,%r296,%r908; $L35: .loc 1 138 0 ld.u32 %r760,[%r463]; cvt.rn.f32.s32 %r415,%r760; st.f32 [%r469],%r415; .loc 1 139 0 @ %r934 bra $L77; cvt.s64.s32 %r763,%r477; shl.b64 %r764,%r763,2; add.u64 %r450,%r933,%r764; mov.u64 %r449,%r571; mov.f32 %r351,0f00000000; $L34: ld.f32 %r765,[%r449]; fma.rn.f32 %r351,%r765,%r415,%r351; add.u64 %r449,%r449,4; setp.eq.u64 %r766,%r449,%r461; @ %r766 bra $L33; ld.f32 %r415,[%r450]; add.u64 %r450,%r450,-4; bra $L34; $L77: mov.f32 %r351,0f00000000; $L33: .loc 1 140 0 st.f32 [%r474],%r351; add.u64 %r463,%r463,4; add.u64 %r469,%r469,4; add.u64 %r474,%r474,4; add.u32 %r477,%r477,1; .loc 1 137 0 setp.ne.u32 %r767,%r477,%r483; @ %r767 bra $L35; bra $L10; $L29: .loc 1 149 0 add.u32 %r252,%r252,-8; .loc 1 150 0 shl.b64 %r769,%r912,2; add.u64 %r770,%frame,%r769; ld.u32 %r772,[%r770+240]; setp.ne.u32 %r773,%r772,0; @ %r773 bra $L36; add.u32 %r775,%r296,-2; cvt.s64.s32 %r776,%r775; shl.b64 %r777,%r776,2; add.u64 %r443,%r921,%r777; $L37: add.u32 %r358,%r358,-1; add.u32 %r252,%r252,-8; add.u64 %r443,%r443,-4; ld.u32 %r778,[%r443+4]; setp.eq.u32 %r779,%r778,0; @ %r779 bra $L37; bra $L36; $L26: .loc 1 152 0 neg.s32 %r782,%r252; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r331; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r782; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r783,[%value_in]; } .loc 1 153 0 setp.ge.f32 %r784,%r783,0f43800000; @ ! %r784 bra $L115; .loc 1 154 0 mul.f32 %r785,%r783,0f3b800000; cvt.rzi.s32.f32 %r786,%r785; cvt.rn.f32.s32 %r356,%r786; .loc 1 155 0 shl.b64 %r788,%r909,2; add.u64 %r789,%frame,%r788; fma.rn.f32 %r792,%r356,0fc3800000,%r783; cvt.rzi.s32.f32 %r793,%r792; st.u32 [%r789+240],%r793; .loc 1 156 0 add.u32 %r358,%r296,1; add.u32 %r252,%r252,8; .loc 1 157 0 cvt.s64.s32 %r794,%r358; shl.b64 %r795,%r794,2; add.u64 %r796,%frame,%r795; cvt.rzi.s32.f32 %r798,%r356; st.u32 [%r796+240],%r798; bra $L36; $L115: .loc 1 158 0 shl.b64 %r800,%r909,2; add.u64 %r801,%frame,%r800; cvt.rzi.s32.f32 %r803,%r783; st.u32 [%r801+240],%r803; mov.u32 %r358,%r296; $L36: .loc 1 162 0 mov.f32 %r804,0f3f800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r804; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r252; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r806,[%value_in]; } mov.f32 %r368,%r806; .loc 1 163 0 setp.lt.s32 %r807,%r358,0; @ %r807 bra $L40; cvt.s64.s32 %r808,%r358; shl.b64 %r432,%r808,2; add.u64 %r430,%r921,%r432; add.u64 %r427,%frame,%r432; add.u64 %r442,%frame,236; mov.u64 %r434,%r427; $L41: .loc 1 164 0 ld.u32 %r815,[%r430]; cvt.rn.f32.s32 %r814,%r815; mul.f32 %r816,%r814,%r368; st.f32 [%r434],%r816; mul.f32 %r368,%r368,0f3b800000; add.u64 %r430,%r430,-4; add.u64 %r434,%r434,-4; .loc 1 163 0 setp.ne.u64 %r817,%r430,%r442; @ %r817 bra $L41; add.u64 %r919,%frame,80; add.u32 %r429,%r358,1; mov.u64 %r425,%r919; mov.u32 %r424,0; .loc 1 169 0 mov.f32 %r922,0f3fc90000; bra $L42; $L44: ld.f32 %r818,[%r420]; fma.rn.f32 %r367,%r818,%r407,%r367; add.u32 %r253,%r253,1; setp.lt.s32 %r819,%r337,%r253; @ %r819 bra $L43; add.u64 %r420,%r420,4; setp.gt.s32 %r820,%r253,%r424; @ %r820 bra $L43; ld.f32 %r407,[%r421]; add.u64 %r421,%r421,4; bra $L44; $L78: mov.f32 %r367,0f00000000; $L43: .loc 1 170 0 st.f32 [%r425],%r367; add.u32 %r424,%r424,1; add.u64 %r425,%r425,4; add.u64 %r427,%r427,-4; .loc 1 168 0 setp.eq.u32 %r821,%r424,%r429; @ %r821 bra $L45; $L42: .loc 1 169 0 @ %r916 bra $L78; cvta.const.u64 %r421,PIo2+4; mov.u64 %r420,%r427; mov.f32 %r407,%r922; mov.f32 %r367,0f00000000; mov.u32 %r253,0; bra $L44; $L40: .loc 1 174 0 setp.gt.s32 %r823,%r575,2; @ %r823 bra $L47; setp.gt.s32 %r824,%r575,0; @ %r824 bra $L48; setp.eq.u32 %r825,%r575,0; @ %r825 bra $L79; bra $L51; $L47: setp.eq.u32 %r826,%r575,3; @ ! %r826 bra $L51; $L50: .loc 1 190 0 setp.gt.s32 %r827,%r358,0; @ %r827 bra $L52; .loc 1 200 0 mov.f32 %r359,0f00000000; bra $L53; $L48: .loc 1 183 0 setp.ge.s32 %r828,%r358,0; @ %r828 bra $L54; .loc 1 182 0 mov.f32 %r365,0f00000000; bra $L55; $L56: add.u64 %r396,%r919,%r432; add.u64 %r390,%r919,-4; .loc 1 174 0 mov.f32 %r366,0f00000000; $L57: .loc 1 177 0 ld.f32 %r832,[%r396]; add.f32 %r366,%r366,%r832; add.u64 %r396,%r396,-4; setp.ne.u64 %r833,%r390,%r396; @ %r833 bra $L57; bra $L49; $L79: .loc 1 176 0 mov.f32 %r366,0f00000000; $L49: .loc 1 178 0 setp.eq.u32 %r834,%r330,0; @ %r834 bra $L58; neg.f32 %r366,%r366; $L58: st.f32 [%r572],%r366; .loc 1 179 0 bra $L51; $L54: cvt.s64.s32 %r835,%r358; shl.b64 %r384,%r835,2; add.u64 %r836,%frame,80; add.u64 %r386,%r836,%r384; add.u64 %r375,%frame,76; .loc 1 182 0 mov.f32 %r365,0f00000000; $L59: .loc 1 183 0 ld.f32 %r842,[%r386]; add.f32 %r365,%r365,%r842; add.u64 %r386,%r386,-4; setp.ne.u64 %r843,%r375,%r386; @ %r843 bra $L59; $L55: .loc 1 184 0 setp.eq.u32 %r914,%r330,0; @ %r914 bra $L60; neg.f32 %r845,%r365; st.f32 [%r572],%r845; .loc 1 185 0 ld.f32 %r846,[%frame+80]; sub.f32 %r363,%r846,%r365; .loc 1 186 0 setp.le.s32 %r847,%r358,0; @ %r847 bra $L61; $L70: add.u64 %r389,%frame,84; .loc 1 182 0 mov.u32 %r364,1; $L62: .loc 1 186 0 ld.f32 %r849,[%r389]; add.f32 %r363,%r363,%r849; add.u32 %r364,%r364,1; add.u64 %r389,%r389,4; setp.ge.s32 %r850,%r358,%r364; @ %r850 bra $L62; .loc 1 187 0 @ %r914 bra $L63; $L61: neg.f32 %r363,%r363; $L63: st.f32 [%r572+4],%r363; .loc 1 188 0 bra $L51; $L52: cvt.s64.s32 %r912,%r358; shl.b64 %r853,%r912,2; add.u64 %r854,%frame,%r853; ld.f32 %r283,[%r854+80]; add.u32 %r913,%r358,-1; cvt.s64.s32 %r404,%r913; shl.b64 %r403,%r404,2; add.u64 %r919,%frame,80; add.u64 %r408,%r919,%r403; add.u64 %r918,%frame,76; add.u64 %r860,%r918,%r403; cvt.u64.u32 %r862,%r913; shl.b64 %r863,%r862,2; sub.u64 %r419,%r860,%r863; neg.s64 %r865,%r404; shl.b64 %r866,%r865,2; add.u64 %r357,%r403,4; $L64: .loc 1 191 0 ld.f32 %r302,[%r408]; add.f32 %r361,%r302,%r283; .loc 1 192 0 add.u64 %r867,%r866,%r408; add.u64 %r868,%r867,%r357; sub.f32 %r869,%r302,%r361; add.f32 %r870,%r869,%r283; st.f32 [%r868],%r870; .loc 1 193 0 st.f32 [%r408],%r361; add.u64 %r408,%r408,-4; mov.f32 %r283,%r361; .loc 1 190 0 setp.ne.u64 %r871,%r408,%r419; @ %r871 bra $L64; .loc 1 195 0 setp.le.s32 %r872,%r358,1; @ %r872 bra $L80; shl.b64 %r874,%r912,2; add.u64 %r875,%frame,%r874; ld.f32 %r342,[%r875+80]; cvt.s64.s32 %r327,%r913; shl.b64 %r326,%r327,2; add.u64 %r329,%r919,%r326; add.u32 %r880,%r358,-2; cvt.u64.u32 %r881,%r880; shl.b64 %r412,%r881,2; add.u64 %r882,%r918,%r326; sub.u64 %r409,%r882,%r412; neg.s64 %r884,%r327; shl.b64 %r885,%r884,2; add.u64 %r318,%r326,4; $L65: .loc 1 196 0 ld.f32 %r305,[%r329]; add.f32 %r360,%r305,%r342; .loc 1 197 0 add.u64 %r886,%r885,%r329; add.u64 %r887,%r886,%r318; sub.f32 %r888,%r305,%r360; add.f32 %r889,%r888,%r342; st.f32 [%r887],%r889; .loc 1 198 0 st.f32 [%r329],%r360; add.u64 %r329,%r329,-4; mov.f32 %r342,%r360; .loc 1 195 0 setp.ne.u64 %r890,%r329,%r409; @ %r890 bra $L65; add.u64 %r349,%r919,%r318; add.u64 %r892,%r918,%r318; sub.u64 %r332,%r892,%r412; .loc 1 200 0 mov.f32 %r359,0f00000000; $L66: ld.f32 %r893,[%r349]; add.f32 %r359,%r359,%r893; add.u64 %r349,%r349,-4; setp.ne.u64 %r894,%r332,%r349; @ %r894 bra $L66; bra $L53; $L80: mov.f32 %r359,0f00000000; $L53: ld.f32 %r410,[%frame+80]; ld.f32 %r411,[%frame+84]; .loc 1 201 0 setp.ne.u32 %r895,%r330,0; @ %r895 bra $L67; .loc 1 202 0 st.f32 [%r572],%r410; st.f32 [%r572+4],%r411; st.f32 [%r572+8],%r359; bra $L51; $L67: .loc 1 204 0 neg.f32 %r896,%r410; st.f32 [%r572],%r896; neg.f32 %r897,%r411; st.f32 [%r572+4],%r897; neg.f32 %r898,%r359; st.f32 [%r572+8],%r898; $L51: .loc 1 207 0 and.b32 %r899,%r319,7; bra $L116; $L16: .loc 1 107 0 add.u32 %r319,%r319,1; .loc 1 108 0 setp.gt.s32 %r900,%r296,0; @ %r900 bra $L81; .loc 1 125 0 mov.f32 %r901,0f3f800000; sub.f32 %r331,%r901,%r331; mov.u32 %r330,2; bra $L17; $L45: .loc 1 174 0 setp.gt.s32 %r902,%r575,2; @ %r902 bra $L69; setp.gt.s32 %r903,%r575,0; @ %r903 bra $L48; setp.eq.u32 %r904,%r575,0; @ %r904 bra $L56; bra $L51; $L69: setp.eq.u32 %r905,%r575,3; @ %r905 bra $L50; bra $L51; $L60: .loc 1 184 0 st.f32 [%r572],%r365; .loc 1 185 0 ld.f32 %r906,[%frame+80]; sub.f32 %r363,%r906,%r365; .loc 1 186 0 setp.gt.s32 %r907,%r358,0; @ %r907 bra $L70; bra $L63; $L116: .loc 1 208 0 mov.u32 %value,%r899; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-kf_sin.o/ 0 0 0 644 1969 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .visible .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libm/math/kf_sin.c" // BEGIN GLOBAL FUNCTION DEF: __kernel_sinf .visible .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r31; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .pred %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; mov.f32 %r43,%ar0; mov.f32 %r44,%ar1; mov.u32 %r45,%ar2; .loc 1 40 0 mov.b32 %r31,%r43; .loc 1 41 0 and.b32 %r46,%r31,2147483647; .loc 1 42 0 setp.gt.s32 %r47,%r46,838860799; @ %r47 bra $L2; .loc 1 43 0 cvt.rzi.s32.f32 %r48,%r43; setp.eq.u32 %r49,%r48,0; @ %r49 bra $L5; $L2: .loc 1 44 0 mul.f32 %r34,%r43,%r43; .loc 1 45 0 mul.f32 %r35,%r43,%r34; .loc 1 46 0 fma.rn.f32 %r50,%r34,0f2f2ec9d3,0fb2d72f34; fma.rn.f32 %r51,%r50,%r34,0f3638ef1b; fma.rn.f32 %r52,%r51,%r34,0fb9500d01; fma.rn.f32 %r36,%r52,%r34,0f3c088889; .loc 1 47 0 setp.ne.u32 %r53,%r45,0; @ %r53 bra $L4; fma.rn.f32 %r54,%r34,%r36,0fbe2aaaab; fma.rn.f32 %r42,%r54,%r35,%r43; bra $L1; $L4: .loc 1 48 0 mul.f32 %r55,%r35,%r36; neg.f32 %r56,%r55; fma.rn.f32 %r57,%r44,0f3f000000,%r56; neg.f32 %r58,%r44; fma.rn.f32 %r59,%r57,%r34,%r58; fma.rn.f32 %r60,%r35,0f3e2aaaab,%r59; sub.f32 %r42,%r43,%r60; bra $L1; $L5: .loc 1 43 0 mov.f32 %r42,%r43; $L1: .loc 1 49 0 mov.f32 %value,%r42; st.param.f32 [%value_out],%value; ret; } lib_a-kf_tan.o/ 0 0 0 644 4603 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __kernel_tanf .visible .func (.param .f32 %value_out) __kernel_tanf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libm/math/kf_tan.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __kernel_tanf .visible .func (.param .f32 %value_out) __kernel_tanf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .f32 %r36; .reg .u32 %r51; .reg .u32 %r52; .reg .f32 %r55; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r69; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .f32 %r82; .reg .f32 %r83; .reg .pred %r84; .reg .f32 %r85; .reg .pred %r87; .reg .f32 %r88; .reg .f32 %r89; .reg .f32 %r90; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r100; .reg .f32 %r101; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r105; .reg .f32 %r106; .reg .f32 %r107; .reg .f32 %r109; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .f32 %r114; .reg .pred %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .f32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .f32 %r121; .reg .f32 %r122; .reg .f32 %r123; .reg .f32 %r124; .reg .pred %r126; mov.f32 %r72,%ar0; mov.f32 %r73,%ar1; mov.u32 %r74,%ar2; .loc 1 50 0 mov.b32 %r51,%r72; .loc 1 51 0 and.b32 %r52,%r51,2147483647; .loc 1 52 0 setp.gt.s32 %r75,%r52,830472191; @ %r75 bra $L2; .loc 1 53 0 cvt.rzi.s32.f32 %r76,%r72; setp.ne.u32 %r77,%r76,0; @ ! %r77 bra $L13; setp.le.s32 %r126,%r52,1059889471; bra $L3; $L13: .loc 1 54 0 add.u32 %r78,%r74,1; or.b32 %r79,%r78,%r52; setp.ne.u32 %r80,%r79,0; @ %r80 bra $L4; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r72; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r82,[%value_in]; } mov.f32 %r83,0f3f800000; div.rn.f32 %r71,%r83,%r82; bra $L1; $L4: .loc 1 55 0 setp.eq.u32 %r84,%r74,1; @ %r84 bra $L8; mov.f32 %r85,0fbf800000; div.rn.f32 %r71,%r85,%r72; bra $L1; $L2: .loc 1 58 0 setp.le.s32 %r126,%r52,1059889471; @ %r126 bra $L3; .loc 1 59 0 setp.ge.s32 %r87,%r51,0; @ %r87 bra $L6; neg.f32 %r72,%r72; neg.f32 %r73,%r73; $L6: .loc 1 60 0 mov.f32 %r88,0f3f490fda; sub.f32 %r55,%r88,%r72; .loc 1 61 0 mov.f32 %r90,0f33222168; sub.f32 %r89,%r90,%r73; .loc 1 62 0 add.f32 %r72,%r89,%r55; mov.f32 %r73,0f00000000; $L3: .loc 1 64 0 mul.f32 %r58,%r72,%r72; .loc 1 65 0 mul.f32 %r59,%r58,%r58; .loc 1 72 0 mul.f32 %r61,%r72,%r58; .loc 1 71 0 fma.rn.f32 %r91,%r59,0f37d95384,0f3895c07a; fma.rn.f32 %r92,%r91,%r59,0f398137b9; fma.rn.f32 %r93,%r92,%r59,0f3abede48; fma.rn.f32 %r94,%r93,%r59,0f3c11371f; fma.rn.f32 %r95,%r94,%r59,0f3d5d0dd1; .loc 1 70 0 fma.rn.f32 %r96,%r59,0fb79bae5f,0f38a3f445; fma.rn.f32 %r97,%r96,%r59,0f3a1a26c8; fma.rn.f32 %r98,%r97,%r59,0f3b6b6916; fma.rn.f32 %r99,%r98,%r59,0f3cb327a4; fma.rn.f32 %r100,%r99,%r59,0f3e088889; .loc 1 73 0 fma.rn.f32 %r101,%r95,%r58,%r100; fma.rn.f32 %r36,%r101,%r61,%r73; fma.rn.f32 %r62,%r36,%r58,%r73; .loc 1 74 0 fma.rn.f32 %r63,%r61,0f3eaaaaab,%r62; .loc 1 75 0 add.f32 %r71,%r72,%r63; .loc 1 76 0 @ %r126 bra $L7; .loc 1 77 0 cvt.rn.f32.s32 %r69,%r74; .loc 1 78 0 mul.f32 %r103,%r71,%r71; add.f32 %r104,%r71,%r69; div.rn.f32 %r105,%r103,%r104; sub.f32 %r106,%r105,%r63; sub.f32 %r107,%r72,%r106; fma.rn.f32 %r109,%r107,0fc0000000,%r69; shr.s32 %r110,%r51,30; and.b32 %r111,%r110,2; mov.u32 %r113,1; sub.u32 %r112,%r113,%r111; cvt.rn.f32.s32 %r114,%r112; mul.f32 %r71,%r109,%r114; bra $L1; $L7: .loc 1 80 0 setp.eq.u32 %r115,%r74,1; @ %r115 bra $L1; .loc 1 88 0 mov.b32 %r117,%r71; and.b32 %r116,%r117,-4096; mov.b32 %r64,%r116; .loc 1 90 0 mov.f32 %r118,0fbf800000; div.rn.f32 %r66,%r118,%r71; .loc 1 92 0 mov.b32 %r120,%r66; and.b32 %r119,%r120,-4096; mov.b32 %r67,%r119; .loc 1 89 0 sub.f32 %r121,%r64,%r72; sub.f32 %r122,%r63,%r121; .loc 1 93 0 fma.rn.f32 %r123,%r64,%r67,0f3f800000; .loc 1 94 0 fma.rn.f32 %r124,%r122,%r67,%r123; fma.rn.f32 %r71,%r124,%r66,%r67; bra $L1; $L8: .loc 1 55 0 mov.f32 %r71,%r72; $L1: .loc 1 96 0 mov.f32 %value,%r71; st.param.f32 [%value_out],%value; ret; } lib_a-ldexpl.o/ 0 0 0 644 1010 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexpl .visible .func (.param .f64 %value_out) ldexpl (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/ldexpl.c" // BEGIN GLOBAL FUNCTION DECL: ldexp .extern .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: ldexpl .visible .func (.param .f64 %value_out) ldexpl (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u32 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-lgammal.o/0 0 0 644 811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lgammal .visible .func (.param .f64 %value_out) lgammal (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/lgammal.c" // BEGIN GLOBAL FUNCTION DECL: lgamma .extern .func (.param .f64 %value_out) lgamma (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: lgammal .visible .func (.param .f64 %value_out) lgammal (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),lgamma,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-llrintl.o/0 0 0 644 811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llrintl .visible .func (.param .u64 %value_out) llrintl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/llrintl.c" // BEGIN GLOBAL FUNCTION DECL: llrint .extern .func (.param .u64 %value_out) llrint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: llrintl .visible .func (.param .u64 %value_out) llrintl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),llrint,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } /391 0 0 0 644 819 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llroundl .visible .func (.param .u64 %value_out) llroundl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/llroundl.c" // BEGIN GLOBAL FUNCTION DECL: llround .extern .func (.param .u64 %value_out) llround (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: llroundl .visible .func (.param .u64 %value_out) llroundl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),llround,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-log10l.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log10l .visible .func (.param .f64 %value_out) log10l (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/log10l.c" // BEGIN GLOBAL FUNCTION DECL: log10 .extern .func (.param .f64 %value_out) log10 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log10l .visible .func (.param .f64 %value_out) log10l (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),log10,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-log1pl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log1pl .visible .func (.param .f64 %value_out) log1pl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/log1pl.c" // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log1pl .visible .func (.param .f64 %value_out) log1pl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-logl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: logl .visible .func (.param .f64 %value_out) logl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/logl.c" // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: logl .visible .func (.param .f64 %value_out) logl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),log,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-lrintl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lrintl .visible .func (.param .u64 %value_out) lrintl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/lrintl.c" // BEGIN GLOBAL FUNCTION DECL: lrint .extern .func (.param .u64 %value_out) lrint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: lrintl .visible .func (.param .u64 %value_out) lrintl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),lrint,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-lroundl.o/0 0 0 644 811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lroundl .visible .func (.param .u64 %value_out) lroundl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/lroundl.c" // BEGIN GLOBAL FUNCTION DECL: lround .extern .func (.param .u64 %value_out) lround (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: lroundl .visible .func (.param .u64 %value_out) lroundl (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .u64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),lround,(%out_arg1); ld.param.u64 %r25,[%value_in]; } .loc 1 40 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-modfl.o/ 0 0 0 644 1002 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modfl .visible .func (.param .f64 %value_out) modfl (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/modfl.c" // BEGIN GLOBAL FUNCTION DECL: modf .extern .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: modfl .visible .func (.param .f64 %value_out) modfl (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),modf,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-nanl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nanl .visible .func (.param .f64 %value_out) nanl (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/nanl.c" // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nanl .visible .func (.param .f64 %value_out) nanl (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .f64 %r25; mov.u64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; call (%value_in),nan,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /409 0 0 0 644 835 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nearbyintl .visible .func (.param .f64 %value_out) nearbyintl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/nearbyintl.c" // BEGIN GLOBAL FUNCTION DECL: nearbyint .extern .func (.param .f64 %value_out) nearbyint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nearbyintl .visible .func (.param .f64 %value_out) nearbyintl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),nearbyint,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /429 0 0 0 644 1042 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nextafterl .visible .func (.param .f64 %value_out) nextafterl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/nextafterl.c" // BEGIN GLOBAL FUNCTION DECL: nextafter .extern .func (.param .f64 %value_out) nextafter (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: nextafterl .visible .func (.param .f64 %value_out) nextafterl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),nextafter,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-powl.o/ 0 0 0 644 994 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: powl .visible .func (.param .f64 %value_out) powl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/powl.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: powl .visible .func (.param .f64 %value_out) powl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } /449 0 0 0 644 1042 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remainderl .visible .func (.param .f64 %value_out) remainderl (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/remainderl.c" // BEGIN GLOBAL FUNCTION DECL: remainder .extern .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: remainderl .visible .func (.param .f64 %value_out) remainderl (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),remainder,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-remquol.o/0 0 0 644 1225 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remquol .visible .func (.param .f64 %value_out) remquol (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/common/remquol.c" // BEGIN GLOBAL FUNCTION DECL: remquo .extern .func (.param .f64 %value_out) remquo (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: remquol .visible .func (.param .f64 %value_out) remquol (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f64 %r23; .reg .f64 %r24; .reg .u64 %r25; .reg .f64 %r29; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),remquo,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r29,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r29; st.param.f64 [%value_out],%value; ret; } lib_a-rintl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rintl .visible .func (.param .f64 %value_out) rintl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/rintl.c" // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: rintl .visible .func (.param .f64 %value_out) rintl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),rint,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-roundl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: roundl .visible .func (.param .f64 %value_out) roundl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/roundl.c" // BEGIN GLOBAL FUNCTION DECL: round .extern .func (.param .f64 %value_out) round (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: roundl .visible .func (.param .f64 %value_out) roundl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),round,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-s_asinh.o/0 0 0 644 3818 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinh .visible .func (.param .f64 %value_out) asinh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_asinh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1p .extern .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinh .visible .func (.param .f64 %value_out) asinh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r36; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r41; .reg .f64 %r42; .reg .u64 %r43; .reg .u64 %r44; .reg .pred %r45; .reg .pred %r46; .reg .f64 %r47; .reg .pred %r48; .reg .pred %r49; .reg .f64 %r51; .reg .f64 %r53; .reg .pred %r54; .reg .f64 %r56; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r67; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .f64 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .pred %r76; mov.f64 %r42,%ar0; .loc 1 89 0 mov.b64 %r43,%r42; shr.u64 %r44,%r43,32; cvt.u32.u64 %r36,%r44; .loc 1 90 0 and.b32 %r37,%r36,2147483647; .loc 1 91 0 setp.le.s32 %r45,%r37,2146435071; @ %r45 bra $L2; add.f64 %r41,%r42,%r42; bra $L1; $L2: .loc 1 92 0 setp.gt.s32 %r46,%r37,1043333119; @ %r46 bra $L4; .loc 1 93 0 add.f64 %r47,%r42,0d7e37e43c8800759c; setp.gt.f64 %r48,%r47,0d3ff0000000000000; @ %r48 bra $L8; bra $L5; $L4: .loc 1 95 0 setp.le.s32 %r49,%r37,1102053376; @ %r49 bra $L6; .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r51,[%value_in]; } { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r51; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r53,[%value_in]; } add.f64 %r41,%r53,0d3fe62e42fefa39ef; bra $L7; $L6: .loc 1 97 0 setp.le.s32 %r54,%r37,1073741824; @ %r54 bra $L5; .loc 1 98 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r56,[%value_in]; } .loc 1 99 0 fma.rn.f64 %r58,%r42,%r42,0d3ff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r58; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r59,[%value_in]; } add.f64 %r61,%r59,%r56; mov.f64 %r63,0d3ff0000000000000; div.rn.f64 %r62,%r63,%r61; fma.rn.f64 %r64,%r56,0d4000000000000000,%r62; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r64; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r65,[%value_in]; } mov.f64 %r41,%r65; bra $L7; $L5: .loc 1 101 0 mul.f64 %r38,%r42,%r42; .loc 1 102 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r67,[%value_in]; } add.f64 %r69,%r38,0d3ff0000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r69; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r70,[%value_in]; } add.f64 %r72,%r70,0d3ff0000000000000; div.rn.f64 %r73,%r38,%r72; add.f64 %r74,%r73,%r67; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),log1p,(%out_arg1); ld.param.f64 %r75,[%value_in]; } mov.f64 %r41,%r75; $L7: .loc 1 104 0 setp.gt.s32 %r76,%r36,0; @ %r76 bra $L1; neg.f64 %r41,%r41; bra $L1; $L8: .loc 1 93 0 mov.f64 %r41,%r42; $L1: .loc 1 105 0 mov.f64 %value,%r41; st.param.f64 [%value_out],%value; ret; } lib_a-s_atan.o/ 0 0 0 644 5098 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan .visible .func (.param .f64 %value_out) atan (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_atan.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN VAR DEF: atanhi .const .align 8 .u64 atanhi[4] = {4602023952714414927,4605249457297304856,4607027438436873883,4609753056924675352 }; // BEGIN VAR DEF: atanlo .const .align 8 .u64 atanlo[4] = {4357843414468748770,4359948597267291143,4354989122426817469,4364452196894661639 }; // BEGIN GLOBAL FUNCTION DEF: atan .visible .func (.param .f64 %value_out) atan (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r26; .reg .f64 %r27; .reg .f64 %r28; .reg .f64 %r29; .reg .f64 %r30; .reg .f64 %r31; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .f64 %r51; .reg .f64 %r52; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .pred %r65; .reg .pred %r66; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u16 %r75; .reg .u16 %r76; .reg .u16 %r77; .reg .u32 %r78; .reg .u16 %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .f64 %r84; .reg .pred %r85; .reg .f64 %r87; .reg .pred %r88; .reg .pred %r89; .reg .f64 %r90; .reg .pred %r91; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .pred %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r113; .reg .f64 %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .pred %r118; mov.f64 %r62,%ar0; .loc 1 138 0 mov.b64 %r63,%r62; shr.u64 %r64,%r63,32; cvt.u32.u64 %r46,%r64; .loc 1 139 0 and.b32 %r47,%r46,2147483647; .loc 1 140 0 setp.le.s32 %r65,%r47,1141899263; @ %r65 bra $L2; .loc 1 143 0 setp.gt.s32 %r66,%r47,2146435072; @ %r66 bra $L3; .loc 1 144 0 set.u32.eq.u32 %r68,%r47,2146435072; neg.s32 %r69,%r68; cvt.u32.u64 %r72,%r63; set.u32.ne.u32 %r73,%r72,0; neg.s32 %r74,%r73; cvt.u16.u32 %r76,%r69; cvt.u16.u32 %r77,%r74; and.b16 %r75,%r76,%r77; .loc 1 143 0 cvt.u32.u16 %r78,%r75; cvt.u16.u8 %r79,%r78; setp.eq.u16 %r80,%r79,0; @ %r80 bra $L4; $L3: .loc 1 145 0 add.f64 %r61,%r62,%r62; bra $L1; $L4: .loc 1 146 0 setp.le.s32 %r81,%r46,0; selp.f64 %r61,0dbff921fb54442d18,0d3ff921fb54442d18,%r81; bra $L1; $L2: .loc 1 148 0 setp.gt.s32 %r82,%r47,1071382527; @ %r82 bra $L6; .loc 1 149 0 setp.gt.s32 %r83,%r47,1042284543; @ %r83 bra $L13; .loc 1 150 0 add.f64 %r84,%r62,0d7e37e43c8800759c; setp.gt.f64 %r85,%r84,0d3ff0000000000000; @ %r85 bra $L14; .loc 1 152 0 mov.u32 %r45,-1; bra $L7; $L6: .loc 1 154 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r87,[%value_in]; } .loc 1 155 0 setp.gt.s32 %r88,%r47,1072889855; @ %r88 bra $L8; .loc 1 156 0 setp.gt.s32 %r89,%r47,1072037887; @ %r89 bra $L9; .loc 1 157 0 fma.rn.f64 %r26,%r87,0d4000000000000000,0dbff0000000000000; add.f64 %r27,%r87,0d4000000000000000; div.rn.f64 %r62,%r26,%r27; mov.u32 %r45,0; bra $L7; $L9: .loc 1 159 0 mov.f64 %r90,0d3ff0000000000000; sub.f64 %r28,%r87,%r90; add.f64 %r29,%r87,0d3ff0000000000000; div.rn.f64 %r62,%r28,%r29; mov.u32 %r45,1; bra $L7; $L8: .loc 1 162 0 setp.gt.s32 %r91,%r47,1073971199; @ %r91 bra $L10; .loc 1 163 0 mov.f64 %r92,0d3ff8000000000000; sub.f64 %r30,%r87,%r92; fma.rn.f64 %r31,%r87,0d3ff8000000000000,0d3ff0000000000000; div.rn.f64 %r62,%r30,%r31; mov.u32 %r45,2; bra $L7; $L10: .loc 1 165 0 mov.f64 %r93,0dbff0000000000000; div.rn.f64 %r62,%r93,%r87; mov.u32 %r45,3; bra $L7; $L13: .loc 1 152 0 mov.u32 %r45,-1; $L7: .loc 1 169 0 mul.f64 %r51,%r62,%r62; .loc 1 170 0 mul.f64 %r52,%r51,%r51; .loc 1 172 0 fma.rn.f64 %r94,%r52,0d3f90ad3ae322da11,0d3fa97b4b24760deb; fma.rn.f64 %r95,%r94,%r52,0d3fb10d66a0d03d51; fma.rn.f64 %r96,%r95,%r52,0d3fb745cdc54c206e; fma.rn.f64 %r97,%r96,%r52,0d3fc24924920083ff; fma.rn.f64 %r98,%r97,%r52,0d3fd555555555550d; .loc 1 173 0 fma.rn.f64 %r99,%r52,0dbfa2b4442c6a6c2f,0dbfadde2d52defd9a; fma.rn.f64 %r100,%r99,%r52,0dbfb3b0f2af749a6d; fma.rn.f64 %r101,%r100,%r52,0dbfbc71c6fe231671; fma.rn.f64 %r102,%r101,%r52,0dbfc999999998ebc4; mul.f64 %r103,%r102,%r52; fma.rn.f64 %r104,%r98,%r51,%r103; mul.f64 %r60,%r104,%r62; .loc 1 174 0 setp.ne.u32 %r105,%r45,-1; @ %r105 bra $L11; sub.f64 %r61,%r62,%r60; bra $L1; $L11: .loc 1 176 0 cvta.const.u64 %r106,atanhi; cvt.s64.s32 %r107,%r45; shl.b64 %r108,%r107,3; add.u64 %r109,%r106,%r108; cvta.const.u64 %r110,atanlo; add.u64 %r113,%r110,%r108; ld.f64 %r115,[%r113]; sub.f64 %r114,%r60,%r115; sub.f64 %r116,%r114,%r62; ld.f64 %r117,[%r109]; sub.f64 %r61,%r117,%r116; .loc 1 177 0 setp.ge.s32 %r118,%r46,0; @ %r118 bra $L1; neg.f64 %r61,%r61; bra $L1; $L14: .loc 1 150 0 mov.f64 %r61,%r62; $L1: .loc 1 179 0 mov.f64 %value,%r61; st.param.f64 [%value_out],%value; ret; } lib_a-s_cbrt.o/ 0 0 0 644 3624 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cbrt .visible .func (.param .f64 %value_out) cbrt (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_cbrt.c" // BEGIN GLOBAL FUNCTION DEF: cbrt .visible .func (.param .f64 %value_out) cbrt (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r39; .reg .f64 %r42; .reg .f64 %r44; .reg .f64 %r46; .reg .f64 %r48; .reg .f64 %r50; .reg .f64 %r52; .reg .u32 %r53; .reg .u64 %r60; .reg .u64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .pred %r77; .reg .u64 %r79; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .f64 %r97; .reg .f64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .f64 %r101; .reg .f64 %r102; .reg .f64 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u32 %r109; .reg .u32 %r110; .reg .u64 %r111; .reg .u64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .u32 %r118; .reg .u64 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; mov.f64 %r65,%ar0; mov.b64 %r66,%r65; shr.u64 %r67,%r66,32; cvt.u32.u64 %r53,%r67; .loc 1 84 0 and.b32 %r22,%r53,2147483647; .loc 1 85 0 setp.le.u32 %r68,%r22,2146435071; @ %r68 bra $L2; add.f64 %r64,%r65,%r65; bra $L1; $L2: .loc 1 87 0 cvt.u32.u64 %r71,%r66; or.b32 %r70,%r22,%r71; setp.eq.u32 %r72,%r70,0; @ %r72 bra $L6; .loc 1 90 0 cvt.u64.u32 %r73,%r22; shl.b64 %r74,%r73,32; and.b64 %r75,%r66,4294967295; or.b64 %r76,%r75,%r74; mov.b64 %r42,%r76; .loc 1 92 0 setp.gt.u32 %r77,%r22,1048575; @ %r77 bra $L4; .loc 1 94 0 mul.f64 %r44,%r42,0d4350000000000000; mov.b64 %r60,%r44; shr.u64 %r79,%r60,32; cvt.u32.u64 %r81,%r79; div.u32 %r82,%r81,3; add.u32 %r83,%r82,696219795; cvt.u64.u32 %r84,%r83; shl.b64 %r85,%r84,32; and.b64 %r86,%r60,4294967295; or.b64 %r87,%r86,%r85; mov.b64 %r39,%r87; bra $L5; $L4: .loc 1 97 0 div.s32 %r91,%r22,3; add.u32 %r92,%r91,715094163; cvt.u64.u32 %r93,%r92; shl.b64 %r94,%r93,32; mov.b64 %r39,%r94; $L5: .loc 1 101 0 mul.f64 %r97,%r39,%r39; div.rn.f64 %r98,%r97,%r42; .loc 1 102 0 fma.rn.f64 %r46,%r39,%r98,0d3fe15f15f15f15f1; .loc 1 103 0 add.f64 %r99,%r46,0d3ff6a0ea0ea0ea0f; mov.f64 %r101,0dbfe691de2532c834; div.rn.f64 %r100,%r101,%r46; add.f64 %r102,%r99,%r100; mov.f64 %r104,0d3ff9b6db6db6db6e; div.rn.f64 %r103,%r104,%r102; add.f64 %r105,%r103,0d3fd6db6db6db6db7; mul.f64 %r106,%r105,%r39; .loc 1 107 0 mov.b64 %r107,%r106; shr.u64 %r108,%r107,32; cvt.u32.u64 %r110,%r108; add.u32 %r109,%r110,1; cvt.u64.u32 %r111,%r109; shl.b64 %r115,%r111,32; mov.b64 %r48,%r115; .loc 1 111 0 mul.f64 %r116,%r48,%r48; .loc 1 112 0 div.rn.f64 %r50,%r42,%r116; .loc 1 114 0 sub.f64 %r36,%r50,%r48; fma.rn.f64 %r37,%r48,0d4000000000000000,%r50; div.rn.f64 %r117,%r36,%r37; .loc 1 115 0 fma.rn.f64 %r52,%r48,%r117,%r48; .loc 1 119 0 mov.b64 %r63,%r52; .loc 1 83 0 and.b32 %r118,%r53,-2147483648; .loc 1 119 0 shr.u64 %r120,%r63,32; cvt.u32.u64 %r122,%r120; or.b32 %r121,%r118,%r122; cvt.u64.u32 %r123,%r121; shl.b64 %r124,%r123,32; and.b64 %r125,%r63,4294967295; or.b64 %r126,%r125,%r124; mov.b64 %r64,%r126; .loc 1 120 0 bra $L1; $L6: .loc 1 88 0 mov.f64 %r64,%r65; $L1: .loc 1 121 0 mov.f64 %value,%r64; st.param.f64 [%value_out],%value; ret; } lib_a-s_ceil.o/ 0 0 0 644 3659 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ceil .visible .func (.param .f64 %value_out) ceil (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_ceil.c" // BEGIN GLOBAL FUNCTION DEF: ceil .visible .func (.param .f64 %value_out) ceil (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .f64 %r49; .reg .f64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .u32 %r54; .reg .pred %r55; .reg .pred %r56; .reg .f64 %r57; .reg .pred %r58; .reg .pred %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .f64 %r66; .reg .pred %r67; .reg .pred %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .f64 %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .u32 %r87; .reg .u64 %r88; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; mov.f64 %r50,%ar0; mov.b64 %r51,%r50; shr.u64 %r52,%r51,32; cvt.u32.u64 %r45,%r52; .loc 1 42 0 cvt.u32.u64 %r40,%r52; cvt.u32.u64 %r46,%r51; .loc 1 43 0 shr.s32 %r54,%r45,20; and.b32 %r23,%r54,2047; add.u32 %r42,%r23,-1023; .loc 1 44 0 setp.gt.s32 %r55,%r42,19; @ %r55 bra $L2; .loc 1 45 0 setp.ge.s32 %r56,%r42,0; @ %r56 bra $L3; .loc 1 46 0 add.f64 %r57,%r50,0d7e37e43c8800759c; setp.gt.f64 %r58,%r57,0d0000000000000000; @ ! %r58 bra $L4; .loc 1 47 0 setp.lt.s32 %r59,%r45,0; @ %r59 bra $L13; .loc 1 48 0 or.b32 %r60,%r45,%r46; setp.eq.u32 %r61,%r60,0; @ %r61 bra $L14; mov.u32 %r46,0; mov.u32 %r45,1072693248; bra $L4; $L3: .loc 1 51 0 mov.u32 %r62,1048575; shr.s32 %r47,%r62,%r42; .loc 1 52 0 and.b32 %r63,%r40,%r47; or.b32 %r64,%r63,%r46; setp.eq.u32 %r65,%r64,0; @ %r65 bra $L15; .loc 1 53 0 add.f64 %r66,%r50,0d7e37e43c8800759c; setp.gt.f64 %r67,%r66,0d0000000000000000; @ ! %r67 bra $L4; .loc 1 54 0 setp.le.s32 %r68,%r40,0; @ %r68 bra $L8; mov.u32 %r70,1048576; shr.s32 %r69,%r70,%r42; add.u32 %r40,%r40,%r69; $L8: .loc 1 55 0 not.b32 %r71,%r47; and.b32 %r45,%r71,%r40; mov.u32 %r46,0; bra $L4; $L2: .loc 1 58 0 setp.le.s32 %r72,%r42,51; @ %r72 bra $L9; .loc 1 59 0 setp.ne.u32 %r73,%r42,1024; @ %r73 bra $L16; add.f64 %r49,%r50,%r50; bra $L1; $L9: .loc 1 62 0 add.u32 %r74,%r23,-1043; mov.u32 %r75,-1; shr.u32 %r43,%r75,%r74; .loc 1 63 0 and.b32 %r76,%r43,%r46; setp.eq.u32 %r77,%r76,0; @ %r77 bra $L17; .loc 1 64 0 add.f64 %r78,%r50,0d7e37e43c8800759c; setp.gt.f64 %r79,%r78,0d0000000000000000; @ ! %r79 bra $L4; .loc 1 65 0 setp.le.s32 %r80,%r40,0; @ %r80 bra $L11; .loc 1 66 0 setp.ne.u32 %r81,%r42,20; @ %r81 bra $L12; add.u32 %r40,%r40,1; bra $L11; $L12: .loc 1 68 0 mov.u32 %r83,52; sub.u32 %r82,%r83,%r42; mov.u32 %r85,1; shl.b32 %r84,%r85,%r82; add.u32 %r44,%r84,%r46; .loc 1 69 0 setp.ge.u32 %r86,%r44,%r46; @ %r86 bra $L18; add.u32 %r40,%r40,1; mov.u32 %r46,%r44; bra $L11; $L18: mov.u32 %r46,%r44; $L11: .loc 1 73 0 not.b32 %r87,%r43; and.b32 %r46,%r46,%r87; mov.u32 %r45,%r40; bra $L4; $L13: mov.u32 %r46,0; mov.u32 %r45,-2147483648; bra $L4; $L14: mov.u32 %r46,%r60; mov.u32 %r45,%r46; $L4: .loc 1 76 0 cvt.u64.u32 %r88,%r45; cvt.u64.u32 %r92,%r46; shl.b64 %r93,%r88,32; or.b64 %r94,%r93,%r92; mov.b64 %r49,%r94; .loc 1 77 0 bra $L1; $L15: .loc 1 52 0 mov.f64 %r49,%r50; bra $L1; $L16: mov.f64 %r49,%r50; bra $L1; $L17: mov.f64 %r49,%r50; $L1: .loc 1 78 0 mov.f64 %value,%r49; st.param.f64 [%value_out],%value; ret; } /469 0 0 0 644 1186 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %r27; .reg .f64 %r29; .reg .f64 %r30; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .u64 %r43; mov.f64 %r29,%ar0; mov.f64 %r30,%ar1; .loc 1 78 0 mov.b64 %r27,%r29; shr.u64 %r32,%r27,32; cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; mov.b64 %r35,%r30; shr.u64 %r36,%r35,32; cvt.u32.u64 %r38,%r36; and.b32 %r37,%r38,-2147483648; or.b32 %r39,%r33,%r37; cvt.u64.u32 %r40,%r39; shl.b64 %r41,%r40,32; and.b64 %r42,%r27,4294967295; or.b64 %r43,%r42,%r41; mov.b64 %value,%r43; .loc 1 80 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_cos.o/ 0 0 0 644 4231 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cos .visible .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_cos.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .extern .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .extern .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .extern .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cos .visible .func (.param .f64 %value_out) cos (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r33; .reg .u32 %r34; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .f64 %r44; .reg .pred %r45; .reg .u32 %r48; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .f64 %r53; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r60; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .u32 %r68; .reg .f64 %r69; .reg .f64 %r70; mov.f64 %r38,%ar0; .loc 1 60 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r33,%r40; .loc 1 63 0 and.b32 %r34,%r33,2147483647; .loc 1 64 0 setp.gt.s32 %r41,%r34,1072243195; @ %r41 bra $L2; mov.f64 %r43,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r44,[%value_in]; } mov.f64 %r37,%r44; bra $L1; $L2: .loc 1 67 0 setp.le.s32 %r45,%r34,2146435071; @ %r45 bra $L4; sub.f64 %r37,%r38,%r38; bra $L1; $L4: .loc 1 71 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2,(%out_arg1,%out_arg2); ld.param.u32 %r48,[%value_in]; } .loc 1 72 0 and.b32 %r49,%r48,3; setp.eq.u32 %r50,%r49,1; @ %r50 bra $L6; setp.eq.u32 %r51,%r49,2; @ %r51 bra $L7; setp.eq.u32 %r52,%r49,0; @ ! %r52 bra $L9; .loc 1 73 0 ld.f64 %r55,[%frame+8]; ld.f64 %r53,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r53; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r55; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r56,[%value_in]; } mov.f64 %r37,%r56; bra $L1; $L6: .loc 1 74 0 ld.f64 %r60,[%frame+8]; ld.f64 %r57,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r57; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r60; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r49; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r61,[%value_in]; } neg.f64 %r37,%r61; bra $L1; $L7: .loc 1 75 0 ld.f64 %r64,[%frame+8]; ld.f64 %r62,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r62; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r64; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r65,[%value_in]; } neg.f64 %r37,%r65; bra $L1; $L9: .loc 1 77 0 ld.f64 %r69,[%frame+8]; mov.u32 %r68,1; ld.f64 %r66,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r66; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r69; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r68; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r70,[%value_in]; } mov.f64 %r37,%r70; $L1: .loc 1 80 0 mov.f64 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-s_erf.o/ 0 0 0 644 16275 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erf .visible .func (.param .f64 %value_out) erf (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_erf.c" // BEGIN GLOBAL FUNCTION DECL: erfc .visible .func (.param .f64 %value_out) erfc (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erf .visible .func (.param .f64 %value_out) erf (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r84; .reg .f64 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .f64 %r89; .reg .f64 %r90; .reg .f64 %r91; .reg .u32 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .u64 %r121; .reg .f64 %r122; .reg .f64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .pred %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .pred %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .pred %r149; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .f64 %r158; .reg .f64 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .pred %r163; .reg .f64 %r164; .reg .f64 %r165; .reg .f64 %r166; .reg .pred %r167; .reg .pred %r168; .reg .f64 %r170; .reg .f64 %r171; .reg .f64 %r172; .reg .pred %r173; .reg .f64 %r174; .reg .f64 %r175; .reg .f64 %r176; .reg .f64 %r177; .reg .f64 %r178; .reg .f64 %r179; .reg .f64 %r180; .reg .f64 %r181; .reg .f64 %r182; .reg .f64 %r183; .reg .f64 %r184; .reg .f64 %r185; .reg .f64 %r186; .reg .f64 %r187; .reg .f64 %r188; .reg .f64 %r189; .reg .f64 %r190; .reg .f64 %r191; .reg .f64 %r192; .reg .f64 %r193; .reg .f64 %r194; .reg .f64 %r195; .reg .f64 %r196; .reg .f64 %r197; .reg .u64 %r198; .reg .f64 %r200; .reg .f64 %r201; .reg .f64 %r202; .reg .f64 %r204; .reg .f64 %r205; .reg .f64 %r206; .reg .f64 %r207; .reg .f64 %r208; .reg .pred %r209; .reg .f64 %r210; .reg .f64 %r211; .reg .f64 %r212; .reg .f64 %r213; mov.f64 %r123,%ar0; mov.b64 %r124,%r123; shr.u64 %r125,%r124,32; cvt.u32.u64 %r92,%r125; .loc 1 260 0 cvt.u32.u64 %r86,%r125; .loc 1 261 0 and.b32 %r87,%r92,2147483647; .loc 1 262 0 setp.le.s32 %r126,%r87,2146435071; @ %r126 bra $L2; .loc 1 263 0 shr.u32 %r127,%r92,31; add.u32 %r128,%r127,%r127; .loc 1 264 0 mov.u32 %r130,1; sub.u32 %r129,%r130,%r128; cvt.rn.f64.s32 %r131,%r129; mov.f64 %r133,0d3ff0000000000000; div.rn.f64 %r132,%r133,%r123; add.f64 %r122,%r131,%r132; bra $L1; $L2: .loc 1 267 0 setp.gt.s32 %r134,%r87,1072365567; @ %r134 bra $L4; .loc 1 268 0 setp.gt.s32 %r135,%r87,1043333119; @ %r135 bra $L5; .loc 1 269 0 setp.gt.s32 %r136,%r87,8388607; @ %r136 bra $L6; .loc 1 270 0 mul.f64 %r137,%r123,0d3ff06eba8214db69; fma.rn.f64 %r138,%r123,0d4020000000000000,%r137; mul.f64 %r122,%r138,0d3fc0000000000000; bra $L1; $L6: .loc 1 271 0 fma.rn.f64 %r122,%r123,0d3fc06eba8214db69,%r123; bra $L1; $L5: .loc 1 273 0 mul.f64 %r96,%r123,%r123; .loc 1 274 0 fma.rn.f64 %r139,%r96,0dbef8ead6120016ac,0dbf77a291236668e4; fma.rn.f64 %r140,%r139,%r96,0dbf9d2a51dbd7194f; fma.rn.f64 %r141,%r140,%r96,0dbfd4cd7d691cb913; fma.rn.f64 %r142,%r141,%r96,0d3fc06eba8214db68; .loc 1 275 0 fma.rn.f64 %r143,%r96,0dbed09c4342a26120,0d3f215dc9221c1a10; fma.rn.f64 %r144,%r143,%r96,0d3f74d022c4d36b0f; fma.rn.f64 %r145,%r144,%r96,0d3fb0a54c5536ceba; fma.rn.f64 %r146,%r145,%r96,0d3fd97779cddadc09; fma.rn.f64 %r147,%r146,%r96,0d3ff0000000000000; .loc 1 276 0 div.rn.f64 %r148,%r142,%r147; .loc 1 277 0 fma.rn.f64 %r122,%r123,%r148,%r123; bra $L1; $L4: .loc 1 279 0 setp.gt.s32 %r149,%r87,1072955391; @ %r149 bra $L7; .loc 1 280 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r123; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r151,[%value_in]; } mov.f64 %r152,0d3ff0000000000000; sub.f64 %r93,%r151,%r152; .loc 1 281 0 fma.rn.f64 %r153,%r93,0dbf61bf380a96073f,0d3fa22a36599795eb; fma.rn.f64 %r154,%r153,%r93,0dbfbc63983d3e28ec; fma.rn.f64 %r155,%r154,%r93,0d3fd45fca805120e4; fma.rn.f64 %r156,%r155,%r93,0dbfd7d240fbb8c3f1; fma.rn.f64 %r157,%r156,%r93,0d3fda8d00ad92b34d; fma.rn.f64 %r94,%r157,%r93,0dbf6359b8bef77538; .loc 1 282 0 fma.rn.f64 %r158,%r93,0d3f888b545735151d,0d3f8bedc26b51dd1c; fma.rn.f64 %r159,%r158,%r93,0d3fc02660e763351f; fma.rn.f64 %r160,%r159,%r93,0d3fb2635cd99fe9a7; fma.rn.f64 %r161,%r160,%r93,0d3fe14af092eb6f33; fma.rn.f64 %r162,%r161,%r93,0d3fbb3e6618eee323; fma.rn.f64 %r95,%r162,%r93,0d3ff0000000000000; .loc 1 283 0 setp.lt.s32 %r163,%r92,0; @ %r163 bra $L8; div.rn.f64 %r164,%r94,%r95; add.f64 %r122,%r164,0d3feb0ac160000000; bra $L1; $L8: div.rn.f64 %r165,%r94,%r95; mov.f64 %r166,0dbfeb0ac160000000; sub.f64 %r122,%r166,%r165; bra $L1; $L7: .loc 1 285 0 setp.le.s32 %r167,%r87,1075314687; @ %r167 bra $L9; .loc 1 286 0 setp.ge.s32 %r168,%r92,0; selp.f64 %r122,0d3ff0000000000000,0dbff0000000000000,%r168; bra $L1; $L9: .loc 1 288 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r123; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r170,[%value_in]; } .loc 1 289 0 mul.f64 %r171,%r170,%r170; mov.f64 %r172,0d3ff0000000000000; div.rn.f64 %r89,%r172,%r171; .loc 1 290 0 setp.gt.s32 %r173,%r87,1074191213; @ %r173 bra $L10; .loc 1 292 0 fma.rn.f64 %r174,%r89,0dc023a0efc69ac25c,0dc054526557e4d2f2; fma.rn.f64 %r175,%r174,%r89,0dc067135cebccabb2; .loc 1 291 0 fma.rn.f64 %r176,%r175,%r89,0dc0644cb184282266; fma.rn.f64 %r177,%r176,%r89,0dc04f300ae4cba38d; fma.rn.f64 %r178,%r177,%r89,0dc0251e0441b0e726; fma.rn.f64 %r179,%r178,%r89,0dbfe63416e4ba7360; fma.rn.f64 %r84,%r179,%r89,0dbf843412600d6435; .loc 1 294 0 fma.rn.f64 %r180,%r89,0dbfaeeff2ee749a62,0d401a47ef8e484a93; fma.rn.f64 %r181,%r180,%r89,0d405b28a3ee48ae2c; fma.rn.f64 %r182,%r181,%r89,0d407ad02157700314; .loc 1 293 0 fma.rn.f64 %r183,%r182,%r89,0d40842b1921ec2868; fma.rn.f64 %r184,%r183,%r89,0d407b290dd58a1a71; fma.rn.f64 %r185,%r184,%r89,0d4061350c526ae721; fma.rn.f64 %r186,%r185,%r89,0d4033a6b9bd707687; fma.rn.f64 %r85,%r186,%r89,0d3ff0000000000000; bra $L11; $L10: .loc 1 297 0 fma.rn.f64 %r187,%r89,0dc07e384e9bdc383f,0dc09004616a2e5992; .loc 1 296 0 fma.rn.f64 %r188,%r187,%r89,0dc083ec881375f228; fma.rn.f64 %r189,%r188,%r89,0dc064145d43c5ed98; fma.rn.f64 %r190,%r189,%r89,0dc031c209555f995a; fma.rn.f64 %r191,%r190,%r89,0dbfe993ba70c285de; fma.rn.f64 %r84,%r191,%r89,0dbf84341239e86f4a; .loc 1 299 0 fma.rn.f64 %r192,%r89,0dc03670e242712d62,0d407da874e79fe763; fma.rn.f64 %r193,%r192,%r89,0d40a3f219cedf3be6; .loc 1 298 0 fma.rn.f64 %r194,%r193,%r89,0d40a8ffb7688c246a; fma.rn.f64 %r195,%r194,%r89,0d409802eb189d5118; fma.rn.f64 %r196,%r195,%r89,0d40745cae221b9f0a; fma.rn.f64 %r197,%r196,%r89,0d403e568b261d5190; fma.rn.f64 %r85,%r197,%r89,0d3ff0000000000000; $L11: .loc 1 302 0 mov.b64 %r121,%r170; and.b64 %r198,%r121,-4294967296; mov.b64 %r90,%r198; .loc 1 303 0 neg.f64 %r200,%r90; fma.rn.f64 %r201,%r200,%r90,0dbfe2000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r201; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r202,[%value_in]; } sub.f64 %r204,%r90,%r170; div.rn.f64 %r205,%r84,%r85; add.f64 %r206,%r170,%r90; fma.rn.f64 %r207,%r204,%r206,%r205; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r207; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r208,[%value_in]; } mul.f64 %r91,%r202,%r208; .loc 1 304 0 setp.lt.s32 %r209,%r86,0; @ %r209 bra $L12; div.rn.f64 %r210,%r91,%r170; mov.f64 %r211,0d3ff0000000000000; sub.f64 %r122,%r211,%r210; bra $L1; $L12: div.rn.f64 %r212,%r91,%r170; mov.f64 %r213,0d3ff0000000000000; sub.f64 %r122,%r212,%r213; $L1: .loc 1 305 0 mov.f64 %value,%r122; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: erfc .visible .func (.param .f64 %value_out) erfc (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r86; .reg .f64 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .f64 %r92; .reg .f64 %r93; .reg .f64 %r94; .reg .f64 %r95; .reg .f64 %r96; .reg .f64 %r97; .reg .f64 %r99; .reg .f64 %r113; .reg .u64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .f64 %r135; .reg .pred %r136; .reg .pred %r137; .reg .f64 %r138; .reg .f64 %r139; .reg .f64 %r140; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .pred %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .f64 %r153; .reg .f64 %r154; .reg .pred %r156; .reg .f64 %r158; .reg .f64 %r159; .reg .f64 %r160; .reg .f64 %r161; .reg .f64 %r162; .reg .f64 %r163; .reg .f64 %r164; .reg .f64 %r165; .reg .f64 %r166; .reg .f64 %r167; .reg .f64 %r168; .reg .f64 %r169; .reg .pred %r170; .reg .f64 %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .f64 %r174; .reg .pred %r175; .reg .f64 %r177; .reg .f64 %r178; .reg .f64 %r179; .reg .pred %r180; .reg .f64 %r181; .reg .f64 %r182; .reg .f64 %r183; .reg .f64 %r184; .reg .f64 %r185; .reg .f64 %r186; .reg .f64 %r187; .reg .f64 %r188; .reg .f64 %r189; .reg .f64 %r190; .reg .f64 %r191; .reg .f64 %r192; .reg .f64 %r193; .reg .u32 %r195; .reg .u32 %r197; .reg .u32 %r198; .reg .u16 %r200; .reg .u16 %r201; .reg .u16 %r202; .reg .u32 %r203; .reg .u16 %r204; .reg .pred %r205; .reg .f64 %r206; .reg .f64 %r207; .reg .f64 %r208; .reg .f64 %r209; .reg .f64 %r210; .reg .f64 %r211; .reg .f64 %r212; .reg .f64 %r213; .reg .f64 %r214; .reg .f64 %r215; .reg .f64 %r216; .reg .u64 %r217; .reg .f64 %r219; .reg .f64 %r220; .reg .f64 %r221; .reg .f64 %r223; .reg .f64 %r224; .reg .f64 %r225; .reg .f64 %r226; .reg .f64 %r227; .reg .pred %r228; .reg .f64 %r229; .reg .f64 %r230; .reg .pred %r231; mov.f64 %r127,%ar0; mov.b64 %r128,%r127; shr.u64 %r129,%r128,32; cvt.u32.u64 %r90,%r129; .loc 1 316 0 cvt.u32.u64 %r88,%r129; .loc 1 317 0 and.b32 %r89,%r90,2147483647; .loc 1 318 0 setp.le.s32 %r130,%r89,2146435071; @ %r130 bra $L15; .loc 1 320 0 shr.u32 %r131,%r90,31; add.u32 %r132,%r131,%r131; cvt.rn.f64.s32 %r133,%r132; mov.f64 %r135,0d3ff0000000000000; div.rn.f64 %r134,%r135,%r127; add.f64 %r126,%r133,%r134; bra $L14; $L15: .loc 1 323 0 setp.gt.s32 %r136,%r89,1072365567; @ %r136 bra $L17; .loc 1 324 0 setp.gt.s32 %r137,%r89,1013972991; @ %r137 bra $L18; .loc 1 325 0 mov.f64 %r138,0d3ff0000000000000; sub.f64 %r126,%r138,%r127; bra $L14; $L18: .loc 1 326 0 mul.f64 %r99,%r127,%r127; .loc 1 327 0 fma.rn.f64 %r139,%r99,0dbef8ead6120016ac,0dbf77a291236668e4; fma.rn.f64 %r140,%r139,%r99,0dbf9d2a51dbd7194f; fma.rn.f64 %r141,%r140,%r99,0dbfd4cd7d691cb913; fma.rn.f64 %r142,%r141,%r99,0d3fc06eba8214db68; .loc 1 328 0 fma.rn.f64 %r143,%r99,0dbed09c4342a26120,0d3f215dc9221c1a10; fma.rn.f64 %r144,%r143,%r99,0d3f74d022c4d36b0f; fma.rn.f64 %r145,%r144,%r99,0d3fb0a54c5536ceba; fma.rn.f64 %r146,%r145,%r99,0d3fd97779cddadc09; fma.rn.f64 %r147,%r146,%r99,0d3ff0000000000000; .loc 1 329 0 div.rn.f64 %r148,%r142,%r147; mul.f64 %r113,%r148,%r127; .loc 1 330 0 setp.gt.s32 %r149,%r90,1070596095; @ %r149 bra $L19; .loc 1 331 0 add.f64 %r150,%r127,%r113; mov.f64 %r151,0d3ff0000000000000; sub.f64 %r126,%r151,%r150; bra $L14; $L19: .loc 1 334 0 mov.f64 %r153,0d3fe0000000000000; sub.f64 %r152,%r127,%r153; add.f64 %r154,%r152,%r113; .loc 1 335 0 sub.f64 %r126,%r153,%r154; bra $L14; $L17: .loc 1 338 0 setp.gt.s32 %r156,%r89,1072955391; @ %r156 bra $L20; .loc 1 339 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r127; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r158,[%value_in]; } mov.f64 %r159,0d3ff0000000000000; sub.f64 %r95,%r158,%r159; .loc 1 340 0 fma.rn.f64 %r160,%r95,0dbf61bf380a96073f,0d3fa22a36599795eb; fma.rn.f64 %r161,%r160,%r95,0dbfbc63983d3e28ec; fma.rn.f64 %r162,%r161,%r95,0d3fd45fca805120e4; fma.rn.f64 %r163,%r162,%r95,0dbfd7d240fbb8c3f1; fma.rn.f64 %r164,%r163,%r95,0d3fda8d00ad92b34d; fma.rn.f64 %r96,%r164,%r95,0dbf6359b8bef77538; .loc 1 341 0 fma.rn.f64 %r165,%r95,0d3f888b545735151d,0d3f8bedc26b51dd1c; fma.rn.f64 %r166,%r165,%r95,0d3fc02660e763351f; fma.rn.f64 %r167,%r166,%r95,0d3fb2635cd99fe9a7; fma.rn.f64 %r168,%r167,%r95,0d3fe14af092eb6f33; fma.rn.f64 %r169,%r168,%r95,0d3fbb3e6618eee323; fma.rn.f64 %r97,%r169,%r95,0d3ff0000000000000; .loc 1 342 0 setp.lt.s32 %r170,%r90,0; @ %r170 bra $L21; .loc 1 343 0 div.rn.f64 %r171,%r96,%r97; mov.f64 %r172,0d3fc3d4fa80000000; sub.f64 %r126,%r172,%r171; bra $L14; $L21: .loc 1 345 0 div.rn.f64 %r173,%r96,%r97; add.f64 %r174,%r173,0d3feb0ac160000000; add.f64 %r126,%r174,0d3ff0000000000000; bra $L14; $L20: .loc 1 348 0 setp.gt.s32 %r175,%r89,1077673983; @ %r175 bra $L22; .loc 1 349 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r127; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r177,[%value_in]; } .loc 1 350 0 mul.f64 %r178,%r177,%r177; mov.f64 %r179,0d3ff0000000000000; div.rn.f64 %r92,%r179,%r178; .loc 1 351 0 setp.gt.s32 %r180,%r89,1074191212; @ %r180 bra $L23; .loc 1 353 0 fma.rn.f64 %r181,%r92,0dc023a0efc69ac25c,0dc054526557e4d2f2; fma.rn.f64 %r182,%r181,%r92,0dc067135cebccabb2; .loc 1 352 0 fma.rn.f64 %r183,%r182,%r92,0dc0644cb184282266; fma.rn.f64 %r184,%r183,%r92,0dc04f300ae4cba38d; fma.rn.f64 %r185,%r184,%r92,0dc0251e0441b0e726; fma.rn.f64 %r186,%r185,%r92,0dbfe63416e4ba7360; fma.rn.f64 %r86,%r186,%r92,0dbf843412600d6435; .loc 1 355 0 fma.rn.f64 %r187,%r92,0dbfaeeff2ee749a62,0d401a47ef8e484a93; fma.rn.f64 %r188,%r187,%r92,0d405b28a3ee48ae2c; fma.rn.f64 %r189,%r188,%r92,0d407ad02157700314; .loc 1 354 0 fma.rn.f64 %r190,%r189,%r92,0d40842b1921ec2868; fma.rn.f64 %r191,%r190,%r92,0d407b290dd58a1a71; fma.rn.f64 %r192,%r191,%r92,0d4061350c526ae721; fma.rn.f64 %r193,%r192,%r92,0d4033a6b9bd707687; fma.rn.f64 %r87,%r193,%r92,0d3ff0000000000000; bra $L24; $L23: .loc 1 357 0 shr.u32 %r195,%r88,31; set.u32.gt.s32 %r197,%r89,1075314687; neg.s32 %r198,%r197; cvt.u16.u32 %r201,%r195; cvt.u16.u32 %r202,%r198; and.b16 %r200,%r201,%r202; cvt.u32.u16 %r203,%r200; cvt.u16.u8 %r204,%r203; setp.ne.u16 %r205,%r204,0; @ %r205 bra $L25; .loc 1 359 0 fma.rn.f64 %r206,%r92,0dc07e384e9bdc383f,0dc09004616a2e5992; .loc 1 358 0 fma.rn.f64 %r207,%r206,%r92,0dc083ec881375f228; fma.rn.f64 %r208,%r207,%r92,0dc064145d43c5ed98; fma.rn.f64 %r209,%r208,%r92,0dc031c209555f995a; fma.rn.f64 %r210,%r209,%r92,0dbfe993ba70c285de; fma.rn.f64 %r86,%r210,%r92,0dbf84341239e86f4a; .loc 1 361 0 fma.rn.f64 %r211,%r92,0dc03670e242712d62,0d407da874e79fe763; fma.rn.f64 %r212,%r211,%r92,0d40a3f219cedf3be6; .loc 1 360 0 fma.rn.f64 %r213,%r212,%r92,0d40a8ffb7688c246a; fma.rn.f64 %r214,%r213,%r92,0d409802eb189d5118; fma.rn.f64 %r215,%r214,%r92,0d40745cae221b9f0a; fma.rn.f64 %r216,%r215,%r92,0d403e568b261d5190; fma.rn.f64 %r87,%r216,%r92,0d3ff0000000000000; $L24: .loc 1 364 0 mov.b64 %r125,%r177; and.b64 %r217,%r125,-4294967296; mov.b64 %r93,%r217; .loc 1 365 0 neg.f64 %r219,%r93; fma.rn.f64 %r220,%r219,%r93,0dbfe2000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r220; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r221,[%value_in]; } .loc 1 366 0 sub.f64 %r223,%r93,%r177; div.rn.f64 %r224,%r86,%r87; add.f64 %r225,%r177,%r93; fma.rn.f64 %r226,%r223,%r225,%r224; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r226; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r227,[%value_in]; } .loc 1 365 0 mul.f64 %r94,%r221,%r227; .loc 1 367 0 setp.le.s32 %r228,%r88,0; @ %r228 bra $L26; div.rn.f64 %r126,%r94,%r177; bra $L14; $L26: div.rn.f64 %r229,%r94,%r177; mov.f64 %r230,0d4000000000000000; sub.f64 %r126,%r230,%r229; bra $L14; $L22: .loc 1 369 0 setp.gt.s32 %r231,%r90,0; @ %r231 bra $L27; $L25: mov.f64 %r126,0d4000000000000000; bra $L14; $L27: mov.f64 %r126,0d0000000000000000; $L14: .loc 1 371 0 mov.f64 %value,%r126; st.param.f64 [%value_out],%value; ret; } lib_a-s_exp10.o/0 0 0 644 928 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp10 .visible .func (.param .f64 %value_out) exp10 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_exp10.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp10 .visible .func (.param .f64 %value_out) exp10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r23,%ar0; .loc 1 77 0 mov.f64 %r24,0d4024000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r23; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 78 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } lib_a-s_expm1.o/0 0 0 644 7803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expm1 .visible .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_expm1.c" // BEGIN GLOBAL FUNCTION DEF: expm1 .visible .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f64 %r37; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .u32 %r59; .reg .f64 %r60; .reg .u32 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .u32 %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .f64 %r71; .reg .f64 %r72; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r83; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r96; .reg .u64 %r98; .reg .f64 %r99; .reg .f64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .u32 %r106; .reg .u32 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .f64 %r113; .reg .f64 %r114; .reg .pred %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .f64 %r119; .reg .pred %r120; .reg .f64 %r121; .reg .f64 %r123; .reg .pred %r124; .reg .f64 %r125; .reg .f64 %r126; .reg .f64 %r127; .reg .f64 %r128; .reg .f64 %r129; .reg .f64 %r130; .reg .f64 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .f64 %r134; .reg .pred %r135; .reg .f64 %r136; .reg .f64 %r137; .reg .f64 %r138; .reg .pred %r139; .reg .f64 %r140; .reg .pred %r141; .reg .pred %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .u32 %r146; .reg .pred %r147; .reg .f64 %r148; .reg .f64 %r149; .reg .u64 %r151; .reg .u32 %r152; .reg .u32 %r153; .reg .u64 %r154; .reg .u64 %r155; .reg .u64 %r156; .reg .u64 %r157; .reg .pred %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .u32 %r162; .reg .u32 %r163; .reg .u64 %r164; .reg .u64 %r165; .reg .f64 %r168; .reg .u64 %r170; .reg .u32 %r171; .reg .u32 %r172; .reg .u64 %r173; .reg .u64 %r174; .reg .u64 %r175; .reg .u64 %r176; .reg .u32 %r177; .reg .u32 %r178; .reg .u32 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .f64 %r184; .reg .u64 %r186; .reg .u32 %r187; .reg .u32 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .pred %r194; mov.f64 %r100,%ar0; mov.b64 %r101,%r100; shr.u64 %r102,%r101,32; cvt.u32.u64 %r64,%r102; .loc 1 187 0 cvt.u32.u64 %r22,%r102; .loc 1 189 0 and.b32 %r61,%r64,2147483647; .loc 1 192 0 setp.le.u32 %r103,%r61,1078159481; @ %r103 bra $L2; .loc 1 193 0 setp.le.u32 %r104,%r61,1082535489; @ %r104 bra $L3; .loc 1 194 0 setp.le.u32 %r105,%r61,2146435071; @ %r105 bra $L4; .loc 1 197 0 and.b32 %r106,%r64,1048575; cvt.u32.u64 %r109,%r101; or.b32 %r108,%r106,%r109; setp.eq.u32 %r110,%r108,0; @ %r110 bra $L5; .loc 1 198 0 add.f64 %r99,%r100,%r100; bra $L1; $L5: .loc 1 199 0 setp.lt.s32 %r111,%r64,0; selp.f64 %r99,0dbff0000000000000,%r100,%r111; bra $L1; $L4: .loc 1 201 0 setp.gt.f64 %r112,%r100,0d40862e42fefa39ef; @ ! %r112 bra $L3; mov.f64 %r113,0d7e37e43c8800759c; mul.f64 %r99,%r113,0d7e37e43c8800759c; bra $L1; $L22: .loc 1 204 0 add.f64 %r114,%r100,0d01a56e1fc2f8f359; setp.lt.f64 %r115,%r114,0d0000000000000000; @ ! %r115 bra $L30; bra $L25; $L2: .loc 1 210 0 setp.le.u32 %r116,%r61,1071001154; @ %r116 bra $L9; .loc 1 211 0 setp.gt.u32 %r117,%r61,1072734897; @ %r117 bra $L10; .loc 1 212 0 setp.lt.s32 %r118,%r64,0; @ %r118 bra $L11; .loc 1 213 0 mov.f64 %r119,0d3fe62e42fee00000; sub.f64 %r56,%r100,%r119; mov.u32 %r59,1; mov.f64 %r57,0d3dea39ef35793c76; bra $L12; $L11: .loc 1 215 0 add.f64 %r56,%r100,0d3fe62e42fee00000; mov.u32 %r59,-1; mov.f64 %r57,0dbdea39ef35793c76; bra $L12; $L10: .loc 1 217 0 mul.f64 %r83,%r100,0d3ff71547652b82fe; setp.lt.s32 %r120,%r64,0; selp.f64 %r60,0dbfe0000000000000,0d3fe0000000000000,%r120; $L13: add.f64 %r121,%r60,%r83; cvt.rzi.s32.f64 %r59,%r121; .loc 1 218 0 cvt.rn.f64.s32 %r63,%r59; .loc 1 219 0 fma.rn.f64 %r56,%r63,0dbfe62e42fee00000,%r100; .loc 1 220 0 mul.f64 %r57,%r63,0d3dea39ef35793c76; $L12: .loc 1 222 0 sub.f64 %r100,%r56,%r57; .loc 1 223 0 sub.f64 %r123,%r56,%r100; sub.f64 %r58,%r123,%r57; bra $L14; $L9: .loc 1 225 0 setp.gt.u32 %r124,%r61,1016070143; @ %r124 bra $L27; .loc 1 226 0 add.f64 %r62,%r100,0d7e37e43c8800759c; .loc 1 227 0 sub.f64 %r125,%r62,%r62; sub.f64 %r99,%r100,%r125; bra $L1; $L27: .loc 1 229 0 mov.u32 %r59,0; $L14: .loc 1 232 0 mul.f64 %r66,%r100,0d3fe0000000000000; .loc 1 233 0 mul.f64 %r67,%r100,%r66; .loc 1 234 0 fma.rn.f64 %r126,%r67,0dbe8afdb76e09c32d,0d3ed0cfca86e65239; fma.rn.f64 %r127,%r126,%r67,0dbf14ce199eaadbb7; fma.rn.f64 %r128,%r127,%r67,0d3f5a01a019fe5585; fma.rn.f64 %r129,%r128,%r67,0dbfa11111111110f4; fma.rn.f64 %r68,%r129,%r67,0d3ff0000000000000; .loc 1 235 0 neg.f64 %r130,%r66; fma.rn.f64 %r69,%r130,%r68,0d4008000000000000; .loc 1 236 0 sub.f64 %r131,%r68,%r69; neg.f64 %r132,%r100; fma.rn.f64 %r133,%r132,%r69,0d4018000000000000; div.rn.f64 %r134,%r131,%r133; mul.f64 %r70,%r134,%r67; .loc 1 237 0 setp.ne.u32 %r135,%r59,0; @ %r135 bra $L15; neg.f64 %r136,%r67; fma.rn.f64 %r137,%r100,%r70,%r136; sub.f64 %r99,%r100,%r137; bra $L1; $L15: .loc 1 239 0 sub.f64 %r37,%r70,%r58; neg.f64 %r138,%r58; fma.rn.f64 %r71,%r37,%r100,%r138; .loc 1 240 0 sub.f64 %r72,%r71,%r67; .loc 1 241 0 setp.ne.u32 %r139,%r59,-1; @ %r139 bra $L16; sub.f64 %r140,%r100,%r72; fma.rn.f64 %r99,%r140,0d3fe0000000000000,0dbfe0000000000000; bra $L1; $L16: .loc 1 242 0 setp.ne.u32 %r141,%r59,1; @ %r141 bra $L17; .loc 1 243 0 setp.lt.f64 %r142,%r100,0dbfd0000000000000; @ ! %r142 bra $L31; add.f64 %r143,%r100,0d3fe0000000000000; sub.f64 %r144,%r72,%r143; mul.f64 %r99,%r144,0dc000000000000000; bra $L1; $L31: .loc 1 244 0 sub.f64 %r145,%r100,%r72; fma.rn.f64 %r99,%r145,0d4000000000000000,0d3ff0000000000000; bra $L1; $L17: shl.b32 %r93,%r59,20; .loc 1 246 0 add.u32 %r146,%r59,1; setp.le.u32 %r147,%r146,57; @ %r147 bra $L20; .loc 1 248 0 sub.f64 %r148,%r72,%r100; mov.f64 %r149,0d3ff0000000000000; sub.f64 %r80,%r149,%r148; .loc 1 250 0 mov.b64 %r94,%r80; shr.u64 %r151,%r94,32; cvt.u32.u64 %r153,%r151; add.u32 %r152,%r93,%r153; cvt.u64.u32 %r154,%r152; shl.b64 %r155,%r154,32; and.b64 %r156,%r94,4294967295; or.b64 %r157,%r156,%r155; mov.b64 %r81,%r157; .loc 1 251 0 sub.f64 %r99,%r81,%r149; bra $L1; $L20: .loc 1 254 0 setp.gt.s32 %r159,%r59,19; @ %r159 bra $L21; .loc 1 256 0 mov.u32 %r161,2097152; shr.s32 %r160,%r161,%r59; mov.u32 %r163,1072693248; sub.u32 %r162,%r163,%r160; cvt.u64.u32 %r164,%r162; shl.b64 %r165,%r164,32; mov.b64 %r77,%r165; .loc 1 257 0 sub.f64 %r168,%r72,%r100; sub.f64 %r78,%r77,%r168; .loc 1 259 0 mov.b64 %r96,%r78; shr.u64 %r170,%r96,32; cvt.u32.u64 %r172,%r170; add.u32 %r171,%r93,%r172; cvt.u64.u32 %r173,%r171; shl.b64 %r174,%r173,32; and.b64 %r175,%r96,4294967295; or.b64 %r176,%r175,%r174; mov.b64 %r99,%r176; bra $L1; $L21: .loc 1 262 0 mov.u32 %r178,1023; sub.u32 %r177,%r178,%r59; shl.b32 %r179,%r177,20; cvt.u64.u32 %r180,%r179; shl.b64 %r181,%r180,32; mov.b64 %r74,%r181; .loc 1 263 0 add.f64 %r184,%r72,%r74; sub.f64 %r75,%r100,%r184; .loc 1 264 0 add.f64 %r76,%r75,0d3ff0000000000000; .loc 1 266 0 mov.b64 %r98,%r76; shr.u64 %r186,%r98,32; cvt.u32.u64 %r188,%r186; add.u32 %r187,%r93,%r188; cvt.u64.u32 %r189,%r187; shl.b64 %r190,%r189,32; and.b64 %r191,%r98,4294967295; or.b64 %r192,%r191,%r190; mov.b64 %r99,%r192; bra $L1; $L25: .loc 1 199 0 mov.f64 %r99,0dbff0000000000000; bra $L1; $L32: .loc 1 217 0 mul.f64 %r83,%r100,0d3ff71547652b82fe; mov.f64 %r60,0d3fe0000000000000; bra $L13; $L30: mul.f64 %r83,%r100,0d3ff71547652b82fe; mov.f64 %r60,0dbfe0000000000000; bra $L13; $L3: .loc 1 203 0 setp.lt.s32 %r194,%r22,0; @ %r194 bra $L22; bra $L32; $L1: .loc 1 270 0 mov.f64 %value,%r99; st.param.f64 [%value_out],%value; ret; } lib_a-s_fabs.o/ 0 0 0 644 844 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fabs .visible .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_fabs.c" // BEGIN GLOBAL FUNCTION DEF: fabs .visible .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .f64 %r26; .reg .u64 %r28; .reg .u32 %r29; .reg .u32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; mov.f64 %r26,%ar0; .loc 1 69 0 mov.b64 %r24,%r26; shr.u64 %r28,%r24,32; cvt.u32.u64 %r30,%r28; and.b32 %r29,%r30,2147483647; cvt.u64.u32 %r31,%r29; shl.b64 %r32,%r31,32; and.b64 %r33,%r24,4294967295; or.b64 %r34,%r33,%r32; mov.b64 %value,%r34; .loc 1 71 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_fdim.o/ 0 0 0 644 1592 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fdim .visible .func (.param .f64 %value_out) fdim (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_fdim.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fdim .visible .func (.param .f64 %value_out) fdim (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r25; .reg .f64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 52 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r28,[%value_in]; } .loc 1 53 0 setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 54 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 55 0 setp.eq.u32 %r33,%r28,1; @ %r33 bra $L5; .loc 1 58 0 setp.gt.f64 %r34,%r25,%r26; @ ! %r34 bra $L11; sub.f64 %r25,%r25,%r26; bra $L2; $L4: .loc 1 54 0 mov.f64 %r25,%r26; bra $L2; $L5: .loc 1 56 0 mov.f64 %r25,0d7ff0000000000000; bra $L2; $L11: .loc 1 58 0 mov.f64 %r25,0d0000000000000000; $L2: .loc 1 59 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /489 0 0 0 644 756 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_finite.c" // BEGIN GLOBAL FUNCTION DEF: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; mov.f64 %r29,%ar0; .loc 1 31 0 mov.b64 %r31,%r29; shr.u64 %r32,%r31,32; .loc 1 32 0 cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; add.u32 %r35,%r33,-2146435072; shr.u32 %value,%r35,31; .loc 1 33 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_floor.o/0 0 0 644 3666 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: floor .visible .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_floor.c" // BEGIN GLOBAL FUNCTION DEF: floor .visible .func (.param .f64 %value_out) floor (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .f64 %r50; .reg .f64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .pred %r57; .reg .f64 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .f64 %r68; .reg .pred %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r78; .reg .pred %r79; .reg .f64 %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .pred %r88; .reg .u32 %r89; .reg .u64 %r90; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; mov.f64 %r51,%ar0; mov.b64 %r52,%r51; shr.u64 %r53,%r52,32; cvt.u32.u64 %r46,%r53; .loc 1 95 0 cvt.u32.u64 %r41,%r53; cvt.u32.u64 %r47,%r52; .loc 1 96 0 shr.s32 %r55,%r46,20; and.b32 %r23,%r55,2047; add.u32 %r43,%r23,-1023; .loc 1 97 0 setp.gt.s32 %r56,%r43,19; @ %r56 bra $L2; .loc 1 98 0 setp.ge.s32 %r57,%r43,0; @ %r57 bra $L3; .loc 1 99 0 add.f64 %r58,%r51,0d7e37e43c8800759c; setp.gt.f64 %r59,%r58,0d0000000000000000; @ ! %r59 bra $L4; .loc 1 100 0 setp.ge.s32 %r60,%r46,0; @ %r60 bra $L13; .loc 1 101 0 and.b32 %r61,%r46,2147483647; or.b32 %r62,%r61,%r47; setp.eq.u32 %r63,%r62,0; mov.u32 %r47,0; selp.u32 %r46,%r46,-1074790400,%r63; bra $L4; $L3: .loc 1 105 0 mov.u32 %r64,1048575; shr.s32 %r48,%r64,%r43; .loc 1 106 0 and.b32 %r65,%r41,%r48; or.b32 %r66,%r65,%r47; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L15; .loc 1 107 0 add.f64 %r68,%r51,0d7e37e43c8800759c; setp.gt.f64 %r69,%r68,0d0000000000000000; @ ! %r69 bra $L4; .loc 1 108 0 setp.ge.s32 %r70,%r41,0; @ %r70 bra $L8; mov.u32 %r72,1048576; shr.s32 %r71,%r72,%r43; add.u32 %r41,%r41,%r71; $L8: .loc 1 109 0 not.b32 %r73,%r48; and.b32 %r46,%r73,%r41; mov.u32 %r47,0; bra $L4; $L2: .loc 1 112 0 setp.le.s32 %r74,%r43,51; @ %r74 bra $L9; .loc 1 113 0 setp.ne.u32 %r75,%r43,1024; @ %r75 bra $L16; add.f64 %r50,%r51,%r51; bra $L1; $L9: .loc 1 116 0 add.u32 %r76,%r23,-1043; mov.u32 %r77,-1; shr.u32 %r44,%r77,%r76; .loc 1 117 0 and.b32 %r78,%r44,%r47; setp.eq.u32 %r79,%r78,0; @ %r79 bra $L17; .loc 1 118 0 add.f64 %r80,%r51,0d7e37e43c8800759c; setp.gt.f64 %r81,%r80,0d0000000000000000; @ ! %r81 bra $L4; .loc 1 119 0 setp.ge.s32 %r82,%r41,0; @ %r82 bra $L11; .loc 1 120 0 setp.ne.u32 %r83,%r43,20; @ %r83 bra $L12; add.u32 %r41,%r41,1; bra $L11; $L12: .loc 1 122 0 mov.u32 %r85,52; sub.u32 %r84,%r85,%r43; mov.u32 %r87,1; shl.b32 %r86,%r87,%r84; add.u32 %r45,%r86,%r47; .loc 1 123 0 setp.ge.u32 %r88,%r45,%r47; @ %r88 bra $L18; add.u32 %r41,%r41,1; mov.u32 %r47,%r45; bra $L11; $L18: mov.u32 %r47,%r45; $L11: .loc 1 127 0 not.b32 %r89,%r44; and.b32 %r47,%r47,%r89; mov.u32 %r46,%r41; bra $L4; $L13: mov.u32 %r47,0; mov.u32 %r46,%r47; $L4: .loc 1 130 0 cvt.u64.u32 %r90,%r46; cvt.u64.u32 %r94,%r47; shl.b64 %r95,%r90,32; or.b64 %r96,%r95,%r94; mov.b64 %r50,%r96; .loc 1 131 0 bra $L1; $L15: .loc 1 106 0 mov.f64 %r50,%r51; bra $L1; $L16: mov.f64 %r50,%r51; bra $L1; $L17: mov.f64 %r50,%r51; $L1: .loc 1 132 0 mov.f64 %value,%r50; st.param.f64 [%value_out],%value; ret; } lib_a-s_fma.o/ 0 0 0 644 778 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fma .visible .func (.param .f64 %value_out) fma (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2); .file 1 "../../../../../../newlib/libm/common/s_fma.c" // BEGIN GLOBAL FUNCTION DEF: fma .visible .func (.param .f64 %value_out) fma (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .f64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r25; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; mov.f64 %r25,%ar2; .loc 1 53 0 fma.rn.f64 %value,%r23,%r24,%r25; .loc 1 54 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_fmax.o/ 0 0 0 644 1437 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmax .visible .func (.param .f64 %value_out) fmax (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_fmax.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fmax .visible .func (.param .f64 %value_out) fmax (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 44 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 46 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 49 0 setp.gt.f64 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f64 %r24,%r26; bra $L1; $L4: .loc 1 47 0 mov.f64 %r24,%r25; bra $L1; $L5: mov.f64 %r24,%r25; $L1: .loc 1 50 0 mov.f64 %value,%r24; st.param.f64 [%value_out],%value; ret; } lib_a-s_fmin.o/ 0 0 0 644 1437 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmin .visible .func (.param .f64 %value_out) fmin (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_fmin.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fmin .visible .func (.param .f64 %value_out) fmin (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f64 %r25,%ar0; mov.f64 %r26,%ar1; .loc 1 44 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r25; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 46 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 49 0 setp.lt.f64 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f64 %r24,%r26; bra $L1; $L4: .loc 1 47 0 mov.f64 %r24,%r25; bra $L1; $L5: mov.f64 %r24,%r25; $L1: .loc 1 50 0 mov.f64 %value,%r24; st.param.f64 [%value_out],%value; ret; } /507 0 0 0 644 1961 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r32; .reg .f64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .u16 %r45; .reg .u16 %r46; .reg .u16 %r47; .reg .u32 %r48; .reg .u16 %r49; .reg .pred %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .u32 %r55; .reg .u32 %r56; .reg .u16 %r57; .reg .u16 %r58; .reg .u32 %r60; mov.f64 %r33,%ar0; mov.b64 %r34,%r33; shr.u64 %r35,%r34,32; cvt.u32.u64 %r27,%r35; cvt.u32.u64 %r28,%r34; .loc 1 16 0 or.b32 %r37,%r27,%r28; setp.eq.u32 %r38,%r37,0; @ %r38 bra $L3; .loc 1 17 0 set.u32.eq.u32 %r40,%r28,0; neg.s32 %r41,%r40; cvt.u32.u32 %r39,%r41; set.u32.eq.u32 %r43,%r27,-2147483648; neg.s32 %r44,%r43; cvt.u16.u32 %r46,%r44; cvt.u16.u8 %r47,%r39; and.b16 %r45,%r46,%r47; .loc 1 16 0 cvt.u32.u16 %r48,%r45; cvt.u16.u8 %r49,%r48; setp.ne.u16 %r50,%r49,0; @ %r50 bra $L4; .loc 1 19 0 and.b32 %r30,%r27,2147483647; add.u32 %r51,%r30,-1048576; setp.le.u32 %r52,%r51,2145386495; @ %r52 bra $L5; .loc 1 22 0 setp.le.u32 %r53,%r30,1048575; @ %r53 bra $L6; .loc 1 26 0 set.u32.eq.u32 %r55,%r30,2146435072; neg.s32 %r56,%r55; cvt.u16.u32 %r58,%r56; and.b16 %r57,%r58,%r47; .loc 1 18 0 cvt.u32.u16 %r60,%r57; cvt.u32.u8 %r32,%r60; bra $L1; $L3: mov.u32 %r32,2; bra $L1; $L4: mov.u32 %r32,2; bra $L1; $L5: .loc 1 21 0 mov.u32 %r32,4; bra $L1; $L6: .loc 1 25 0 mov.u32 %r32,3; $L1: .loc 1 31 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-s_frexp.o/0 0 0 644 1959 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/s_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r29; .reg .u32 %r30; .reg .u32 %r35; .reg .u64 %r36; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 98 0 mov.b64 %r40,%r38; shr.u64 %r41,%r40,32; cvt.u32.u64 %r29,%r41; .loc 1 99 0 and.b32 %r30,%r29,2147483647; .loc 1 100 0 mov.u32 %r42,0; st.u32 [%r39],%r42; .loc 1 101 0 setp.gt.s32 %r43,%r30,2146435071; @ %r43 bra $L2; cvt.u32.u64 %r46,%r40; or.b32 %r45,%r30,%r46; setp.eq.u32 %r47,%r45,0; @ %r47 bra $L2; .loc 1 102 0 setp.gt.s32 %r48,%r30,1048575; @ %r48 bra $L4; .loc 1 103 0 mul.f64 %r38,%r38,0d4350000000000000; .loc 1 104 0 mov.b64 %r49,%r38; shr.u64 %r50,%r49,32; cvt.u32.u64 %r29,%r50; .loc 1 105 0 and.b32 %r30,%r29,2147483647; mov.u32 %r35,-54; bra $L3; $L4: mov.u32 %r35,%r42; $L3: .loc 1 108 0 shr.s32 %r51,%r30,20; add.u32 %r52,%r51,-1022; add.u32 %r53,%r52,%r35; st.u32 [%r39],%r53; .loc 1 110 0 mov.b64 %r36,%r38; .loc 1 109 0 and.b32 %r54,%r29,-2146435073; or.b32 %r55,%r54,1071644672; .loc 1 110 0 cvt.u64.u32 %r56,%r55; shl.b64 %r57,%r56,32; and.b64 %r58,%r36,4294967295; or.b64 %r59,%r58,%r57; mov.b64 %r38,%r59; $L2: .loc 1 112 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } lib_a-s_ilogb.o/0 0 0 644 1727 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ilogb .visible .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_ilogb.c" // BEGIN GLOBAL FUNCTION DEF: ilogb .visible .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; .reg .u32 %r36; .reg .f64 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r47; .reg .pred %r49; .reg .pred %r50; .reg .u32 %r51; mov.f64 %r37,%ar0; .loc 1 86 0 mov.b64 %r38,%r37; shr.u64 %r39,%r38,32; cvt.u32.u64 %r31,%r39; .loc 1 87 0 and.b32 %r32,%r31,2147483647; .loc 1 88 0 setp.gt.s32 %r40,%r32,1048575; @ %r40 bra $L2; .loc 1 86 0 cvt.u32.u64 %r30,%r38; .loc 1 89 0 or.b32 %r42,%r30,%r32; setp.eq.u32 %r43,%r42,0; @ %r43 bra $L7; .loc 1 92 0 setp.ne.u32 %r44,%r32,0; @ %r44 bra $L4; .loc 1 93 0 setp.le.s32 %r45,%r30,0; @ %r45 bra $L8; mov.u32 %r36,-1043; $L5: add.u32 %r36,%r36,-1; add.u32 %r30,%r30,%r30; setp.gt.s32 %r47,%r30,0; @ %r47 bra $L5; bra $L1; $L4: .loc 1 95 0 shl.b32 %r33,%r32,11; mov.u32 %r36,-1022; $L6: add.u32 %r36,%r36,-1; add.u32 %r33,%r33,%r33; setp.gt.s32 %r49,%r33,0; @ %r49 bra $L6; bra $L1; $L2: .loc 1 99 0 setp.gt.s32 %r50,%r32,2146435071; @ %r50 bra $L9; shr.s32 %r51,%r32,20; add.u32 %r36,%r51,-1023; bra $L1; $L7: .loc 1 90 0 mov.u32 %r36,-2147483647; bra $L1; $L8: .loc 1 93 0 mov.u32 %r36,-1043; bra $L1; $L9: .loc 1 103 0 mov.u32 %r36,2147483647; $L1: .loc 1 104 0 mov.u32 %value,%r36; st.param.u32 [%value_out],%value; ret; } /529 0 0 0 644 393 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL VAR DEF: __infinity .visible .const .align 8 .u64 __infinity[1] = {9218868437227405312 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: __infinityld .visible .const .align 8 .u64 __infinityld[2] = {9218868437227405312 }; // BEGIN GLOBAL VAR DEF: __infinityf .visible .const .align 4 .u32 __infinityf[1] = {2139095040 }; /549 0 0 0 644 436 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: infinity .visible .func (.param .f64 %value_out) infinity; .file 1 "../../../../../../newlib/libm/common/s_infinity.c" // BEGIN GLOBAL FUNCTION DEF: infinity .visible .func (.param .f64 %value_out) infinity { .reg .f64 %value; .loc 1 45 0 mov.f64 %value,0d7ff0000000000000; .loc 1 47 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_isinf.o/0 0 0 644 1169 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 22 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 24 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 23 0 and.b32 %r48,%r33,2147483647; .loc 1 24 0 or.b32 %r27,%r47,%r48; .loc 1 25 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 26 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 27 0 st.param.u32 [%value_out],%value; ret; } /569 0 0 0 644 1182 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isinfd.c" // BEGIN GLOBAL FUNCTION DEF: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 16 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 18 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 17 0 and.b32 %r48,%r33,2147483647; .loc 1 18 0 or.b32 %r27,%r47,%r48; .loc 1 19 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 20 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 21 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_isnan.o/0 0 0 644 1030 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 199 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 201 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 200 0 and.b32 %r45,%r30,2147483647; .loc 1 201 0 or.b32 %r27,%r44,%r45; .loc 1 202 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 203 0 shr.u32 %value,%r47,31; .loc 1 204 0 st.param.u32 [%value_out],%value; ret; } /587 0 0 0 644 1043 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isnand.c" // BEGIN GLOBAL FUNCTION DEF: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 115 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 117 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 116 0 and.b32 %r45,%r30,2147483647; .loc 1 117 0 or.b32 %r27,%r44,%r45; .loc 1 118 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 119 0 shr.u32 %value,%r47,31; .loc 1 120 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_ldexp.o/0 0 0 644 2587 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/s_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f64 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f64 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 75 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f64 %r37,%r32,0d0000000000000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } mov.f64 %r32,%r50; .loc 1 77 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f64 %r54,%r32,0d0000000000000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 79 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } /605 0 0 0 644 177 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL VAR DEF: __fdlib_version .visible .global .align 4 .u32 __fdlib_version[1] = {1 }; /624 0 0 0 644 4407 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llrint .visible .func (.param .u64 %value_out) llrint (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_llrint.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: TWO52 .const .align 8 .u64 TWO52[2] = {4841369599423283200,-4382002437431492608 }; // BEGIN GLOBAL FUNCTION DEF: llrint .visible .func (.param .u64 %value_out) llrint (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u32 %r22; .reg .u32 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .f64 %r41; .reg .f64 %r42; .reg .f64 %r43; .reg .u32 %r45; .reg .u32 %r48; .reg .u32 %r53; .reg .f64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r65; .reg .u64 %r70; .reg .f64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .f64 %r81; .reg .u64 %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .pred %r93; .reg .pred %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u64 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u32 %r101; .reg .u32 %r102; .reg .u32 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u64 %r113; .reg .u32 %r114; .reg .u32 %r116; .reg .pred %r117; .reg .u32 %r119; .reg .u32 %r120; .reg .u64 %r121; .reg .pred %r122; mov.f64 %r71,%ar0; mov.b64 %r72,%r71; shr.u64 %r73,%r72,32; cvt.u32.u64 %r65,%r73; .loc 1 60 0 shr.u32 %r22,%r65,31; .loc 1 63 0 shr.s32 %r74,%r65,20; and.b32 %r24,%r74,2047; add.u32 %r53,%r24,-1023; .loc 1 66 0 setp.gt.s32 %r75,%r53,19; @ %r75 bra $L2; .loc 1 69 0 setp.ge.s32 %r76,%r53,-1; @ %r76 bra $L3; $L5: .loc 1 70 0 mov.u64 %r70,0; bra $L1; $L3: .loc 1 75 0 cvta.const.u64 %r77,TWO52; cvt.s64.s32 %r78,%r22; shl.b64 %r79,%r78,3; add.u64 %r80,%r77,%r79; ld.f64 %r25,[%r80]; add.f64 %r26,%r25,%r71; st.f64 [%frame],%r26; .loc 1 76 0 ld.f64 %r27,[%frame]; sub.f64 %r81,%r27,%r25; .loc 1 77 0 mov.b64 %r82,%r81; shr.u64 %r83,%r82,32; cvt.u32.u64 %r61,%r83; .loc 1 80 0 and.b32 %r84,%r61,2147483647; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L5; .loc 1 84 0 and.b32 %r63,%r61,1048575; .loc 1 85 0 or.b32 %r86,%r63,1048576; .loc 1 83 0 shr.s32 %r87,%r61,20; and.b32 %r88,%r87,2047; .loc 1 87 0 mov.u32 %r91,1043; sub.u32 %r90,%r91,%r88; shr.s32 %r92,%r86,%r90; cvt.s64.s32 %r70,%r92; bra $L6; $L2: .loc 1 90 0 setp.gt.s32 %r93,%r53,62; @ %r93 bra $L7; .loc 1 93 0 setp.le.s32 %r94,%r53,51; @ %r94 bra $L8; .loc 1 96 0 and.b32 %r95,%r65,983039; or.b32 %r96,%r95,65536; cvt.s64.s32 %r97,%r96; add.u32 %r98,%r24,-1043; shl.b64 %r99,%r97,%r98; .loc 1 98 0 add.u32 %r101,%r24,-1075; cvt.u32.u64 %r103,%r72; shl.b32 %r102,%r103,%r101; cvt.u64.u32 %r104,%r102; .loc 1 96 0 or.b64 %r70,%r99,%r104; bra $L6; $L8: .loc 1 102 0 cvta.const.u64 %r105,TWO52; cvt.s64.s32 %r106,%r22; shl.b64 %r107,%r106,3; add.u64 %r108,%r105,%r107; ld.f64 %r41,[%r108]; add.f64 %r42,%r41,%r71; st.f64 [%frame],%r42; .loc 1 103 0 ld.f64 %r43,[%frame]; sub.f64 %r54,%r43,%r41; .loc 1 104 0 mov.b64 %r109,%r54; shr.u64 %r110,%r109,32; cvt.u32.u64 %r55,%r110; .loc 1 105 0 shr.s32 %r111,%r55,20; and.b32 %r45,%r111,2047; .loc 1 106 0 and.b32 %r57,%r55,1048575; .loc 1 107 0 or.b32 %r112,%r57,1048576; .loc 1 112 0 cvt.s64.s32 %r113,%r112; add.u32 %r114,%r45,-1043; shl.b64 %r70,%r113,%r114; .loc 1 113 0 mov.u32 %r116,1075; sub.u32 %r48,%r116,%r45; setp.gt.u32 %r117,%r48,31; @ %r117 bra $L6; cvt.u32.u64 %r120,%r109; shr.u32 %r119,%r120,%r48; cvt.u64.u32 %r121,%r119; or.b64 %r70,%r70,%r121; bra $L6; $L7: .loc 1 118 0 cvt.rzi.s64.f64 %r70,%r71; bra $L1; $L6: .loc 1 121 0 setp.eq.u32 %r122,%r22,0; @ %r122 bra $L1; neg.s64 %r70,%r70; $L1: .loc 1 122 0 mov.u64 %value,%r70; st.param.u64 [%value_out],%value; ret; } /642 0 0 0 644 2814 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llround .visible .func (.param .u64 %value_out) llround (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_llround.c" // BEGIN GLOBAL FUNCTION DEF: llround .visible .func (.param .u64 %value_out) llround (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r38; .reg .u32 %r41; .reg .u64 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r50; .reg .u64 %r51; .reg .f64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .pred %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .pred %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .u64 %r82; .reg .u64 %r83; mov.f64 %r52,%ar0; mov.b64 %r53,%r52; shr.u64 %r54,%r53,32; cvt.u32.u64 %r30,%r54; .loc 1 28 0 setp.ge.s32 %r55,%r30,0; selp.u32 %r43,1,-1,%r55; .loc 1 30 0 shr.u32 %r56,%r30,20; and.b32 %r57,%r56,2047; add.u32 %r44,%r57,-1023; .loc 1 31 0 and.b32 %r45,%r30,1048575; .loc 1 32 0 or.b32 %r41,%r45,1048576; .loc 1 35 0 setp.gt.s32 %r58,%r44,19; @ %r58 bra $L3; .loc 1 38 0 setp.ge.s32 %r59,%r44,0; @ %r59 bra $L4; .loc 1 40 0 setp.ne.u32 %r60,%r44,-1; @ %r60 bra $L12; .loc 1 43 0 cvt.s64.s32 %r51,%r43; bra $L1; $L4: .loc 1 49 0 mov.u32 %r62,524288; shr.s32 %r61,%r62,%r44; add.u32 %r63,%r61,%r41; .loc 1 51 0 mov.u32 %r65,20; sub.u32 %r64,%r65,%r44; shr.u32 %r66,%r63,%r64; cvt.u64.u32 %r42,%r66; bra $L6; $L3: .loc 1 54 0 setp.gt.u32 %r67,%r44,62; @ %r67 bra $L7; cvt.u32.u64 %r47,%r53; add.u32 %r50,%r57,-1043; .loc 1 57 0 setp.le.s32 %r69,%r44,51; @ %r69 bra $L8; .loc 1 62 0 add.u32 %r70,%r57,-1075; shl.b32 %r71,%r47,%r70; cvt.u64.u32 %r72,%r71; .loc 1 60 0 cvt.u64.u32 %r73,%r41; shl.b64 %r74,%r73,%r50; or.b64 %r42,%r72,%r74; bra $L6; $L8: .loc 1 68 0 mov.u32 %r76,-2147483648; shr.u32 %r75,%r76,%r50; .loc 1 66 0 add.u32 %r46,%r75,%r47; .loc 1 69 0 setp.ge.u32 %r77,%r46,%r47; @ %r77 bra $L9; .loc 1 70 0 add.u32 %r41,%r41,1; $L9: .loc 1 72 0 cvt.u64.u32 %r78,%r41; shl.b64 %r42,%r78,%r50; .loc 1 74 0 mov.u32 %r79,52; sub.u32 %r38,%r79,%r44; setp.eq.u32 %r80,%r38,32; @ %r80 bra $L6; shr.u32 %r81,%r46,%r38; cvt.u64.u32 %r82,%r81; or.b64 %r42,%r42,%r82; bra $L6; $L7: .loc 1 79 0 cvt.rzi.s64.f64 %r51,%r52; bra $L1; $L6: .loc 1 81 0 cvt.s64.s32 %r83,%r43; mul.lo.u64 %r51,%r83,%r42; bra $L1; $L12: .loc 1 41 0 mov.u64 %r51,0; $L1: .loc 1 82 0 mov.u64 %value,%r51; st.param.u64 [%value_out],%value; ret; } lib_a-s_log1p.o/0 0 0 644 6645 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log1p .visible .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_log1p.c" // BEGIN GLOBAL FUNCTION DEF: log1p .visible .func (.param .f64 %value_out) log1p (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r22; .reg .u32 %r34; .reg .f64 %r36; .reg .f64 %r38; .reg .f64 %r50; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .f64 %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r69; .reg .f64 %r78; .reg .u64 %r80; .reg .u64 %r81; .reg .f64 %r82; .reg .f64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .pred %r89; .reg .f64 %r90; .reg .pred %r91; .reg .f64 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r97; .reg .u32 %r98; .reg .u16 %r99; .reg .u16 %r100; .reg .u16 %r101; .reg .u32 %r102; .reg .u16 %r103; .reg .pred %r104; .reg .f64 %r105; .reg .u32 %r107; .reg .pred %r108; .reg .f64 %r109; .reg .pred %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u32 %r113; .reg .pred %r114; .reg .f64 %r115; .reg .f64 %r116; .reg .f64 %r117; .reg .f64 %r118; .reg .u32 %r119; .reg .pred %r120; .reg .u32 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u32 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u32 %r131; .reg .f64 %r132; .reg .f64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .pred %r136; .reg .f64 %r137; .reg .f64 %r139; .reg .pred %r140; .reg .f64 %r141; .reg .f64 %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .f64 %r145; .reg .f64 %r146; .reg .f64 %r147; .reg .f64 %r148; .reg .f64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .pred %r153; .reg .f64 %r154; .reg .f64 %r155; .reg .f64 %r156; .reg .f64 %r157; .reg .f64 %r158; .reg .f64 %r159; mov.f64 %r83,%ar0; mov.b64 %r84,%r83; shr.u64 %r85,%r84,32; cvt.u32.u64 %r64,%r85; .loc 1 159 0 cvt.u32.u64 %r59,%r85; .loc 1 163 0 setp.le.s32 %r86,%r59,1071284857; @ %r86 bra $L2; .loc 1 178 0 setp.gt.s32 %r87,%r59,2146435071; @ ! %r87 bra $L22; bra $L3; $L2: .loc 1 160 0 and.b32 %r63,%r64,2147483647; .loc 1 164 0 setp.le.s32 %r88,%r63,1072693247; @ %r88 bra $L5; .loc 1 165 0 setp.neu.f64 %r89,%r83,0dbff0000000000000; @ %r89 bra $L6; mov.f64 %r90,0dc350000000000000; div.rn.f64 %r82,%r90,0d0000000000000000; bra $L1; $L6: .loc 1 166 0 sub.f64 %r22,%r83,%r83; div.rn.f64 %r82,%r22,%r22; bra $L1; $L5: .loc 1 168 0 setp.gt.s32 %r91,%r63,1042284543; @ %r91 bra $L8; .loc 1 169 0 add.f64 %r92,%r83,0d4350000000000000; set.u32.gt.f64 %r94,%r92,0d0000000000000000; neg.s32 %r95,%r94; .loc 1 170 0 set.u32.le.s32 %r97,%r63,1016070143; neg.s32 %r98,%r97; cvt.u16.u32 %r100,%r95; cvt.u16.u32 %r101,%r98; and.b16 %r99,%r100,%r101; cvt.u32.u16 %r102,%r99; cvt.u16.u8 %r103,%r102; setp.ne.u16 %r104,%r103,0; @ %r104 bra $L20; .loc 1 173 0 mul.f64 %r105,%r83,%r83; fma.rn.f64 %r82,%r105,0dbfe0000000000000,%r83; bra $L1; $L8: .loc 1 175 0 add.u32 %r107,%r64,1076707644; setp.le.u32 %r108,%r107,1076707644; @ %r108 bra $L9; .loc 1 202 0 mul.f64 %r109,%r83,0d3fe0000000000000; mul.f64 %r66,%r109,%r83; .loc 1 176 0 mov.u32 %r58,0; bra $L10; $L3: .loc 1 178 0 add.f64 %r82,%r83,%r83; bra $L1; $L22: .loc 1 180 0 setp.gt.s32 %r110,%r59,1128267775; @ %r110 bra $L11; $L9: .loc 1 181 0 add.f64 %r56,%r83,0d3ff0000000000000; .loc 1 182 0 mov.b64 %r111,%r56; shr.u64 %r112,%r111,32; cvt.u32.u64 %r59,%r112; .loc 1 183 0 shr.s32 %r113,%r59,20; add.u32 %r58,%r113,-1023; .loc 1 184 0 setp.le.s32 %r114,%r58,0; @ %r114 bra $L12; sub.f64 %r115,%r56,%r83; mov.f64 %r116,0d3ff0000000000000; sub.f64 %r61,%r116,%r115; bra $L13; $L12: mov.f64 %r118,0d3ff0000000000000; sub.f64 %r117,%r56,%r118; sub.f64 %r61,%r83,%r117; $L13: .loc 1 185 0 div.rn.f64 %r55,%r61,%r56; bra $L14; $L11: .loc 1 189 0 shr.s32 %r119,%r59,20; add.u32 %r58,%r119,-1023; .loc 1 187 0 mov.f64 %r56,%r83; .loc 1 190 0 mov.f64 %r55,0d0000000000000000; $L14: .loc 1 192 0 and.b32 %r60,%r59,1048575; .loc 1 193 0 setp.gt.s32 %r120,%r60,434333; @ %r120 bra $L15; .loc 1 194 0 mov.b64 %r80,%r56; or.b32 %r121,%r60,1072693248; cvt.u64.u32 %r122,%r121; shl.b64 %r123,%r122,32; and.b64 %r124,%r80,4294967295; or.b64 %r125,%r124,%r123; mov.b64 %r57,%r125; bra $L16; $L15: .loc 1 196 0 add.u32 %r58,%r58,1; .loc 1 197 0 mov.b64 %r81,%r56; or.b32 %r126,%r60,1071644672; cvt.u64.u32 %r127,%r126; shl.b64 %r128,%r127,32; and.b64 %r129,%r81,4294967295; or.b64 %r130,%r129,%r128; mov.b64 %r57,%r130; .loc 1 198 0 mov.u32 %r131,1048576; sub.u32 %r34,%r131,%r60; shr.s32 %r60,%r34,2; $L16: .loc 1 200 0 mov.f64 %r132,0d3ff0000000000000; sub.f64 %r83,%r57,%r132; .loc 1 202 0 mul.f64 %r133,%r83,0d3fe0000000000000; mul.f64 %r66,%r133,%r83; .loc 1 203 0 setp.ne.u32 %r134,%r60,0; @ %r134 bra $L10; .loc 1 204 0 setp.neu.f64 %r135,%r83,0d0000000000000000; @ %r135 bra $L17; setp.eq.u32 %r136,%r58,0; @ %r136 bra $L21; .loc 1 205 0 cvt.rn.f64.s32 %r36,%r58; fma.rn.f64 %r137,%r36,0d3dea39ef35793c76,%r55; fma.rn.f64 %r82,%r36,0d3fe62e42fee00000,%r137; bra $L1; $L17: .loc 1 206 0 fma.rn.f64 %r139,%r83,0dbfe5555555555555,0d3ff0000000000000; mul.f64 %r69,%r139,%r66; .loc 1 207 0 setp.ne.u32 %r140,%r58,0; @ %r140 bra $L18; sub.f64 %r82,%r83,%r69; bra $L1; $L18: .loc 1 208 0 cvt.rn.f64.s32 %r38,%r58; fma.rn.f64 %r141,%r38,0d3dea39ef35793c76,%r55; sub.f64 %r142,%r69,%r141; sub.f64 %r143,%r142,%r83; neg.f64 %r144,%r143; fma.rn.f64 %r82,%r38,0d3fe62e42fee00000,%r144; bra $L1; $L10: .loc 1 210 0 add.f64 %r145,%r83,0d4000000000000000; div.rn.f64 %r67,%r83,%r145; .loc 1 211 0 mul.f64 %r68,%r67,%r67; .loc 1 212 0 fma.rn.f64 %r146,%r68,0d3fc2f112df3e5244,0d3fc39a09d078c69f; fma.rn.f64 %r147,%r146,%r68,0d3fc7466496cb03de; fma.rn.f64 %r148,%r147,%r68,0d3fcc71c51d8e78af; fma.rn.f64 %r149,%r148,%r68,0d3fd2492494229359; fma.rn.f64 %r150,%r149,%r68,0d3fd999999997fa04; fma.rn.f64 %r151,%r150,%r68,0d3fe5555555555593; fma.rn.f64 %r152,%r151,%r68,%r66; mul.f64 %r78,%r152,%r67; .loc 1 213 0 setp.ne.u32 %r153,%r58,0; @ %r153 bra $L19; sub.f64 %r154,%r66,%r78; sub.f64 %r82,%r83,%r154; bra $L1; $L19: .loc 1 214 0 cvt.rn.f64.s32 %r50,%r58; fma.rn.f64 %r155,%r50,0d3dea39ef35793c76,%r55; add.f64 %r156,%r155,%r78; sub.f64 %r157,%r66,%r156; sub.f64 %r158,%r157,%r83; neg.f64 %r159,%r158; fma.rn.f64 %r82,%r50,0d3fe62e42fee00000,%r159; bra $L1; $L20: .loc 1 171 0 mov.f64 %r82,%r83; bra $L1; $L21: .loc 1 204 0 mov.f64 %r82,0d0000000000000000; $L1: .loc 1 215 0 mov.f64 %value,%r82; st.param.f64 [%value_out],%value; ret; } lib_a-s_log2.o/ 0 0 0 644 811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log2 .visible .func (.param .f64 %value_out) log2 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_log2.c" // BEGIN GLOBAL FUNCTION DECL: log .extern .func (.param .f64 %value_out) log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log2 .visible .func (.param .f64 %value_out) log2 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r24,%ar0; .loc 1 82 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),log,(%out_arg1); ld.param.f64 %r26,[%value_in]; } div.rn.f64 %value,%r26,0d3fe62e42fefa39ef; .loc 1 83 0 st.param.f64 [%value_out],%value; ret; } lib_a-s_logb.o/ 0 0 0 644 2352 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: logb .visible .func (.param .f64 %value_out) logb (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_logb.c" // BEGIN GLOBAL FUNCTION DEF: logb .visible .func (.param .f64 %value_out) logb (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r39; .reg .u32 %r40; .reg .f64 %r44; .reg .f64 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .pred %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r56; .reg .pred %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .u32 %r67; .reg .u16 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u32 %r71; .reg .u16 %r72; .reg .pred %r73; mov.f64 %r45,%ar0; .loc 1 88 0 mov.b64 %r46,%r45; shr.u64 %r47,%r46,32; cvt.u32.u64 %r36,%r47; cvt.u32.u64 %r34,%r46; .loc 1 89 0 and.b32 %r37,%r36,2147483647; .loc 1 90 0 setp.gt.s32 %r49,%r37,1048575; @ %r49 bra $L2; .loc 1 91 0 or.b32 %r50,%r34,%r37; setp.ne.u32 %r51,%r50,0; @ %r51 bra $L3; .loc 1 95 0 mov.f64 %r52,0dbff0000000000000; div.rn.f64 %r44,%r52,0d0000000000000000; bra $L1; $L3: .loc 1 98 0 setp.ne.u32 %r53,%r37,0; @ %r53 bra $L5; .loc 1 99 0 setp.le.s32 %r54,%r34,0; @ %r54 bra $L10; mov.u32 %r35,-1043; $L7: add.u32 %r35,%r35,-1; add.u32 %r34,%r34,%r34; setp.gt.s32 %r56,%r34,0; @ %r56 bra $L7; cvt.rn.f64.s32 %r44,%r35; bra $L1; $L5: .loc 1 101 0 shl.b32 %r40,%r37,11; mov.u32 %r39,-1022; $L8: add.u32 %r39,%r39,-1; add.u32 %r40,%r40,%r40; setp.gt.s32 %r58,%r40,0; @ %r58 bra $L8; cvt.rn.f64.s32 %r44,%r39; bra $L1; $L10: .loc 1 99 0 mov.f64 %r44,0dc0904c0000000000; .loc 1 103 0 bra $L1; $L2: .loc 1 105 0 setp.gt.s32 %r59,%r37,2146435071; @ %r59 bra $L9; shr.s32 %r60,%r37,20; add.u32 %r61,%r60,-1023; cvt.rn.f64.s32 %r44,%r61; bra $L1; $L9: .loc 1 106 0 set.u32.gt.s32 %r63,%r37,2146435072; neg.s32 %r64,%r63; set.u32.ne.u32 %r66,%r34,0; neg.s32 %r67,%r66; cvt.u16.u32 %r69,%r64; cvt.u16.u32 %r70,%r67; or.b16 %r68,%r69,%r70; cvt.u32.u16 %r71,%r68; cvt.u16.u8 %r72,%r71; setp.eq.u16 %r73,%r72,0; selp.f64 %r44,0d7ff0000000000000,%r45,%r73; $L1: .loc 1 108 0 mov.f64 %value,%r44; st.param.f64 [%value_out],%value; ret; } lib_a-s_lrint.o/0 0 0 644 4465 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lrint .visible .func (.param .u64 %value_out) lrint (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_lrint.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: TWO52 .const .align 8 .u64 TWO52[2] = {4841369599423283200,-4382002437431492608 }; // BEGIN GLOBAL FUNCTION DEF: lrint .visible .func (.param .u64 %value_out) lrint (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u32 %r22; .reg .u32 %r24; .reg .f64 %r25; .reg .f64 %r26; .reg .f64 %r27; .reg .f64 %r42; .reg .f64 %r43; .reg .f64 %r44; .reg .u32 %r46; .reg .u32 %r49; .reg .u32 %r54; .reg .f64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .u32 %r62; .reg .u32 %r64; .reg .u32 %r66; .reg .u64 %r71; .reg .f64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r81; .reg .f64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .pred %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u32 %r100; .reg .u64 %r101; .reg .u32 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r118; .reg .pred %r119; .reg .u32 %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .pred %r124; mov.f64 %r72,%ar0; mov.b64 %r73,%r72; shr.u64 %r74,%r73,32; cvt.u32.u64 %r66,%r74; .loc 1 97 0 shr.u32 %r22,%r66,31; .loc 1 100 0 shr.s32 %r75,%r66,20; and.b32 %r24,%r75,2047; add.u32 %r54,%r24,-1023; .loc 1 103 0 setp.gt.s32 %r76,%r54,19; @ %r76 bra $L2; .loc 1 106 0 setp.ge.s32 %r77,%r54,-1; @ %r77 bra $L3; $L5: .loc 1 107 0 mov.u64 %r71,0; bra $L1; $L3: .loc 1 112 0 cvta.const.u64 %r78,TWO52; cvt.s64.s32 %r79,%r22; shl.b64 %r80,%r79,3; add.u64 %r81,%r78,%r80; ld.f64 %r25,[%r81]; add.f64 %r26,%r25,%r72; st.f64 [%frame],%r26; .loc 1 113 0 ld.f64 %r27,[%frame]; sub.f64 %r82,%r27,%r25; .loc 1 114 0 mov.b64 %r83,%r82; shr.u64 %r84,%r83,32; cvt.u32.u64 %r62,%r84; .loc 1 117 0 cvt.s64.s32 %r85,%r62; and.b64 %r86,%r85,-2147483649; setp.eq.u64 %r87,%r86,0; @ %r87 bra $L5; .loc 1 121 0 and.b32 %r64,%r62,1048575; .loc 1 122 0 or.b32 %r88,%r64,1048576; .loc 1 120 0 shr.s32 %r89,%r62,20; and.b32 %r90,%r89,2047; .loc 1 124 0 mov.u32 %r93,1043; sub.u32 %r92,%r93,%r90; shr.s32 %r94,%r88,%r92; cvt.s64.s32 %r71,%r94; bra $L6; $L2: .loc 1 127 0 setp.gt.s32 %r95,%r54,62; @ %r95 bra $L7; .loc 1 131 0 setp.le.s32 %r96,%r54,51; @ %r96 bra $L8; .loc 1 134 0 and.b32 %r97,%r66,983039; or.b32 %r98,%r97,65536; cvt.s64.s32 %r99,%r98; add.u32 %r100,%r24,-1043; shl.b64 %r101,%r99,%r100; .loc 1 136 0 add.u32 %r103,%r24,-1075; cvt.u32.u64 %r105,%r73; shl.b32 %r104,%r105,%r103; cvt.u64.u32 %r106,%r104; .loc 1 134 0 or.b64 %r71,%r101,%r106; bra $L6; $L8: .loc 1 141 0 cvta.const.u64 %r107,TWO52; cvt.s64.s32 %r108,%r22; shl.b64 %r109,%r108,3; add.u64 %r110,%r107,%r109; ld.f64 %r42,[%r110]; add.f64 %r43,%r42,%r72; st.f64 [%frame],%r43; .loc 1 142 0 ld.f64 %r44,[%frame]; sub.f64 %r55,%r44,%r42; .loc 1 143 0 mov.b64 %r111,%r55; shr.u64 %r112,%r111,32; cvt.u32.u64 %r56,%r112; .loc 1 144 0 shr.s32 %r113,%r56,20; and.b32 %r46,%r113,2047; .loc 1 145 0 and.b32 %r58,%r56,1048575; .loc 1 146 0 or.b32 %r114,%r58,1048576; .loc 1 154 0 cvt.s64.s32 %r115,%r114; add.u32 %r116,%r46,-1043; shl.b64 %r71,%r115,%r116; .loc 1 155 0 mov.u32 %r118,1075; sub.u32 %r49,%r118,%r46; setp.gt.u32 %r119,%r49,31; @ %r119 bra $L6; cvt.u32.u64 %r122,%r111; shr.u32 %r121,%r122,%r49; cvt.u64.u32 %r123,%r121; or.b64 %r71,%r71,%r123; bra $L6; $L7: .loc 1 160 0 cvt.rzi.s64.f64 %r71,%r72; bra $L1; $L6: .loc 1 163 0 setp.eq.u32 %r124,%r22,0; @ %r124 bra $L1; neg.s64 %r71,%r71; $L1: .loc 1 164 0 mov.u64 %value,%r71; st.param.u64 [%value_out],%value; ret; } /661 0 0 0 644 2820 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lround .visible .func (.param .u64 %value_out) lround (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_lround.c" // BEGIN GLOBAL FUNCTION DEF: lround .visible .func (.param .u64 %value_out) lround (.param .f64 %in_ar0) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r38; .reg .u32 %r41; .reg .u64 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r50; .reg .u64 %r51; .reg .f64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .pred %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .pred %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .u64 %r82; .reg .u64 %r83; mov.f64 %r52,%ar0; mov.b64 %r53,%r52; shr.u64 %r54,%r53,32; cvt.u32.u64 %r30,%r54; .loc 1 69 0 setp.ge.s32 %r55,%r30,0; selp.u32 %r43,1,-1,%r55; .loc 1 71 0 shr.u32 %r56,%r30,20; and.b32 %r57,%r56,2047; add.u32 %r44,%r57,-1023; .loc 1 72 0 and.b32 %r45,%r30,1048575; .loc 1 73 0 or.b32 %r41,%r45,1048576; .loc 1 75 0 setp.gt.s32 %r58,%r44,19; @ %r58 bra $L3; .loc 1 78 0 setp.ge.s32 %r59,%r44,0; @ %r59 bra $L4; .loc 1 80 0 setp.ne.u32 %r60,%r44,-1; @ %r60 bra $L12; .loc 1 83 0 cvt.s64.s32 %r51,%r43; bra $L1; $L4: .loc 1 89 0 mov.u32 %r62,524288; shr.s32 %r61,%r62,%r44; add.u32 %r63,%r61,%r41; .loc 1 91 0 mov.u32 %r65,20; sub.u32 %r64,%r65,%r44; shr.u32 %r66,%r63,%r64; cvt.u64.u32 %r42,%r66; bra $L6; $L3: .loc 1 94 0 setp.gt.u32 %r67,%r44,62; @ %r67 bra $L7; cvt.u32.u64 %r47,%r53; add.u32 %r50,%r57,-1043; .loc 1 98 0 setp.le.s32 %r69,%r44,51; @ %r69 bra $L8; .loc 1 103 0 add.u32 %r70,%r57,-1075; shl.b32 %r71,%r47,%r70; cvt.u64.u32 %r72,%r71; .loc 1 101 0 cvt.u64.u32 %r73,%r41; shl.b64 %r74,%r73,%r50; or.b64 %r42,%r72,%r74; bra $L6; $L8: .loc 1 111 0 mov.u32 %r76,-2147483648; shr.u32 %r75,%r76,%r50; .loc 1 108 0 add.u32 %r46,%r75,%r47; .loc 1 112 0 setp.ge.u32 %r77,%r46,%r47; @ %r77 bra $L9; .loc 1 113 0 add.u32 %r41,%r41,1; $L9: .loc 1 116 0 cvt.u64.u32 %r78,%r41; shl.b64 %r42,%r78,%r50; .loc 1 119 0 mov.u32 %r79,52; sub.u32 %r38,%r79,%r44; setp.eq.u32 %r80,%r38,32; @ %r80 bra $L6; shr.u32 %r81,%r46,%r38; cvt.u64.u32 %r82,%r81; or.b64 %r42,%r42,%r82; bra $L6; $L7: .loc 1 124 0 cvt.rzi.s64.f64 %r51,%r52; bra $L1; $L6: .loc 1 126 0 cvt.s64.s32 %r83,%r43; mul.lo.u64 %r51,%r83,%r42; bra $L1; $L12: .loc 1 81 0 mov.u64 %r51,0; $L1: .loc 1 127 0 mov.u64 %value,%r51; st.param.u64 [%value_out],%value; ret; } /679 0 0 0 644 492 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: matherr .visible .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_matherr.c" // BEGIN GLOBAL FUNCTION DEF: matherr .visible .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; mov.u32 %value,0; .loc 1 123 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_modf.o/ 0 0 0 644 3141 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_modf.c" // BEGIN GLOBAL FUNCTION DEF: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r23; .reg .f64 %r32; .reg .u32 %r38; .reg .f64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .f64 %r52; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u64 %r62; .reg .u64 %r66; .reg .f64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u64 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .u32 %r96; .reg .u64 %r97; .reg .u64 %r101; .reg .u64 %r102; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; mov.f64 %r53,%ar0; mov.u64 %r54,%ar1; mov.b64 %r55,%r53; shr.u64 %r56,%r55,32; cvt.u32.u64 %r38,%r56; cvt.u32.u64 %r44,%r55; .loc 1 92 0 shr.s32 %r58,%r38,20; and.b32 %r23,%r58,2047; add.u32 %r42,%r23,-1023; .loc 1 93 0 setp.gt.s32 %r59,%r42,19; @ %r59 bra $L2; .loc 1 94 0 setp.ge.s32 %r60,%r42,0; @ %r60 bra $L3; .loc 1 95 0 and.b32 %r61,%r38,-2147483648; cvt.u64.u32 %r62,%r61; shl.b64 %r66,%r62,32; mov.b64 %r67,%r66; st.f64 [%r54],%r67; .loc 1 96 0 mov.f64 %r52,%r53; bra $L1; $L3: .loc 1 98 0 mov.u32 %r68,1048575; shr.s32 %r45,%r68,%r42; .loc 1 99 0 and.b32 %r69,%r38,%r45; or.b32 %r70,%r69,%r44; setp.ne.u32 %r71,%r70,0; @ %r71 bra $L5; .loc 1 101 0 st.f64 [%r54],%r53; .loc 1 103 0 and.b32 %r72,%r38,-2147483648; cvt.u64.u32 %r73,%r72; shl.b64 %r77,%r73,32; mov.b64 %r52,%r77; .loc 1 104 0 bra $L1; $L5: .loc 1 106 0 not.b32 %r78,%r45; and.b32 %r79,%r78,%r38; cvt.u64.u32 %r80,%r79; shl.b64 %r84,%r80,32; mov.b64 %r32,%r84; st.f64 [%r54],%r32; .loc 1 107 0 sub.f64 %r52,%r53,%r32; bra $L1; $L2: .loc 1 110 0 setp.le.s32 %r85,%r42,51; @ %r85 bra $L6; .loc 1 112 0 st.f64 [%r54],%r53; .loc 1 114 0 and.b32 %r86,%r38,-2147483648; cvt.u64.u32 %r87,%r86; shl.b64 %r91,%r87,32; mov.b64 %r52,%r91; .loc 1 115 0 bra $L1; $L6: .loc 1 117 0 add.u32 %r92,%r23,-1043; mov.u32 %r93,-1; shr.u32 %r43,%r93,%r92; .loc 1 118 0 and.b32 %r94,%r43,%r44; setp.ne.u32 %r95,%r94,0; @ %r95 bra $L7; .loc 1 120 0 st.f64 [%r54],%r53; .loc 1 122 0 and.b32 %r96,%r38,-2147483648; cvt.u64.u32 %r97,%r96; shl.b64 %r101,%r97,32; mov.b64 %r52,%r101; .loc 1 123 0 bra $L1; $L7: .loc 1 125 0 cvt.u64.u32 %r102,%r38; not.b32 %r106,%r43; and.b32 %r107,%r106,%r44; cvt.u64.u32 %r108,%r107; shl.b64 %r109,%r102,32; or.b64 %r110,%r109,%r108; mov.b64 %r40,%r110; st.f64 [%r54],%r40; .loc 1 126 0 sub.f64 %r52,%r53,%r40; $L1: .loc 1 129 0 mov.f64 %value,%r52; st.param.f64 [%value_out],%value; ret; } lib_a-s_nan.o/ 0 0 0 644 500 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_nan.c" // BEGIN GLOBAL FUNCTION DEF: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 49 0 mov.f64 %value,0d7ff8000000000000; .loc 1 50 0 st.param.f64 [%value_out],%value; ret; } /698 0 0 0 644 817 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nearbyint .visible .func (.param .f64 %value_out) nearbyint (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_nearbyint.c" // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nearbyint .visible .func (.param .f64 %value_out) nearbyint (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 61 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),rint,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 62 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } /719 0 0 0 644 5163 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nextafter .visible .func (.param .f64 %value_out) nextafter (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_nextafter.c" // BEGIN GLOBAL FUNCTION DEF: nextafter .visible .func (.param .f64 %value_out) nextafter (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .f64 %r47; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r62; .reg .u64 %r63; .reg .pred %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .pred %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r81; .reg .u64 %r82; .reg .pred %r83; .reg .pred %r84; .reg .pred %r85; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u16 %r94; .reg .u32 %r95; .reg .u16 %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r101; .reg .u32 %r102; .reg .u32 %r104; .reg .u32 %r105; .reg .u16 %r107; .reg .u16 %r108; .reg .u16 %r109; .reg .u32 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .u32 %r114; .reg .u32 %r115; .reg .u32 %r117; .reg .u32 %r118; .reg .u16 %r119; .reg .u16 %r120; .reg .u16 %r121; .reg .u32 %r122; .reg .u16 %r123; .reg .pred %r124; .reg .pred %r125; .reg .pred %r126; .reg .pred %r127; .reg .pred %r128; .reg .f64 %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r142; .reg .u64 %r143; .reg .u64 %r144; mov.f64 %r57,%ar0; mov.f64 %r58,%ar1; .loc 1 77 0 mov.b64 %r59,%r57; shr.u64 %r60,%r59,32; cvt.u32.u64 %r40,%r60; cvt.u32.u64 %r49,%r59; mov.b64 %r62,%r58; shr.u64 %r63,%r62,32; cvt.u32.u64 %r50,%r63; .loc 1 78 0 cvt.u32.u64 %r42,%r63; cvt.u32.u64 %r51,%r62; .loc 1 79 0 and.b32 %r43,%r40,2147483647; .loc 1 80 0 and.b32 %r44,%r50,2147483647; .loc 1 82 0 setp.le.s32 %r65,%r43,2146435071; @ %r65 bra $L2; add.u32 %r66,%r43,-2146435072; or.b32 %r67,%r66,%r49; setp.ne.u32 %r68,%r67,0; @ %r68 bra $L3; $L2: setp.le.s32 %r69,%r44,2146435071; @ %r69 bra $L4; .loc 1 83 0 add.u32 %r70,%r44,-2146435072; or.b32 %r71,%r70,%r51; setp.eq.u32 %r72,%r71,0; @ %r72 bra $L4; $L3: .loc 1 84 0 add.f64 %r56,%r57,%r58; bra $L1; $L4: .loc 1 85 0 setp.eq.f64 %r73,%r57,%r58; @ %r73 bra $L17; .loc 1 86 0 or.b32 %r74,%r43,%r49; setp.ne.u32 %r75,%r74,0; @ %r75 bra $L6; .loc 1 87 0 and.b32 %r76,%r50,-2147483648; cvt.u64.u32 %r77,%r76; shl.b64 %r81,%r77,32; or.b64 %r82,%r81,1; mov.b64 %r56,%r82; .loc 1 88 0 mul.f64 %r47,%r56,%r56; .loc 1 89 0 setp.neu.f64 %r83,%r56,%r47; selp.f64 %r56,%r56,%r47,%r83; bra $L1; $L6: .loc 1 91 0 setp.lt.s32 %r84,%r40,0; @ %r84 bra $L7; .loc 1 92 0 setp.gt.s32 %r85,%r40,%r42; @ %r85 bra $L8; set.u32.eq.u32 %r87,%r40,%r42; neg.s32 %r88,%r87; set.u32.gt.u32 %r90,%r49,%r51; neg.s32 %r91,%r90; cvt.u16.u32 %r93,%r88; cvt.u16.u32 %r94,%r91; and.b16 %r92,%r93,%r94; cvt.u32.u16 %r95,%r92; cvt.u16.u8 %r96,%r95; setp.ne.u16 %r97,%r96,0; @ %r97 bra $L9; bra $L21; $L8: .loc 1 93 0 setp.ne.u32 %r98,%r49,0; @ %r98 bra $L9; add.u32 %r40,%r40,-1; $L9: .loc 1 94 0 add.u32 %r41,%r49,-1; bra $L11; $L21: .loc 1 96 0 add.u32 %r41,%r49,1; .loc 1 97 0 setp.ne.u32 %r99,%r41,0; @ %r99 bra $L11; add.u32 %r40,%r40,1; bra $L11; $L7: .loc 1 100 0 not.b32 %r101,%r42; shr.u32 %r102,%r101,31; set.u32.gt.s32 %r104,%r40,%r42; neg.s32 %r105,%r104; cvt.u16.u32 %r108,%r102; cvt.u16.u32 %r109,%r105; or.b16 %r107,%r108,%r109; cvt.u32.u16 %r110,%r107; cvt.u16.u8 %r111,%r110; setp.ne.u16 %r112,%r111,0; @ %r112 bra $L12; set.u32.eq.u32 %r114,%r40,%r42; neg.s32 %r115,%r114; set.u32.gt.u32 %r117,%r49,%r51; neg.s32 %r118,%r117; cvt.u16.u32 %r120,%r115; cvt.u16.u32 %r121,%r118; and.b16 %r119,%r120,%r121; cvt.u32.u16 %r122,%r119; cvt.u16.u8 %r123,%r122; setp.ne.u16 %r124,%r123,0; @ %r124 bra $L13; bra $L22; $L12: .loc 1 101 0 setp.ne.u32 %r125,%r49,0; @ %r125 bra $L13; add.u32 %r40,%r40,-1; $L13: .loc 1 102 0 add.u32 %r41,%r49,-1; bra $L11; $L22: .loc 1 104 0 add.u32 %r41,%r49,1; .loc 1 105 0 setp.ne.u32 %r126,%r41,0; @ %r126 bra $L11; add.u32 %r40,%r40,1; $L11: .loc 1 108 0 and.b32 %r45,%r40,2146435072; .loc 1 109 0 setp.ne.u32 %r127,%r45,2146435072; @ %r127 bra $L15; add.f64 %r56,%r57,%r57; bra $L1; $L15: .loc 1 110 0 setp.gt.s32 %r128,%r45,1048575; @ %r128 bra $L16; .loc 1 111 0 mul.f64 %r129,%r57,%r57; .loc 1 112 0 setp.eq.f64 %r130,%r57,%r129; @ %r130 bra $L16; .loc 1 113 0 cvt.u64.u32 %r131,%r40; cvt.u64.u32 %r135,%r41; shl.b64 %r136,%r131,32; or.b64 %r137,%r136,%r135; mov.b64 %r56,%r137; .loc 1 114 0 bra $L1; $L16: .loc 1 117 0 cvt.u64.u32 %r138,%r40; cvt.u64.u32 %r142,%r41; shl.b64 %r143,%r138,32; or.b64 %r144,%r143,%r142; mov.b64 %r56,%r144; .loc 1 118 0 bra $L1; $L17: .loc 1 85 0 mov.f64 %r56,%r57; $L1: .loc 1 119 0 mov.f64 %value,%r56; st.param.f64 [%value_out],%value; ret; } lib_a-s_pow10.o/0 0 0 644 928 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: pow10 .visible .func (.param .f64 %value_out) pow10 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_pow10.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: pow10 .visible .func (.param .f64 %value_out) pow10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r23,%ar0; .loc 1 76 0 mov.f64 %r24,0d4024000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r23; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 77 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } /740 0 0 0 644 12385 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remquo .visible .func (.param .f64 %value_out) remquo (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/common/s_remquo.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN VAR DEF: Zero .const .align 8 .u64 Zero[2] = {0,-9223372036854775808 }; // BEGIN GLOBAL FUNCTION DEF: remquo .visible .func (.param .f64 %value_out) remquo (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r39; .reg .f64 %r46; .reg .u32 %r54; .reg .u32 %r62; .reg .u32 %r87; .reg .u32 %r90; .reg .u32 %r97; .reg .f64 %r101; .reg .f64 %r103; .reg .f64 %r108; .reg .u32 %r109; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .u32 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .u32 %r133; .reg .u32 %r134; .reg .u32 %r136; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r147; .reg .u64 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .u64 %r153; .reg .u64 %r154; .reg .u64 %r155; .reg .u64 %r156; .reg .u64 %r157; .reg .u32 %r159; .reg .u32 %r161; .reg .u32 %r162; .reg .u32 %r164; .reg .u32 %r165; .reg .u16 %r166; .reg .u16 %r167; .reg .u16 %r168; .reg .u32 %r169; .reg .u16 %r170; .reg .pred %r171; .reg .u32 %r172; .reg .u32 %r173; .reg .u32 %r174; .reg .u32 %r175; .reg .pred %r176; .reg .u32 %r177; .reg .pred %r179; .reg .u32 %r181; .reg .u32 %r182; .reg .u32 %r184; .reg .u32 %r185; .reg .u16 %r186; .reg .u16 %r187; .reg .u16 %r188; .reg .u32 %r189; .reg .u16 %r190; .reg .pred %r191; .reg .pred %r192; .reg .pred %r193; .reg .u64 %r194; .reg .u32 %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u64 %r198; .reg .pred %r199; .reg .pred %r200; .reg .pred %r201; .reg .pred %r203; .reg .pred %r205; .reg .u32 %r206; .reg .pred %r207; .reg .pred %r208; .reg .pred %r209; .reg .pred %r211; .reg .pred %r213; .reg .u32 %r214; .reg .pred %r215; .reg .u32 %r216; .reg .pred %r217; .reg .u32 %r218; .reg .u32 %r219; .reg .u32 %r220; .reg .u32 %r221; .reg .u32 %r222; .reg .u32 %r224; .reg .pred %r225; .reg .u32 %r226; .reg .u32 %r227; .reg .u32 %r228; .reg .u32 %r229; .reg .u32 %r230; .reg .pred %r231; .reg .pred %r232; .reg .pred %r233; .reg .pred %r234; .reg .u32 %r235; .reg .u32 %r236; .reg .u32 %r238; .reg .u32 %r239; .reg .pred %r242; .reg .pred %r243; .reg .pred %r244; .reg .u32 %r245; .reg .pred %r246; .reg .pred %r247; .reg .pred %r248; .reg .u64 %r249; .reg .u32 %r250; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .u32 %r254; .reg .u32 %r255; .reg .pred %r257; .reg .u32 %r259; .reg .u32 %r260; .reg .u32 %r261; .reg .pred %r262; .reg .u32 %r263; .reg .u32 %r264; .reg .pred %r265; .reg .u32 %r266; .reg .u32 %r267; .reg .u32 %r268; .reg .u32 %r269; .reg .u64 %r270; .reg .u64 %r274; .reg .u64 %r275; .reg .u64 %r276; .reg .f64 %r278; .reg .pred %r279; .reg .pred %r280; .reg .pred %r281; .reg .u32 %r282; .reg .pred %r283; .reg .pred %r284; .reg .pred %r285; .reg .u32 %r286; .reg .pred %r287; .reg .u64 %r289; .reg .u32 %r290; .reg .u32 %r291; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u64 %r295; .reg .pred %r296; .reg .pred %r298; mov.f64 %r151,%ar0; mov.f64 %r152,%ar1; mov.u64 %r153,%ar2; .loc 1 88 0 mov.b64 %r154,%r151; shr.u64 %r155,%r154,32; cvt.u32.u64 %r121,%r155; .loc 1 89 0 mov.b64 %r156,%r152; shr.u64 %r157,%r156,32; cvt.u32.u64 %r122,%r157; cvt.u32.u64 %r116,%r156; .loc 1 92 0 and.b32 %r110,%r121,2147483647; .loc 1 93 0 and.b32 %r124,%r122,2147483647; .loc 1 96 0 or.b32 %r159,%r124,%r116; set.u32.eq.u32 %r161,%r159,0; neg.s32 %r162,%r161; set.u32.gt.s32 %r164,%r110,2146435071; neg.s32 %r165,%r164; cvt.u16.u32 %r167,%r162; cvt.u16.u32 %r168,%r165; or.b16 %r166,%r167,%r168; cvt.u32.u16 %r169,%r166; cvt.u16.u8 %r170,%r169; setp.ne.u16 %r171,%r170,0; @ %r171 bra $L2; .loc 1 97 0 neg.s32 %r172,%r116; or.b32 %r173,%r172,%r116; shr.u32 %r174,%r173,31; or.b32 %r175,%r174,%r124; .loc 1 96 0 setp.le.u32 %r176,%r175,2146435072; @ %r176 bra $L3; $L2: .loc 1 98 0 mov.u32 %r177,0; st.u32 [%r153],%r177; .loc 1 99 0 mul.f64 %r46,%r151,%r152; div.rn.f64 %r150,%r46,%r46; bra $L1; $L3: cvt.u32.u64 %r115,%r154; .loc 1 90 0 xor.b32 %r39,%r121,%r122; .loc 1 91 0 and.b32 %r123,%r121,-2147483648; .loc 1 101 0 setp.gt.s32 %r179,%r110,%r124; @ %r179 bra $L5; .loc 1 102 0 set.u32.lt.s32 %r181,%r110,%r124; neg.s32 %r182,%r181; set.u32.lt.u32 %r184,%r115,%r116; neg.s32 %r185,%r184; cvt.u16.u32 %r187,%r182; cvt.u16.u32 %r188,%r185; or.b16 %r186,%r187,%r188; cvt.u32.u16 %r189,%r186; cvt.u16.u8 %r190,%r189; setp.ne.u16 %r191,%r190,0; @ %r191 bra $L48; .loc 1 106 0 setp.ne.u32 %r192,%r115,%r116; @ %r192 bra $L5; .loc 1 107 0 setp.ge.s32 %r193,%r39,0; selp.u32 %r118,1,-1,%r193; st.u32 [%r153],%r118; .loc 1 108 0 cvta.const.u64 %r194,Zero; shr.u32 %r195,%r123,31; cvt.u64.u32 %r196,%r195; shl.b64 %r197,%r196,3; add.u64 %r198,%r194,%r197; ld.f64 %r150,[%r198]; bra $L1; $L5: .loc 1 113 0 setp.gt.s32 %r199,%r110,1048575; @ %r199 bra $L8; .loc 1 114 0 setp.ne.u32 %r200,%r110,0; @ %r200 bra $L9; .loc 1 115 0 mov.u32 %r127,%r115; setp.le.s32 %r201,%r115,0; @ %r201 bra $L50; mov.u32 %r125,-1043; $L11: add.u32 %r125,%r125,-1; add.u32 %r127,%r127,%r127; setp.gt.s32 %r203,%r127,0; @ %r203 bra $L11; bra $L10; $L9: .loc 1 117 0 shl.b32 %r126,%r110,11; mov.u32 %r125,-1022; $L12: add.u32 %r125,%r125,-1; add.u32 %r126,%r126,%r126; setp.gt.s32 %r205,%r126,0; @ %r205 bra $L12; bra $L10; $L8: .loc 1 119 0 shr.s32 %r206,%r110,20; add.u32 %r125,%r206,-1023; bra $L10; $L50: .loc 1 115 0 mov.u32 %r125,-1043; $L10: .loc 1 122 0 setp.gt.s32 %r207,%r124,1048575; @ %r207 bra $L13; .loc 1 123 0 setp.ne.u32 %r208,%r124,0; @ %r208 bra $L14; .loc 1 124 0 mov.u32 %r130,%r116; setp.le.s32 %r209,%r116,0; @ %r209 bra $L51; mov.u32 %r138,-1043; $L16: add.u32 %r138,%r138,-1; add.u32 %r130,%r130,%r130; setp.gt.s32 %r211,%r130,0; @ %r211 bra $L16; bra $L15; $L14: .loc 1 126 0 shl.b32 %r129,%r124,11; mov.u32 %r138,-1022; $L17: add.u32 %r138,%r138,-1; add.u32 %r129,%r129,%r129; setp.gt.s32 %r213,%r129,0; @ %r213 bra $L17; bra $L15; $L13: .loc 1 128 0 shr.s32 %r214,%r124,20; add.u32 %r138,%r214,-1023; bra $L15; $L51: .loc 1 124 0 mov.u32 %r138,-1043; $L15: .loc 1 131 0 setp.lt.s32 %r215,%r125,-1022; @ %r215 bra $L18; .loc 1 132 0 and.b32 %r54,%r121,1048575; or.b32 %r109,%r54,1048576; bra $L19; $L18: .loc 1 134 0 mov.u32 %r216,-1022; sub.u32 %r131,%r216,%r125; .loc 1 135 0 setp.gt.s32 %r217,%r131,31; @ %r217 bra $L20; .loc 1 136 0 add.u32 %r218,%r125,1054; shr.u32 %r219,%r115,%r218; shl.b32 %r220,%r110,%r131; or.b32 %r109,%r219,%r220; .loc 1 137 0 shl.b32 %r115,%r115,%r131; bra $L19; $L20: .loc 1 139 0 mov.u32 %r222,-1054; sub.u32 %r221,%r222,%r125; shl.b32 %r109,%r115,%r221; .loc 1 140 0 mov.u32 %r115,0; $L19: .loc 1 143 0 setp.lt.s32 %r298,%r138,-1022; @ %r298 bra $L21; .loc 1 144 0 and.b32 %r62,%r122,1048575; or.b32 %r111,%r62,1048576; sub.u32 %r144,%r115,%r116; bra $L22; $L21: .loc 1 146 0 mov.u32 %r224,-1022; sub.u32 %r133,%r224,%r138; .loc 1 147 0 setp.gt.s32 %r225,%r133,31; @ %r225 bra $L23; .loc 1 148 0 add.u32 %r226,%r138,1054; shr.u32 %r227,%r116,%r226; shl.b32 %r228,%r124,%r133; or.b32 %r111,%r227,%r228; .loc 1 149 0 shl.b32 %r116,%r116,%r133; sub.u32 %r144,%r115,%r116; bra $L22; $L23: .loc 1 151 0 mov.u32 %r230,-1054; sub.u32 %r229,%r230,%r138; shl.b32 %r111,%r116,%r229; .loc 1 157 0 sub.u32 %r147,%r125,%r138; .loc 1 159 0 add.u32 %r136,%r147,-1; setp.ne.u32 %r231,%r147,0; @ %r231 bra $L52; bra $L68; $L22: .loc 1 157 0 sub.u32 %r134,%r125,%r138; .loc 1 159 0 add.u32 %r136,%r134,-1; setp.eq.u32 %r232,%r134,0; @ ! %r232 bra $L24; bra $L53; $L52: .loc 1 152 0 mov.u32 %r116,0; $L24: mov.u32 %r117,0; $L30: .loc 1 160 0 sub.u32 %r112,%r109,%r111; setp.ge.u32 %r233,%r115,%r116; @ %r233 bra $L27; add.u32 %r112,%r112,-1; $L27: .loc 1 161 0 setp.ge.s32 %r234,%r112,0; @ %r234 bra $L28; add.u32 %r235,%r109,%r109; shr.u32 %r236,%r115,31; add.u32 %r109,%r235,%r236; add.u32 %r115,%r115,%r115; bra $L29; $L28: .loc 1 160 0 sub.u32 %r140,%r115,%r116; .loc 1 162 0 add.u32 %r238,%r112,%r112; shr.u32 %r239,%r140,31; add.u32 %r109,%r238,%r239; add.u32 %r115,%r140,%r140; add.u32 %r117,%r117,1; $L29: .loc 1 163 0 add.u32 %r117,%r117,%r117; .loc 1 159 0 add.u32 %r136,%r136,-1; setp.ne.u32 %r242,%r136,-1; @ %r242 bra $L30; sub.u32 %r144,%r115,%r116; bra $L26; $L53: .loc 1 158 0 mov.u32 %r117,%r134; $L26: .loc 1 165 0 sub.u32 %r113,%r109,%r111; setp.ge.u32 %r243,%r115,%r116; @ %r243 bra $L31; add.u32 %r113,%r113,-1; $L31: .loc 1 166 0 setp.lt.s32 %r244,%r113,0; @ %r244 bra $L32; add.u32 %r117,%r117,1; mov.u32 %r115,%r144; mov.u32 %r109,%r113; $L32: .loc 1 169 0 or.b32 %r245,%r109,%r115; setp.eq.u32 %r246,%r245,0; @ %r246 bra $L33; .loc 1 174 0 setp.le.s32 %r247,%r109,1048575; @ %r247 bra $L34; bra $L35; $L33: .loc 1 170 0 and.b32 %r139,%r117,2147483647; .loc 1 171 0 setp.ge.s32 %r248,%r39,0; @ %r248 bra $L36; neg.s32 %r119,%r139; bra $L37; $L36: mov.u32 %r119,%r139; $L37: st.u32 [%r153],%r119; .loc 1 172 0 cvta.const.u64 %r249,Zero; shr.u32 %r250,%r123,31; cvt.u64.u32 %r251,%r250; shl.b64 %r252,%r251,3; add.u64 %r253,%r249,%r252; ld.f64 %r150,[%r253]; bra $L1; $L34: .loc 1 175 0 add.u32 %r254,%r109,%r109; shr.u32 %r255,%r115,31; add.u32 %r109,%r254,%r255; add.u32 %r115,%r115,%r115; .loc 1 176 0 add.u32 %r138,%r138,-1; .loc 1 174 0 setp.le.s32 %r257,%r109,1048575; @ %r257 bra $L34; setp.lt.s32 %r298,%r138,-1022; $L35: .loc 1 178 0 @ %r298 bra $L38; .loc 1 179 0 add.u32 %r87,%r109,-1048576; add.u32 %r259,%r138,1023; shl.b32 %r260,%r259,20; or.b32 %r110,%r260,%r87; bra $L6; $L38: .loc 1 181 0 mov.u32 %r261,-1022; sub.u32 %r137,%r261,%r138; .loc 1 182 0 setp.gt.s32 %r262,%r137,20; @ %r262 bra $L39; .loc 1 183 0 shr.u32 %r90,%r115,%r137; add.u32 %r263,%r138,1054; shl.b32 %r264,%r109,%r263; or.b32 %r115,%r264,%r90; .loc 1 184 0 shr.s32 %r110,%r109,%r137; bra $L6; $L39: .loc 1 185 0 setp.gt.s32 %r265,%r137,31; @ %r265 bra $L40; .loc 1 186 0 shr.u32 %r97,%r115,%r137; add.u32 %r266,%r138,1054; shl.b32 %r267,%r109,%r266; or.b32 %r115,%r267,%r97; mov.u32 %r110,%r123; bra $L6; $L40: .loc 1 188 0 mov.u32 %r269,-1054; sub.u32 %r268,%r269,%r138; shr.s32 %r115,%r109,%r268; mov.u32 %r110,%r123; bra $L6; $L48: .loc 1 103 0 mov.u32 %r117,0; $L6: .loc 1 192 0 cvt.u64.u32 %r270,%r110; cvt.u64.u32 %r274,%r115; shl.b64 %r275,%r270,32; or.b64 %r276,%r275,%r274; mov.b64 %r108,%r276; .loc 1 193 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r152; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r278,[%value_in]; } .loc 1 194 0 setp.lt.f64 %r279,%r278,0d0020000000000000; @ ! %r279 bra $L69; .loc 1 195 0 add.f64 %r101,%r108,%r108; setp.gt.f64 %r280,%r101,%r278; @ %r280 bra $L43; setp.neu.f64 %r281,%r101,%r278; @ %r281 bra $L44; and.b32 %r282,%r117,1; setp.eq.u32 %r283,%r282,0; @ %r283 bra $L44; $L43: .loc 1 196 0 add.u32 %r117,%r117,1; .loc 1 197 0 sub.f64 %r108,%r108,%r278; bra $L44; $L69: .loc 1 199 0 mul.f64 %r103,%r278,0d3fe0000000000000; setp.lt.f64 %r284,%r103,%r108; @ %r284 bra $L45; setp.neu.f64 %r285,%r103,%r108; @ %r285 bra $L44; and.b32 %r286,%r117,1; setp.eq.u32 %r287,%r286,0; @ %r287 bra $L44; $L45: .loc 1 200 0 add.u32 %r117,%r117,1; .loc 1 201 0 sub.f64 %r108,%r108,%r278; $L44: .loc 1 204 0 mov.b64 %r149,%r108; .loc 1 203 0 shr.u64 %r289,%r149,32; .loc 1 204 0 cvt.u32.u64 %r291,%r289; xor.b32 %r290,%r123,%r291; cvt.u64.u32 %r292,%r290; shl.b64 %r293,%r292,32; and.b64 %r294,%r149,4294967295; or.b64 %r295,%r294,%r293; mov.b64 %r150,%r295; .loc 1 205 0 and.b32 %r143,%r117,2147483647; .loc 1 206 0 setp.ge.s32 %r296,%r39,0; @ %r296 bra $L46; neg.s32 %r120,%r143; bra $L47; $L46: mov.u32 %r120,%r143; $L47: st.u32 [%r153],%r120; .loc 1 207 0 bra $L1; $L68: .loc 1 165 0 sub.u32 %r113,%r109,%r111; mov.u32 %r144,%r115; .loc 1 158 0 mov.u32 %r117,%r147; bra $L31; $L1: .loc 1 208 0 mov.f64 %value,%r150; st.param.f64 [%value_out],%value; ret; } lib_a-s_rint.o/ 0 0 0 644 5373 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rint .visible .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_rint.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: TWO52 .const .align 8 .u64 TWO52[2] = {4841369599423283200,-4382002437431492608 }; // BEGIN GLOBAL FUNCTION DEF: rint .visible .func (.param .f64 %value_out) rint (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u32 %r24; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .u32 %r42; .reg .u32 %r45; .reg .u32 %r53; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r72; .reg .f64 %r74; .reg .f64 %r75; .reg .f64 %r77; .reg .u64 %r79; .reg .f64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u32 %r86; .reg .pred %r87; .reg .pred %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r108; .reg .u32 %r109; .reg .u32 %r110; .reg .u32 %r111; .reg .u32 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .pred %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .pred %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .pred %r133; .reg .u32 %r134; .reg .pred %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .u64 %r144; .reg .u64 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u64 %r148; .reg .u64 %r149; .reg .u64 %r150; mov.f64 %r82,%ar0; mov.b64 %r83,%r82; shr.u64 %r84,%r83,32; cvt.u32.u64 %r42,%r84; .loc 1 93 0 cvt.u32.u64 %r64,%r84; cvt.u32.u64 %r45,%r83; .loc 1 94 0 shr.u32 %r65,%r42,31; .loc 1 95 0 shr.s32 %r86,%r42,20; and.b32 %r24,%r86,2047; add.u32 %r66,%r24,-1023; .loc 1 96 0 setp.gt.s32 %r87,%r66,19; @ %r87 bra $L2; .loc 1 97 0 setp.ge.s32 %r88,%r66,0; @ %r88 bra $L3; .loc 1 98 0 and.b32 %r89,%r42,2147483647; or.b32 %r90,%r89,%r45; setp.eq.u32 %r91,%r90,0; @ %r91 bra $L4; .loc 1 99 0 and.b32 %r92,%r42,1048575; or.b32 %r72,%r92,%r45; .loc 1 101 0 neg.s32 %r93,%r72; or.b32 %r94,%r93,%r72; shr.u32 %r95,%r94,12; and.b32 %r96,%r95,524288; .loc 1 100 0 and.b32 %r97,%r42,-131072; .loc 1 101 0 or.b32 %r98,%r96,%r97; .loc 1 102 0 cvt.u64.u32 %r99,%r98; shl.b64 %r100,%r99,32; and.b64 %r101,%r83,4294967295; or.b64 %r102,%r101,%r100; mov.b64 %r74,%r102; .loc 1 103 0 cvta.const.u64 %r103,TWO52; cvt.s64.s32 %r104,%r65; shl.b64 %r105,%r104,3; add.u64 %r106,%r103,%r105; ld.f64 %r34,[%r106]; add.f64 %r35,%r34,%r74; st.f64 [%frame],%r35; .loc 1 104 0 ld.f64 %r36,[%frame]; sub.f64 %r75,%r36,%r34; .loc 1 106 0 mov.b64 %r79,%r75; .loc 1 105 0 shr.u64 %r108,%r79,32; .loc 1 106 0 cvt.u32.u64 %r110,%r108; and.b32 %r109,%r110,2147483647; shl.b32 %r111,%r65,31; or.b32 %r112,%r109,%r111; cvt.u64.u32 %r113,%r112; shl.b64 %r114,%r113,32; and.b64 %r115,%r79,4294967295; or.b64 %r116,%r115,%r114; mov.b64 %r82,%r116; .loc 1 107 0 bra $L4; $L3: .loc 1 109 0 mov.u32 %r117,1048575; shr.s32 %r69,%r117,%r66; .loc 1 110 0 and.b32 %r118,%r64,%r69; or.b32 %r119,%r118,%r45; setp.eq.u32 %r120,%r119,0; @ %r120 bra $L4; .loc 1 111 0 shr.u32 %r70,%r69,1; .loc 1 112 0 and.b32 %r121,%r64,%r70; or.b32 %r122,%r121,%r45; setp.eq.u32 %r123,%r122,0; @ %r123 bra $L8; .loc 1 114 0 setp.eq.u32 %r124,%r66,19; selp.u32 %r45,-2147483648,0,%r124; .loc 1 115 0 not.b32 %r125,%r70; and.b32 %r126,%r125,%r64; mov.u32 %r128,262144; shr.s32 %r127,%r128,%r66; or.b32 %r64,%r126,%r127; bra $L5; $L2: .loc 1 118 0 setp.le.s32 %r129,%r66,51; @ %r129 bra $L7; .loc 1 119 0 setp.ne.u32 %r130,%r66,1024; @ %r130 bra $L4; add.f64 %r82,%r82,%r82; bra $L4; $L7: .loc 1 122 0 add.u32 %r53,%r24,-1043; mov.u32 %r131,-1; shr.u32 %r67,%r131,%r53; .loc 1 123 0 and.b32 %r132,%r45,%r67; setp.eq.u32 %r133,%r132,0; @ %r133 bra $L4; .loc 1 124 0 shr.u32 %r68,%r67,1; .loc 1 125 0 and.b32 %r134,%r45,%r68; setp.eq.u32 %r135,%r134,0; @ %r135 bra $L5; not.b32 %r136,%r68; and.b32 %r137,%r136,%r45; mov.u32 %r139,1073741824; shr.s32 %r138,%r139,%r53; or.b32 %r45,%r137,%r138; bra $L5; $L8: mov.u32 %r45,%r122; $L5: .loc 1 127 0 cvt.u64.u32 %r140,%r64; cvt.u64.u32 %r144,%r45; shl.b64 %r145,%r140,32; or.b64 %r146,%r145,%r144; mov.b64 %r77,%r146; .loc 1 128 0 cvta.const.u64 %r147,TWO52; cvt.s64.s32 %r148,%r65; shl.b64 %r149,%r148,3; add.u64 %r150,%r147,%r149; ld.f64 %r61,[%r150]; add.f64 %r62,%r61,%r77; st.f64 [%frame],%r62; .loc 1 129 0 ld.f64 %r63,[%frame]; sub.f64 %r82,%r63,%r61; $L4: .loc 1 130 0 mov.f64 %value,%r82; st.param.f64 [%value_out],%value; ret; } lib_a-s_round.o/0 0 0 644 2845 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: round .visible .func (.param .f64 %value_out) round (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_round.c" // BEGIN GLOBAL FUNCTION DEF: round .visible .func (.param .f64 %value_out) round (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r25; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r45; .reg .f64 %r48; .reg .f64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .pred %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r81; .reg .u64 %r82; .reg .u64 %r83; mov.f64 %r49,%ar0; mov.b64 %r50,%r49; shr.u64 %r51,%r50,32; .loc 1 59 0 cvt.u32.u64 %r39,%r51; cvt.u32.u64 %r25,%r50; .loc 1 62 0 shr.s32 %r53,%r39,20; and.b32 %r23,%r53,2047; add.u32 %r41,%r23,-1023; .loc 1 64 0 setp.gt.s32 %r54,%r41,19; @ %r54 bra $L2; .loc 1 66 0 setp.ge.s32 %r55,%r41,0; @ %r55 bra $L3; .loc 1 68 0 and.b32 %r39,%r39,-2147483648; .loc 1 69 0 setp.ne.u32 %r56,%r41,-1; @ %r56 bra $L8; .loc 1 71 0 or.b32 %r39,%r39,1072693248; .loc 1 72 0 mov.u32 %r40,0; bra $L4; $L3: .loc 1 76 0 mov.u32 %r57,1048575; shr.s32 %r45,%r57,%r41; .loc 1 77 0 and.b32 %r58,%r39,%r45; or.b32 %r59,%r58,%r25; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L9; .loc 1 81 0 mov.u32 %r62,524288; shr.s32 %r61,%r62,%r41; add.u32 %r63,%r61,%r39; .loc 1 82 0 not.b32 %r64,%r45; and.b32 %r39,%r63,%r64; .loc 1 83 0 mov.u32 %r40,0; bra $L4; $L2: .loc 1 86 0 setp.le.s32 %r65,%r41,51; @ %r65 bra $L6; .loc 1 88 0 setp.ne.u32 %r66,%r41,1024; @ %r66 bra $L10; .loc 1 90 0 add.f64 %r48,%r49,%r49; bra $L1; $L6: .loc 1 96 0 add.u32 %r67,%r23,-1043; mov.u32 %r68,-1; shr.u32 %r42,%r68,%r67; .loc 1 99 0 and.b32 %r69,%r25,%r42; setp.eq.u32 %r70,%r69,0; @ %r70 bra $L11; .loc 1 103 0 mov.u32 %r72,51; sub.u32 %r71,%r72,%r41; mov.u32 %r74,1; shl.b32 %r73,%r74,%r71; add.u32 %r43,%r73,%r25; .loc 1 104 0 setp.le.u32 %r75,%r25,%r43; @ %r75 bra $L7; .loc 1 105 0 add.u32 %r39,%r39,1; $L7: .loc 1 108 0 not.b32 %r76,%r42; and.b32 %r40,%r76,%r43; bra $L4; $L8: .loc 1 72 0 mov.u32 %r40,0; $L4: .loc 1 110 0 cvt.u64.u32 %r77,%r39; cvt.u64.u32 %r81,%r40; shl.b64 %r82,%r77,32; or.b64 %r83,%r82,%r81; mov.b64 %r48,%r83; .loc 1 112 0 bra $L1; $L9: .loc 1 79 0 mov.f64 %r48,%r49; bra $L1; $L10: mov.f64 %r48,%r49; bra $L1; $L11: mov.f64 %r48,%r49; $L1: .loc 1 113 0 mov.f64 %value,%r48; st.param.f64 [%value_out],%value; ret; } /758 0 0 0 644 4365 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbln .visible .func (.param .f64 %value_out) scalbln (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_scalbln.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbln .visible .func (.param .f64 %value_out) scalbln (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r29; .reg .u32 %r48; .reg .u32 %r50; .reg .f64 %r53; .reg .u64 %r55; .reg .u64 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r76; .reg .u32 %r77; .reg .u32 %r79; .reg .u32 %r80; .reg .u16 %r81; .reg .u16 %r82; .reg .u16 %r83; .reg .u32 %r84; .reg .u16 %r85; .reg .pred %r86; .reg .f64 %r87; .reg .f64 %r89; .reg .pred %r90; .reg .f64 %r91; .reg .f64 %r93; .reg .pred %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .f64 %r103; .reg .f64 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; mov.f64 %r58,%ar0; mov.u64 %r59,%ar1; .loc 1 42 0 mov.b64 %r60,%r58; shr.u64 %r61,%r60,32; cvt.u32.u64 %r48,%r61; .loc 1 43 0 shr.s32 %r62,%r48,20; and.b32 %r50,%r62,2047; .loc 1 44 0 setp.ne.u32 %r63,%r50,0; @ %r63 bra $L2; .loc 1 45 0 and.b32 %r64,%r48,2147483647; cvt.u32.u64 %r67,%r60; or.b32 %r66,%r64,%r67; setp.eq.u32 %r68,%r66,0; @ %r68 bra $L9; .loc 1 46 0 mul.f64 %r58,%r58,0d4350000000000000; .loc 1 47 0 mov.b64 %r69,%r58; shr.u64 %r70,%r69,32; cvt.u32.u64 %r48,%r70; .loc 1 48 0 shr.s32 %r71,%r48,20; and.b32 %r72,%r71,2047; add.u32 %r50,%r72,-54; bra $L4; $L2: .loc 1 50 0 setp.ne.u32 %r73,%r50,2047; @ %r73 bra $L4; add.f64 %r57,%r58,%r58; bra $L1; $L4: .loc 1 51 0 cvt.u32.u64 %r74,%r59; add.u32 %r29,%r50,%r74; .loc 1 52 0 set.u32.gt.s64 %r76,%r59,50000; neg.s32 %r77,%r76; set.u32.gt.s32 %r79,%r29,2046; neg.s32 %r80,%r79; cvt.u16.u32 %r82,%r77; cvt.u16.u32 %r83,%r80; or.b16 %r81,%r82,%r83; cvt.u32.u16 %r84,%r81; cvt.u16.u8 %r85,%r84; setp.eq.u16 %r86,%r85,0; @ %r86 bra $L5; .loc 1 53 0 mov.f64 %r87,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r87; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r58; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r89,[%value_in]; } mul.f64 %r57,%r89,0d7e37e43c8800759c; bra $L1; $L5: .loc 1 54 0 setp.ge.s64 %r90,%r59,-50000; @ %r90 bra $L6; mov.f64 %r91,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r91; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r58; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r93,[%value_in]; } mul.f64 %r57,%r93,0d01a56e1fc2f8f359; bra $L1; $L6: .loc 1 55 0 setp.le.s32 %r94,%r29,0; @ %r94 bra $L7; .loc 1 56 0 mov.b64 %r55,%r58; and.b32 %r95,%r48,-2146435073; shl.b32 %r96,%r29,20; or.b32 %r97,%r95,%r96; cvt.u64.u32 %r98,%r97; shl.b64 %r99,%r98,32; and.b64 %r100,%r55,4294967295; or.b64 %r101,%r100,%r99; mov.b64 %r57,%r101; bra $L1; $L7: .loc 1 57 0 setp.ge.s32 %r102,%r29,-53; @ %r102 bra $L8; .loc 1 58 0 mov.f64 %r103,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r103; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r58; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r105,[%value_in]; } mul.f64 %r57,%r105,0d01a56e1fc2f8f359; bra $L1; $L8: .loc 1 60 0 mov.b64 %r56,%r58; .loc 1 59 0 add.u32 %r106,%r29,54; .loc 1 60 0 shl.b32 %r107,%r106,20; and.b32 %r108,%r48,-2146435073; or.b32 %r109,%r107,%r108; cvt.u64.u32 %r110,%r109; shl.b64 %r111,%r110,32; and.b64 %r112,%r56,4294967295; or.b64 %r113,%r112,%r111; mov.b64 %r53,%r113; .loc 1 61 0 mul.f64 %r57,%r53,0d3c90000000000000; bra $L1; $L9: .loc 1 45 0 mov.f64 %r57,%r58; $L1: .loc 1 62 0 mov.f64 %value,%r57; st.param.f64 [%value_out],%value; ret; } /777 0 0 0 644 4054 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .f64 %r46; .reg .u64 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .pred %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .pred %r81; .reg .pred %r82; .reg .f64 %r83; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; mov.f64 %r52,%ar0; mov.u32 %r53,%ar1; .loc 1 86 0 mov.b64 %r54,%r52; shr.u64 %r55,%r54,32; cvt.u32.u64 %r41,%r55; .loc 1 87 0 shr.s32 %r56,%r41,20; and.b32 %r43,%r56,2047; .loc 1 88 0 setp.ne.u32 %r57,%r43,0; @ %r57 bra $L2; .loc 1 89 0 and.b32 %r58,%r41,2147483647; cvt.u32.u64 %r61,%r54; or.b32 %r60,%r58,%r61; setp.eq.u32 %r62,%r60,0; @ %r62 bra $L10; .loc 1 90 0 mul.f64 %r52,%r52,0d4350000000000000; .loc 1 93 0 setp.ge.s32 %r63,%r53,-50000; @ %r63 bra $L4; mul.f64 %r51,%r52,0d01a56e1fc2f8f359; bra $L1; $L2: .loc 1 95 0 setp.ne.u32 %r64,%r43,2047; @ %r64 bra $L5; add.f64 %r51,%r52,%r52; bra $L1; $L4: .loc 1 91 0 mov.b64 %r65,%r52; shr.u64 %r66,%r65,32; cvt.u32.u64 %r41,%r66; .loc 1 92 0 shr.s32 %r67,%r41,20; and.b32 %r68,%r67,2047; add.u32 %r43,%r68,-54; $L5: .loc 1 96 0 add.u32 %r44,%r53,%r43; .loc 1 97 0 setp.le.s32 %r69,%r44,2046; @ %r69 bra $L6; mov.f64 %r70,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r70; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r72,[%value_in]; } mul.f64 %r51,%r72,0d7e37e43c8800759c; bra $L1; $L6: .loc 1 98 0 setp.le.s32 %r73,%r44,0; @ %r73 bra $L7; .loc 1 99 0 mov.b64 %r49,%r52; and.b32 %r74,%r41,-2146435073; shl.b32 %r75,%r44,20; or.b32 %r76,%r74,%r75; cvt.u64.u32 %r77,%r76; shl.b64 %r78,%r77,32; and.b64 %r79,%r49,4294967295; or.b64 %r80,%r79,%r78; mov.b64 %r51,%r80; bra $L1; $L7: .loc 1 100 0 setp.ge.s32 %r81,%r44,-53; @ %r81 bra $L8; .loc 1 101 0 setp.le.s32 %r82,%r53,50000; @ %r82 bra $L9; .loc 1 102 0 mov.f64 %r83,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r83; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r85,[%value_in]; } mul.f64 %r51,%r85,0d7e37e43c8800759c; bra $L1; $L9: .loc 1 103 0 mov.f64 %r86,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r88,[%value_in]; } mul.f64 %r51,%r88,0d01a56e1fc2f8f359; bra $L1; $L8: .loc 1 106 0 mov.b64 %r50,%r52; .loc 1 105 0 add.u32 %r89,%r44,54; .loc 1 106 0 shl.b32 %r90,%r89,20; and.b32 %r91,%r41,-2146435073; or.b32 %r92,%r90,%r91; cvt.u64.u32 %r93,%r92; shl.b64 %r94,%r93,32; and.b64 %r95,%r50,4294967295; or.b64 %r96,%r95,%r94; mov.b64 %r46,%r96; .loc 1 107 0 mul.f64 %r51,%r46,0d3c90000000000000; bra $L1; $L10: .loc 1 89 0 mov.f64 %r51,%r52; $L1: .loc 1 108 0 mov.f64 %value,%r51; st.param.f64 [%value_out],%value; ret; } /795 0 0 0 644 1140 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __signbitf .visible .func (.param .u32 %value_out) __signbitf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_signbit.c" // BEGIN GLOBAL FUNCTION DECL: __signbitd .visible .func (.param .u32 %value_out) __signbitd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __signbitf .visible .func (.param .u32 %value_out) __signbitf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r25; .reg .u32 %r27; mov.f32 %r25,%ar0; .loc 1 48 0 mov.b32 %r27,%r25; and.b32 %value,%r27,-2147483648; .loc 1 49 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __signbitd .visible .func (.param .u32 %value_out) __signbitd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r25; .reg .u64 %r27; .reg .u64 %r28; .reg .u32 %r29; mov.f64 %r25,%ar0; .loc 1 58 0 mov.b64 %r27,%r25; shr.u64 %r28,%r27,32; cvt.u32.u64 %r29,%r28; and.b32 %value,%r29,-2147483648; .loc 1 59 0 st.param.u32 [%value_out],%value; ret; } /814 0 0 0 644 1284 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: significand .visible .func (.param .f64 %value_out) significand (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_signif.c" // BEGIN GLOBAL FUNCTION DECL: ilogb .extern .func (.param .u32 %value_out) ilogb (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalb .extern .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: significand .visible .func (.param .f64 %value_out) significand (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r26; .reg .u32 %r28; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; mov.f64 %r26,%ar0; .loc 1 31 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; call (%value_in),ilogb,(%out_arg1); ld.param.u32 %r28,[%value_in]; } neg.s32 %r31,%r28; cvt.rn.f64.s32 %r32,%r31; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r26; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r32; call (%value_in),__ieee754_scalb,(%out_arg1,%out_arg2); ld.param.f64 %r33,[%value_in]; } .loc 1 32 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } lib_a-s_sin.o/ 0 0 0 644 4370 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sin .visible .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_sin.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_sin .extern .func (.param .f64 %value_out) __kernel_sin (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .extern .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_cos .extern .func (.param .f64 %value_out) __kernel_cos (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: sin .visible .func (.param .f64 %value_out) sin (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r33; .reg .u32 %r34; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .u32 %r44; .reg .f64 %r45; .reg .pred %r46; .reg .u32 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .f64 %r54; .reg .u32 %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .u32 %r65; .reg .f64 %r66; .reg .f64 %r67; .reg .f64 %r68; .reg .f64 %r70; .reg .f64 %r71; mov.f64 %r38,%ar0; .loc 1 110 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r33,%r40; .loc 1 113 0 and.b32 %r34,%r33,2147483647; .loc 1 114 0 setp.gt.s32 %r41,%r34,1072243195; @ %r41 bra $L2; mov.u32 %r44,0; mov.f64 %r43,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r43; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r44; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r45,[%value_in]; } mov.f64 %r37,%r45; bra $L1; $L2: .loc 1 117 0 setp.le.s32 %r46,%r34,2146435071; @ %r46 bra $L4; sub.f64 %r37,%r38,%r38; bra $L1; $L4: .loc 1 121 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2,(%out_arg1,%out_arg2); ld.param.u32 %r49,[%value_in]; } .loc 1 122 0 and.b32 %r50,%r49,3; setp.eq.u32 %r51,%r50,1; @ %r51 bra $L6; setp.eq.u32 %r52,%r50,2; @ %r52 bra $L7; setp.eq.u32 %r53,%r50,0; @ ! %r53 bra $L9; .loc 1 123 0 ld.f64 %r57,[%frame+8]; mov.u32 %r56,1; ld.f64 %r54,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r54; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r57; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r56; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r58,[%value_in]; } mov.f64 %r37,%r58; bra $L1; $L6: .loc 1 124 0 ld.f64 %r61,[%frame+8]; ld.f64 %r59,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r59; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r61; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r62,[%value_in]; } mov.f64 %r37,%r62; bra $L1; $L7: .loc 1 125 0 ld.f64 %r66,[%frame+8]; mov.u32 %r65,1; ld.f64 %r63,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r63; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r66; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r65; call (%value_in),__kernel_sin,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r67,[%value_in]; } neg.f64 %r37,%r67; bra $L1; $L9: .loc 1 127 0 ld.f64 %r70,[%frame+8]; ld.f64 %r68,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r68; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r70; call (%value_in),__kernel_cos,(%out_arg1,%out_arg2); ld.param.f64 %r71,[%value_in]; } neg.f64 %r37,%r71; $L1: .loc 1 130 0 mov.f64 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-s_tan.o/ 0 0 0 644 2947 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tan .visible .func (.param .f64 %value_out) tan (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_tan.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_tan .extern .func (.param .f64 %value_out) __kernel_tan (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2 .extern .func (.param .u32 %value_out) __ieee754_rem_pio2 (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: tan .visible .func (.param .f64 %value_out) tan (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r27; .reg .u32 %r28; .reg .f64 %r31; .reg .f64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .pred %r35; .reg .f64 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .pred %r40; .reg .u32 %r43; .reg .f64 %r44; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .f64 %r51; .reg .f64 %r52; mov.f64 %r32,%ar0; .loc 1 97 0 mov.b64 %r33,%r32; shr.u64 %r34,%r33,32; cvt.u32.u64 %r27,%r34; .loc 1 100 0 and.b32 %r28,%r27,2147483647; .loc 1 101 0 setp.gt.s32 %r35,%r28,1072243195; @ %r35 bra $L2; mov.u32 %r38,1; mov.f64 %r37,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r37; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r38; call (%value_in),__kernel_tan,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r39,[%value_in]; } mov.f64 %r31,%r39; bra $L1; $L2: .loc 1 104 0 setp.le.s32 %r40,%r28,2146435071; @ %r40 bra $L4; sub.f64 %r31,%r32,%r32; bra $L1; $L4: .loc 1 108 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2,(%out_arg1,%out_arg2); ld.param.u32 %r43,[%value_in]; } .loc 1 109 0 add.u32 %r47,%r43,%r43; and.b32 %r48,%r47,2; mov.u32 %r50,1; sub.u32 %r49,%r50,%r48; ld.f64 %r51,[%frame+8]; ld.f64 %r44,[%frame]; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r51; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r49; call (%value_in),__kernel_tan,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r52,[%value_in]; } mov.f64 %r31,%r52; $L1: .loc 1 112 0 mov.f64 %value,%r31; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-s_tanh.o/ 0 0 0 644 2921 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanh .visible .func (.param .f64 %value_out) tanh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/s_tanh.c" // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1 .extern .func (.param .f64 %value_out) expm1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanh .visible .func (.param .f64 %value_out) tanh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r31; .reg .u32 %r32; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .f64 %r42; .reg .pred %r43; .reg .pred %r45; .reg .pred %r46; .reg .f64 %r47; .reg .pred %r48; .reg .f64 %r50; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .f64 %r59; .reg .f64 %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .pred %r65; mov.f64 %r38,%ar0; .loc 1 101 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r31,%r40; .loc 1 102 0 and.b32 %r32,%r31,2147483647; .loc 1 105 0 setp.le.s32 %r41,%r32,2146435071; @ %r41 bra $L2; mov.f64 %r42,0d3ff0000000000000; div.rn.f64 %r36,%r42,%r38; .loc 1 106 0 setp.lt.s32 %r43,%r31,0; @ %r43 bra $L3; add.f64 %r37,%r36,0d3ff0000000000000; bra $L1; $L3: .loc 1 107 0 sub.f64 %r37,%r36,%r42; bra $L1; $L2: .loc 1 111 0 setp.gt.s32 %r45,%r32,1077280767; @ %r45 bra $L8; .loc 1 112 0 setp.gt.s32 %r46,%r32,1015021567; @ %r46 bra $L6; .loc 1 113 0 add.f64 %r47,%r38,0d3ff0000000000000; mul.f64 %r37,%r47,%r38; bra $L1; $L6: .loc 1 114 0 setp.le.s32 %r48,%r32,1072693247; @ %r48 bra $L7; .loc 1 115 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r50,[%value_in]; } add.f64 %r52,%r50,%r50; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r53,[%value_in]; } .loc 1 116 0 add.f64 %r54,%r53,0d4000000000000000; mov.f64 %r56,0d4000000000000000; div.rn.f64 %r55,%r56,%r54; mov.f64 %r57,0d3ff0000000000000; sub.f64 %r37,%r57,%r55; bra $L5; $L7: .loc 1 118 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r59,[%value_in]; } mul.f64 %r61,%r59,0dc000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r61; call (%value_in),expm1,(%out_arg1); ld.param.f64 %r62,[%value_in]; } .loc 1 119 0 neg.f64 %r63,%r62; add.f64 %r64,%r62,0d4000000000000000; div.rn.f64 %r37,%r63,%r64; bra $L5; $L8: .loc 1 123 0 mov.f64 %r37,0d3ff0000000000000; $L5: .loc 1 125 0 setp.ge.s32 %r65,%r31,0; @ %r65 bra $L1; neg.f64 %r37,%r37; $L1: .loc 1 126 0 mov.f64 %value,%r37; st.param.f64 [%value_out],%value; ret; } lib_a-s_trunc.o/0 0 0 644 2021 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: trunc .visible .func (.param .f64 %value_out) trunc (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_trunc.c" // BEGIN GLOBAL FUNCTION DEF: trunc .visible .func (.param .f64 %value_out) trunc (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r41; .reg .f64 %r42; .reg .u64 %r43; .reg .u64 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r62; .reg .pred %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; mov.f64 %r42,%ar0; mov.b64 %r43,%r42; shr.u64 %r44,%r43,32; cvt.u32.u64 %r36,%r44; .loc 1 64 0 shr.s32 %r45,%r36,20; and.b32 %r23,%r45,2047; add.u32 %r35,%r23,-1023; .loc 1 66 0 setp.gt.s32 %r46,%r35,19; @ %r46 bra $L2; .loc 1 69 0 setp.ge.s32 %r47,%r35,0; @ %r47 bra $L3; .loc 1 61 0 and.b32 %r48,%r36,-2147483648; .loc 1 72 0 cvt.u64.u32 %r49,%r48; shl.b64 %r53,%r49,32; mov.b64 %r41,%r53; bra $L1; $L3: .loc 1 77 0 mov.u32 %r55,1048575; shr.s32 %r54,%r55,%r35; not.b32 %r56,%r54; and.b32 %r57,%r56,%r36; cvt.u64.u32 %r58,%r57; shl.b64 %r62,%r58,32; mov.b64 %r41,%r62; bra $L1; $L2: .loc 1 80 0 setp.le.s32 %r63,%r35,51; @ %r63 bra $L5; .loc 1 82 0 setp.ne.u32 %r64,%r35,1024; @ %r64 bra $L6; .loc 1 85 0 add.f64 %r41,%r42,%r42; bra $L1; $L5: .loc 1 93 0 cvt.u64.u32 %r65,%r36; add.u32 %r69,%r23,-1043; mov.u32 %r71,-1; shr.u32 %r70,%r71,%r69; not.b32 %r72,%r70; cvt.u32.u64 %r75,%r43; and.b32 %r74,%r72,%r75; cvt.u64.u32 %r76,%r74; shl.b64 %r77,%r65,32; or.b64 %r78,%r77,%r76; mov.b64 %r41,%r78; bra $L1; $L6: mov.f64 %r41,%r42; $L1: .loc 1 96 0 mov.f64 %value,%r41; st.param.f64 [%value_out],%value; ret; } /832 0 0 0 644 1026 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalblnl .visible .func (.param .f64 %value_out) scalblnl (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/scalblnl.c" // BEGIN GLOBAL FUNCTION DECL: scalbln .extern .func (.param .f64 %value_out) scalbln (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalblnl .visible .func (.param .f64 %value_out) scalblnl (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),scalbln,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-scalbnl.o/0 0 0 644 1018 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbnl .visible .func (.param .f64 %value_out) scalbnl (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/scalbnl.c" // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbnl .visible .func (.param .f64 %value_out) scalbnl (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .u32 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } /850 0 0 0 644 3693 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: asinhf .visible .func (.param .f32 %value_out) asinhf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_asinh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: log1pf .extern .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: asinhf .visible .func (.param .f32 %value_out) asinhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r36; .reg .u32 %r37; .reg .f32 %r39; .reg .f32 %r41; .reg .f32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .f32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .f32 %r49; .reg .f32 %r51; .reg .pred %r52; .reg .f32 %r54; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .pred %r74; mov.f32 %r42,%ar0; .loc 1 36 0 mov.b32 %r36,%r42; .loc 1 37 0 and.b32 %r37,%r36,2147483647; .loc 1 38 0 setp.le.s32 %r43,%r37,2139095039; @ %r43 bra $L2; add.f32 %r41,%r42,%r42; bra $L1; $L2: .loc 1 39 0 setp.gt.s32 %r44,%r37,830472191; @ %r44 bra $L4; .loc 1 40 0 add.f32 %r45,%r42,0f7149f2ca; setp.gt.f32 %r46,%r45,0f3f800000; @ %r46 bra $L8; bra $L5; $L4: .loc 1 42 0 setp.le.s32 %r47,%r37,1300234240; @ %r47 bra $L6; .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r49; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r51,[%value_in]; } add.f32 %r41,%r51,0f3f317218; bra $L7; $L6: .loc 1 44 0 setp.le.s32 %r52,%r37,1073741824; @ %r52 bra $L5; .loc 1 45 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r54,[%value_in]; } .loc 1 46 0 fma.rn.f32 %r56,%r42,%r42,0f3f800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r56; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r57,[%value_in]; } add.f32 %r59,%r57,%r54; mov.f32 %r61,0f3f800000; div.rn.f32 %r60,%r61,%r59; fma.rn.f32 %r62,%r54,0f40000000,%r60; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r62; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r63,[%value_in]; } mov.f32 %r41,%r63; bra $L7; $L5: .loc 1 48 0 mul.f32 %r39,%r42,%r42; .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r65,[%value_in]; } add.f32 %r67,%r39,0f3f800000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r67; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r68,[%value_in]; } add.f32 %r70,%r68,0f3f800000; div.rn.f32 %r71,%r39,%r70; add.f32 %r72,%r71,%r65; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r72; call (%value_in),log1pf,(%out_arg1); ld.param.f32 %r73,[%value_in]; } mov.f32 %r41,%r73; $L7: .loc 1 51 0 setp.gt.s32 %r74,%r36,0; @ %r74 bra $L1; neg.f32 %r41,%r41; bra $L1; $L8: .loc 1 40 0 mov.f32 %r41,%r42; $L1: .loc 1 52 0 mov.f32 %value,%r41; st.param.f32 [%value_out],%value; ret; } lib_a-sf_atan.o/0 0 0 644 4197 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atanf .visible .func (.param .f32 %value_out) atanf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_atan.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN VAR DEF: atanhi .const .align 4 .u32 atanhi[4] = {1055744824,1061752794,1065064542,1070141402 }; // BEGIN VAR DEF: atanlo .const .align 4 .u32 atanlo[4] = {833369961,857874792,856952756,866263400 }; // BEGIN GLOBAL FUNCTION DEF: atanf .visible .func (.param .f32 %value_out) atanf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .f32 %r27; .reg .f32 %r28; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .pred %r61; .reg .pred %r62; .reg .pred %r63; .reg .f32 %r64; .reg .pred %r65; .reg .f32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .f32 %r70; .reg .pred %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r75; .reg .f32 %r76; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .f32 %r80; .reg .f32 %r81; .reg .f32 %r82; .reg .f32 %r83; .reg .f32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .pred %r98; mov.f32 %r58,%ar0; .loc 1 77 0 mov.b32 %r43,%r58; .loc 1 78 0 and.b32 %r44,%r43,2147483647; .loc 1 79 0 setp.le.s32 %r59,%r44,1350565887; @ %r59 bra $L2; .loc 1 80 0 setp.le.s32 %r60,%r44,2139095040; @ %r60 bra $L3; .loc 1 81 0 add.f32 %r57,%r58,%r58; bra $L1; $L3: .loc 1 82 0 setp.le.s32 %r61,%r43,0; selp.f32 %r57,0fbfc90fdb,0f3fc90fdb,%r61; bra $L1; $L2: .loc 1 84 0 setp.gt.s32 %r62,%r44,1054867455; @ %r62 bra $L5; .loc 1 85 0 setp.gt.s32 %r63,%r44,822083583; @ %r63 bra $L12; .loc 1 86 0 add.f32 %r64,%r58,0f7149f2ca; setp.gt.f32 %r65,%r64,0f3f800000; @ %r65 bra $L13; .loc 1 88 0 mov.u32 %r42,-1; bra $L6; $L5: .loc 1 90 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r67,[%value_in]; } .loc 1 91 0 setp.gt.s32 %r68,%r44,1066926079; @ %r68 bra $L7; .loc 1 92 0 setp.gt.s32 %r69,%r44,1060110335; @ %r69 bra $L8; .loc 1 93 0 fma.rn.f32 %r23,%r67,0f40000000,0fbf800000; add.f32 %r24,%r67,0f40000000; div.rn.f32 %r58,%r23,%r24; mov.u32 %r42,0; bra $L6; $L8: .loc 1 95 0 mov.f32 %r70,0f3f800000; sub.f32 %r25,%r67,%r70; add.f32 %r26,%r67,0f3f800000; div.rn.f32 %r58,%r25,%r26; mov.u32 %r42,1; bra $L6; $L7: .loc 1 98 0 setp.gt.s32 %r71,%r44,1075576831; @ %r71 bra $L9; .loc 1 99 0 mov.f32 %r72,0f3fc00000; sub.f32 %r27,%r67,%r72; fma.rn.f32 %r28,%r67,0f3fc00000,0f3f800000; div.rn.f32 %r58,%r27,%r28; mov.u32 %r42,2; bra $L6; $L9: .loc 1 101 0 mov.f32 %r73,0fbf800000; div.rn.f32 %r58,%r73,%r67; mov.u32 %r42,3; bra $L6; $L12: .loc 1 88 0 mov.u32 %r42,-1; $L6: .loc 1 105 0 mul.f32 %r47,%r58,%r58; .loc 1 106 0 mul.f32 %r48,%r47,%r47; .loc 1 108 0 fma.rn.f32 %r74,%r48,0f3c8569d7,0f3d4bda59; fma.rn.f32 %r75,%r74,%r48,0f3d886b35; fma.rn.f32 %r76,%r75,%r48,0f3dba2e6e; fma.rn.f32 %r77,%r76,%r48,0f3e124925; fma.rn.f32 %r78,%r77,%r48,0f3eaaaaab; .loc 1 109 0 fma.rn.f32 %r79,%r48,0fbd15a221,0fbd6ef16b; fma.rn.f32 %r80,%r79,%r48,0fbd9d8795; fma.rn.f32 %r81,%r80,%r48,0fbde38e38; fma.rn.f32 %r82,%r81,%r48,0fbe4ccccd; mul.f32 %r83,%r82,%r48; fma.rn.f32 %r84,%r78,%r47,%r83; mul.f32 %r56,%r84,%r58; .loc 1 110 0 setp.ne.u32 %r85,%r42,-1; @ %r85 bra $L10; sub.f32 %r57,%r58,%r56; bra $L1; $L10: .loc 1 112 0 cvta.const.u64 %r86,atanhi; cvt.s64.s32 %r87,%r42; shl.b64 %r88,%r87,2; add.u64 %r89,%r86,%r88; cvta.const.u64 %r90,atanlo; add.u64 %r93,%r90,%r88; ld.f32 %r95,[%r93]; sub.f32 %r94,%r56,%r95; sub.f32 %r96,%r94,%r58; ld.f32 %r97,[%r89]; sub.f32 %r57,%r97,%r96; .loc 1 113 0 setp.ge.s32 %r98,%r43,0; @ %r98 bra $L1; neg.f32 %r57,%r57; bra $L1; $L13: .loc 1 86 0 mov.f32 %r57,%r58; $L1: .loc 1 115 0 mov.f32 %value,%r57; st.param.f32 [%value_out],%value; ret; } lib_a-sf_cbrt.o/0 0 0 644 2043 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cbrtf .visible .func (.param .f32 %value_out) cbrtf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_cbrt.c" // BEGIN GLOBAL FUNCTION DEF: cbrtf .visible .func (.param .f32 %value_out) cbrtf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .u32 %r24; .reg .u32 %r27; .reg .u32 %r37; .reg .f32 %r38; .reg .f32 %r41; .reg .f32 %r44; .reg .f32 %r46; .reg .f32 %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .f32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r58; .reg .u32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r69; .reg .u32 %r70; .reg .u32 %r71; mov.f32 %r47,%ar0; .loc 1 53 0 mov.b32 %r22,%r47; .loc 1 55 0 and.b32 %r24,%r22,2147483647; .loc 1 56 0 setp.le.u32 %r48,%r24,2139095039; @ %r48 bra $L2; .loc 1 57 0 add.f32 %r46,%r47,%r47; bra $L1; $L2: .loc 1 58 0 setp.eq.u32 %r49,%r24,0; @ %r49 bra $L6; .loc 1 61 0 mov.b32 %r41,%r24; .loc 1 63 0 setp.gt.s32 %r50,%r24,8388607; @ %r50 bra $L4; .loc 1 65 0 mul.f32 %r51,%r41,0f4b800000; mov.b32 %r53,%r51; div.u32 %r54,%r53,3; add.u32 %r27,%r54,642849266; mov.b32 %r38,%r27; bra $L5; $L4: .loc 1 68 0 div.s32 %r58,%r24,3; add.u32 %r59,%r58,709958130; mov.b32 %r38,%r59; $L5: .loc 1 72 0 mul.f32 %r60,%r38,%r38; div.rn.f32 %r61,%r60,%r41; .loc 1 73 0 fma.rn.f32 %r44,%r38,%r61,0f3f0af8b0; .loc 1 74 0 add.f32 %r62,%r44,0f3fb50750; mov.f32 %r64,0fbf348ef1; div.rn.f32 %r63,%r64,%r44; add.f32 %r65,%r62,%r63; mov.f32 %r67,0f3fcdb6db; div.rn.f32 %r66,%r67,%r65; add.f32 %r68,%r66,0f3eb6db6e; mul.f32 %r69,%r68,%r38; .loc 1 54 0 and.b32 %r70,%r22,-2147483648; .loc 1 78 0 mov.b32 %r71,%r69; or.b32 %r37,%r70,%r71; mov.b32 %r46,%r37; .loc 1 79 0 bra $L1; $L6: .loc 1 59 0 mov.f32 %r46,%r47; $L1: .loc 1 80 0 mov.f32 %value,%r46; st.param.f32 [%value_out],%value; ret; } lib_a-sf_ceil.o/0 0 0 644 2154 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ceilf .visible .func (.param .f32 %value_out) ceilf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_ceil.c" // BEGIN GLOBAL FUNCTION DEF: ceilf .visible .func (.param .f32 %value_out) ceilf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .pred %r56; mov.f32 %r38,%ar0; .loc 1 33 0 mov.b32 %r22,%r38; .loc 1 34 0 and.b32 %r34,%r22,2147483647; .loc 1 35 0 shr.u32 %r39,%r34,23; add.u32 %r35,%r39,-127; .loc 1 36 0 setp.gt.s32 %r40,%r35,22; @ %r40 bra $L2; .loc 1 33 0 mov.u32 %r33,%r22; .loc 1 37 0 setp.ge.s32 %r41,%r35,0; @ %r41 bra $L3; .loc 1 38 0 add.f32 %r42,%r38,0f7149f2ca; setp.gt.f32 %r43,%r42,0f00000000; @ ! %r43 bra $L17; .loc 1 39 0 setp.lt.s32 %r44,%r22,0; @ %r44 bra $L10; .loc 1 40 0 setp.eq.u32 %r45,%r34,0; selp.f32 %r37,%r38,0f3f800000,%r45; bra $L1; $L3: .loc 1 43 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r35; .loc 1 44 0 and.b32 %r47,%r22,%r36; setp.eq.u32 %r48,%r47,0; @ %r48 bra $L12; .loc 1 45 0 add.f32 %r49,%r38,0f7149f2ca; setp.gt.f32 %r50,%r49,0f00000000; @ ! %r50 bra $L18; .loc 1 46 0 setp.le.s32 %r51,%r33,0; @ %r51 bra $L8; mov.u32 %r53,8388608; shr.s32 %r52,%r53,%r35; add.u32 %r33,%r33,%r52; $L8: .loc 1 47 0 not.b32 %r54,%r36; and.b32 %r55,%r54,%r33; mov.b32 %r37,%r55; bra $L1; $L2: .loc 1 51 0 setp.le.u32 %r56,%r34,2139095039; @ %r56 bra $L14; add.f32 %r37,%r38,%r38; bra $L1; $L17: mov.f32 %r37,%r38; bra $L1; $L10: mov.f32 %r37,0f80000000; bra $L1; $L18: mov.f32 %r37,%r38; .loc 1 55 0 bra $L1; $L12: .loc 1 44 0 mov.f32 %r37,%r38; bra $L1; $L14: mov.f32 %r37,%r38; $L1: .loc 1 56 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /868 0 0 0 644 887 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r24; .reg .f32 %r28; .reg .f32 %r29; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; mov.f32 %r28,%ar0; mov.f32 %r29,%ar1; .loc 1 34 0 mov.b32 %r31,%r28; and.b32 %r30,%r31,2147483647; mov.b32 %r33,%r29; and.b32 %r32,%r33,-2147483648; or.b32 %r24,%r30,%r32; .loc 1 35 0 mov.b32 %value,%r24; .loc 1 36 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_cos.o/ 0 0 0 644 4162 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cosf .visible .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_cos.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .extern .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .extern .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .extern .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: cosf .visible .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .pred %r39; .reg .f32 %r41; .reg .f32 %r42; .reg .pred %r43; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .f32 %r51; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r58; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .u32 %r66; .reg .f32 %r67; .reg .f32 %r68; mov.f32 %r38,%ar0; .loc 1 34 0 mov.b32 %r34,%r38; .loc 1 37 0 and.b32 %r35,%r34,2147483647; .loc 1 38 0 setp.gt.s32 %r39,%r35,1061752792; @ %r39 bra $L2; mov.f32 %r41,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r42,[%value_in]; } mov.f32 %r37,%r42; bra $L1; $L2: .loc 1 41 0 setp.le.s32 %r43,%r35,2139095039; @ %r43 bra $L4; sub.f32 %r37,%r38,%r38; bra $L1; $L4: .loc 1 45 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2f,(%out_arg1,%out_arg2); ld.param.u32 %r46,[%value_in]; } .loc 1 46 0 and.b32 %r47,%r46,3; setp.eq.u32 %r48,%r47,1; @ %r48 bra $L6; setp.eq.u32 %r49,%r47,2; @ %r49 bra $L7; setp.eq.u32 %r50,%r47,0; @ ! %r50 bra $L9; .loc 1 47 0 ld.f32 %r53,[%frame+4]; ld.f32 %r51,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r51; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r54,[%value_in]; } mov.f32 %r37,%r54; bra $L1; $L6: .loc 1 48 0 ld.f32 %r58,[%frame+4]; ld.f32 %r55,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r55; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r58; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r47; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r59,[%value_in]; } neg.f32 %r37,%r59; bra $L1; $L7: .loc 1 49 0 ld.f32 %r62,[%frame+4]; ld.f32 %r60,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r60; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r62; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r63,[%value_in]; } neg.f32 %r37,%r63; bra $L1; $L9: .loc 1 51 0 ld.f32 %r67,[%frame+4]; mov.u32 %r66,1; ld.f32 %r64,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r64; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r67; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r66; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r68,[%value_in]; } mov.f32 %r37,%r68; $L1: .loc 1 54 0 mov.f32 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-sf_erf.o/ 0 0 0 644 14920 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: erff .visible .func (.param .f32 %value_out) erff (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_erf.c" // BEGIN GLOBAL FUNCTION DECL: erfcf .visible .func (.param .f32 %value_out) erfcf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: erff .visible .func (.param .f32 %value_out) erff (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r86; .reg .f32 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .f32 %r91; .reg .f32 %r92; .reg .f32 %r93; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r123; .reg .f32 %r124; .reg .pred %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .pred %r133; .reg .pred %r134; .reg .pred %r135; .reg .f32 %r136; .reg .f32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .pred %r148; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r152; .reg .f32 %r153; .reg .f32 %r154; .reg .f32 %r155; .reg .f32 %r156; .reg .f32 %r157; .reg .f32 %r158; .reg .f32 %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .pred %r162; .reg .f32 %r163; .reg .f32 %r164; .reg .f32 %r165; .reg .pred %r166; .reg .pred %r167; .reg .f32 %r169; .reg .f32 %r170; .reg .f32 %r171; .reg .pred %r172; .reg .f32 %r173; .reg .f32 %r174; .reg .f32 %r175; .reg .f32 %r176; .reg .f32 %r177; .reg .f32 %r178; .reg .f32 %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r182; .reg .f32 %r183; .reg .f32 %r184; .reg .f32 %r185; .reg .f32 %r186; .reg .f32 %r187; .reg .f32 %r188; .reg .f32 %r189; .reg .f32 %r190; .reg .f32 %r191; .reg .f32 %r192; .reg .f32 %r193; .reg .f32 %r194; .reg .f32 %r195; .reg .f32 %r196; .reg .u32 %r197; .reg .u32 %r198; .reg .f32 %r200; .reg .f32 %r201; .reg .f32 %r202; .reg .f32 %r204; .reg .f32 %r205; .reg .f32 %r206; .reg .f32 %r207; .reg .f32 %r208; .reg .pred %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r212; .reg .f32 %r213; mov.f32 %r124,%ar0; .loc 1 110 0 mov.b32 %r88,%r124; .loc 1 111 0 and.b32 %r89,%r88,2147483647; .loc 1 112 0 setp.le.s32 %r125,%r89,2139095039; @ %r125 bra $L2; .loc 1 113 0 shr.u32 %r126,%r88,31; add.u32 %r127,%r126,%r126; .loc 1 114 0 mov.u32 %r129,1; sub.u32 %r128,%r129,%r127; cvt.rn.f32.s32 %r130,%r128; mov.f32 %r132,0f3f800000; div.rn.f32 %r131,%r132,%r124; add.f32 %r123,%r130,%r131; bra $L1; $L2: .loc 1 117 0 setp.gt.s32 %r133,%r89,1062731775; @ %r133 bra $L4; .loc 1 118 0 setp.gt.s32 %r134,%r89,830472191; @ %r134 bra $L5; .loc 1 119 0 setp.gt.s32 %r135,%r89,67108863; @ %r135 bra $L6; .loc 1 121 0 mul.f32 %r136,%r124,0f3f8375d4; fma.rn.f32 %r137,%r124,0f41000000,%r136; mul.f32 %r123,%r137,0f3e000000; bra $L1; $L6: .loc 1 122 0 fma.rn.f32 %r123,%r124,0f3e0375d4,%r124; bra $L1; $L5: .loc 1 124 0 mul.f32 %r98,%r124,%r124; .loc 1 125 0 fma.rn.f32 %r138,%r98,0fb7c756b1,0fbbbd1489; fma.rn.f32 %r139,%r138,%r98,0fbce9528f; fma.rn.f32 %r140,%r139,%r98,0fbea66beb; fma.rn.f32 %r141,%r140,%r98,0f3e0375d4; .loc 1 126 0 fma.rn.f32 %r142,%r98,0fb684e21a,0f390aee49; fma.rn.f32 %r143,%r142,%r98,0f3ba68116; fma.rn.f32 %r144,%r143,%r98,0f3d852a63; fma.rn.f32 %r145,%r144,%r98,0f3ecbbbce; fma.rn.f32 %r146,%r145,%r98,0f3f800000; .loc 1 127 0 div.rn.f32 %r147,%r141,%r146; .loc 1 128 0 fma.rn.f32 %r123,%r124,%r147,%r124; bra $L1; $L4: .loc 1 130 0 setp.gt.s32 %r148,%r89,1067450367; @ %r148 bra $L7; .loc 1 131 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r124; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r150,[%value_in]; } mov.f32 %r151,0f3f800000; sub.f32 %r95,%r150,%r151; .loc 1 132 0 fma.rn.f32 %r152,%r95,0fbb0df9c0,0f3d1151b3; fma.rn.f32 %r153,%r152,%r95,0fbde31cc2; fma.rn.f32 %r154,%r153,%r95,0f3ea2fe54; fma.rn.f32 %r155,%r154,%r95,0fbebe9208; fma.rn.f32 %r156,%r155,%r95,0f3ed46805; fma.rn.f32 %r96,%r156,%r95,0fbb1acdc6; .loc 1 133 0 fma.rn.f32 %r157,%r95,0f3c445aa3,0f3c5f6e13; fma.rn.f32 %r158,%r157,%r95,0f3e013307; fma.rn.f32 %r159,%r158,%r95,0f3d931ae7; fma.rn.f32 %r160,%r159,%r95,0f3f0a5785; fma.rn.f32 %r161,%r160,%r95,0f3dd9f331; fma.rn.f32 %r97,%r161,%r95,0f3f800000; .loc 1 134 0 setp.lt.s32 %r162,%r88,0; @ %r162 bra $L8; div.rn.f32 %r163,%r96,%r97; add.f32 %r123,%r163,0f3f58560b; bra $L1; $L8: div.rn.f32 %r164,%r96,%r97; mov.f32 %r165,0fbf58560b; sub.f32 %r123,%r165,%r164; bra $L1; $L7: .loc 1 136 0 setp.le.s32 %r166,%r89,1086324735; @ %r166 bra $L9; .loc 1 137 0 setp.ge.s32 %r167,%r88,0; selp.f32 %r123,0f3f800000,0fbf800000,%r167; bra $L1; $L9: .loc 1 139 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r124; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r169,[%value_in]; } .loc 1 140 0 mul.f32 %r170,%r169,%r169; mov.f32 %r171,0f3f800000; div.rn.f32 %r91,%r171,%r170; .loc 1 141 0 setp.gt.s32 %r172,%r89,1077336941; @ %r172 bra $L10; .loc 1 143 0 fma.rn.f32 %r173,%r91,0fc11d077e,0fc2a2932b; fma.rn.f32 %r174,%r173,%r91,0fc3389ae7; .loc 1 142 0 fma.rn.f32 %r175,%r174,%r91,0fc322658c; fma.rn.f32 %r176,%r175,%r91,0fc2798057; fma.rn.f32 %r177,%r176,%r91,0fc128f022; fma.rn.f32 %r178,%r177,%r91,0fbf31a0b7; fma.rn.f32 %r86,%r178,%r91,0fbc21a093; .loc 1 145 0 fma.rn.f32 %r179,%r91,0fbd777f97,0f40d23f7c; fma.rn.f32 %r180,%r179,%r91,0f42d9451f; fma.rn.f32 %r181,%r180,%r91,0f43d6810b; .loc 1 144 0 fma.rn.f32 %r182,%r181,%r91,0f442158c9; fma.rn.f32 %r183,%r182,%r91,0f43d9486f; fma.rn.f32 %r184,%r183,%r91,0f4309a863; fma.rn.f32 %r185,%r184,%r91,0f419d35ce; fma.rn.f32 %r87,%r185,%r91,0f3f800000; bra $L11; $L10: .loc 1 148 0 fma.rn.f32 %r186,%r91,0fc3f1c275,0fc480230b; .loc 1 147 0 fma.rn.f32 %r187,%r186,%r91,0fc41f6441; fma.rn.f32 %r188,%r187,%r91,0fc320a2ea; fma.rn.f32 %r189,%r188,%r91,0fc18e104b; fma.rn.f32 %r190,%r189,%r91,0fbf4c9dd4; fma.rn.f32 %r86,%r190,%r91,0fbc21a092; .loc 1 150 0 fma.rn.f32 %r191,%r91,0fc1b38712,0f43ed43a7; fma.rn.f32 %r192,%r191,%r91,0f451f90ce; .loc 1 149 0 fma.rn.f32 %r193,%r192,%r91,0f4547fdbb; fma.rn.f32 %r194,%r193,%r91,0f44c01759; fma.rn.f32 %r195,%r194,%r91,0f43a2e571; fma.rn.f32 %r196,%r195,%r91,0f41f2b459; fma.rn.f32 %r87,%r196,%r91,0f3f800000; $L11: .loc 1 153 0 mov.b32 %r198,%r169; and.b32 %r197,%r198,-4096; mov.b32 %r92,%r197; .loc 1 154 0 neg.f32 %r200,%r92; fma.rn.f32 %r201,%r200,%r92,0fbf100000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r201; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r202,[%value_in]; } sub.f32 %r204,%r92,%r169; div.rn.f32 %r205,%r86,%r87; add.f32 %r206,%r169,%r92; fma.rn.f32 %r207,%r204,%r206,%r205; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r207; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r208,[%value_in]; } mul.f32 %r93,%r202,%r208; .loc 1 155 0 setp.lt.s32 %r209,%r88,0; @ %r209 bra $L12; div.rn.f32 %r210,%r93,%r169; mov.f32 %r211,0f3f800000; sub.f32 %r123,%r211,%r210; bra $L1; $L12: div.rn.f32 %r212,%r93,%r169; mov.f32 %r213,0f3f800000; sub.f32 %r123,%r212,%r213; $L1: .loc 1 156 0 mov.f32 %value,%r123; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: erfcf .visible .func (.param .f32 %value_out) erfcf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r87; .reg .f32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .f32 %r94; .reg .f32 %r95; .reg .f32 %r96; .reg .f32 %r97; .reg .f32 %r98; .reg .f32 %r99; .reg .f32 %r101; .reg .f32 %r116; .reg .f32 %r127; .reg .f32 %r128; .reg .pred %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .pred %r135; .reg .pred %r136; .reg .f32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .f32 %r147; .reg .pred %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .f32 %r152; .reg .f32 %r153; .reg .pred %r155; .reg .f32 %r157; .reg .f32 %r158; .reg .f32 %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .f32 %r162; .reg .f32 %r163; .reg .f32 %r164; .reg .f32 %r165; .reg .f32 %r166; .reg .f32 %r167; .reg .f32 %r168; .reg .pred %r169; .reg .f32 %r170; .reg .f32 %r171; .reg .f32 %r172; .reg .f32 %r173; .reg .pred %r174; .reg .f32 %r176; .reg .f32 %r177; .reg .f32 %r178; .reg .pred %r179; .reg .f32 %r180; .reg .f32 %r181; .reg .f32 %r182; .reg .f32 %r183; .reg .f32 %r184; .reg .f32 %r185; .reg .f32 %r186; .reg .f32 %r187; .reg .f32 %r188; .reg .f32 %r189; .reg .f32 %r190; .reg .f32 %r191; .reg .f32 %r192; .reg .u32 %r194; .reg .u32 %r196; .reg .u32 %r197; .reg .u16 %r199; .reg .u16 %r200; .reg .u16 %r201; .reg .u32 %r202; .reg .u16 %r203; .reg .pred %r204; .reg .f32 %r205; .reg .f32 %r206; .reg .f32 %r207; .reg .f32 %r208; .reg .f32 %r209; .reg .f32 %r210; .reg .f32 %r211; .reg .f32 %r212; .reg .f32 %r213; .reg .f32 %r214; .reg .f32 %r215; .reg .u32 %r216; .reg .u32 %r217; .reg .f32 %r219; .reg .f32 %r220; .reg .f32 %r221; .reg .f32 %r223; .reg .f32 %r224; .reg .f32 %r225; .reg .f32 %r226; .reg .f32 %r227; .reg .pred %r228; .reg .f32 %r229; .reg .f32 %r230; .reg .pred %r231; mov.f32 %r128,%ar0; .loc 1 167 0 mov.b32 %r89,%r128; .loc 1 168 0 and.b32 %r90,%r89,2147483647; .loc 1 169 0 setp.le.s32 %r129,%r90,2139095039; @ %r129 bra $L15; .loc 1 171 0 shr.u32 %r130,%r89,31; add.u32 %r131,%r130,%r130; cvt.rn.f32.s32 %r132,%r131; mov.f32 %r134,0f3f800000; div.rn.f32 %r133,%r134,%r128; add.f32 %r127,%r132,%r133; bra $L14; $L15: .loc 1 174 0 setp.gt.s32 %r135,%r90,1062731775; @ %r135 bra $L17; .loc 1 175 0 setp.gt.s32 %r136,%r90,595591167; @ %r136 bra $L18; .loc 1 176 0 mov.f32 %r137,0f3f800000; sub.f32 %r127,%r137,%r128; bra $L14; $L18: .loc 1 177 0 mul.f32 %r101,%r128,%r128; .loc 1 178 0 fma.rn.f32 %r138,%r101,0fb7c756b1,0fbbbd1489; fma.rn.f32 %r139,%r138,%r101,0fbce9528f; fma.rn.f32 %r140,%r139,%r101,0fbea66beb; fma.rn.f32 %r141,%r140,%r101,0f3e0375d4; .loc 1 179 0 fma.rn.f32 %r142,%r101,0fb684e21a,0f390aee49; fma.rn.f32 %r143,%r142,%r101,0f3ba68116; fma.rn.f32 %r144,%r143,%r101,0f3d852a63; fma.rn.f32 %r145,%r144,%r101,0f3ecbbbce; fma.rn.f32 %r146,%r145,%r101,0f3f800000; .loc 1 180 0 div.rn.f32 %r147,%r141,%r146; mul.f32 %r116,%r147,%r128; .loc 1 181 0 setp.gt.s32 %r148,%r89,1048575999; @ %r148 bra $L19; .loc 1 182 0 add.f32 %r149,%r128,%r116; mov.f32 %r150,0f3f800000; sub.f32 %r127,%r150,%r149; bra $L14; $L19: .loc 1 185 0 mov.f32 %r152,0f3f000000; sub.f32 %r151,%r128,%r152; add.f32 %r153,%r151,%r116; .loc 1 186 0 sub.f32 %r127,%r152,%r153; bra $L14; $L17: .loc 1 189 0 setp.gt.s32 %r155,%r90,1067450367; @ %r155 bra $L20; .loc 1 190 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r128; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r157,[%value_in]; } mov.f32 %r158,0f3f800000; sub.f32 %r97,%r157,%r158; .loc 1 191 0 fma.rn.f32 %r159,%r97,0fbb0df9c0,0f3d1151b3; fma.rn.f32 %r160,%r159,%r97,0fbde31cc2; fma.rn.f32 %r161,%r160,%r97,0f3ea2fe54; fma.rn.f32 %r162,%r161,%r97,0fbebe9208; fma.rn.f32 %r163,%r162,%r97,0f3ed46805; fma.rn.f32 %r98,%r163,%r97,0fbb1acdc6; .loc 1 192 0 fma.rn.f32 %r164,%r97,0f3c445aa3,0f3c5f6e13; fma.rn.f32 %r165,%r164,%r97,0f3e013307; fma.rn.f32 %r166,%r165,%r97,0f3d931ae7; fma.rn.f32 %r167,%r166,%r97,0f3f0a5785; fma.rn.f32 %r168,%r167,%r97,0f3dd9f331; fma.rn.f32 %r99,%r168,%r97,0f3f800000; .loc 1 193 0 setp.lt.s32 %r169,%r89,0; @ %r169 bra $L21; .loc 1 194 0 div.rn.f32 %r170,%r98,%r99; mov.f32 %r171,0f3e1ea7d4; sub.f32 %r127,%r171,%r170; bra $L14; $L21: .loc 1 196 0 div.rn.f32 %r172,%r98,%r99; add.f32 %r173,%r172,0f3f58560b; add.f32 %r127,%r173,0f3f800000; bra $L14; $L20: .loc 1 199 0 setp.gt.s32 %r174,%r90,1105199103; @ %r174 bra $L22; .loc 1 200 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r128; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r176,[%value_in]; } .loc 1 201 0 mul.f32 %r177,%r176,%r176; mov.f32 %r178,0f3f800000; div.rn.f32 %r94,%r178,%r177; .loc 1 202 0 setp.gt.s32 %r179,%r90,1077336940; @ %r179 bra $L23; .loc 1 204 0 fma.rn.f32 %r180,%r94,0fc11d077e,0fc2a2932b; fma.rn.f32 %r181,%r180,%r94,0fc3389ae7; .loc 1 203 0 fma.rn.f32 %r182,%r181,%r94,0fc322658c; fma.rn.f32 %r183,%r182,%r94,0fc2798057; fma.rn.f32 %r184,%r183,%r94,0fc128f022; fma.rn.f32 %r185,%r184,%r94,0fbf31a0b7; fma.rn.f32 %r87,%r185,%r94,0fbc21a093; .loc 1 206 0 fma.rn.f32 %r186,%r94,0fbd777f97,0f40d23f7c; fma.rn.f32 %r187,%r186,%r94,0f42d9451f; fma.rn.f32 %r188,%r187,%r94,0f43d6810b; .loc 1 205 0 fma.rn.f32 %r189,%r188,%r94,0f442158c9; fma.rn.f32 %r190,%r189,%r94,0f43d9486f; fma.rn.f32 %r191,%r190,%r94,0f4309a863; fma.rn.f32 %r192,%r191,%r94,0f419d35ce; fma.rn.f32 %r88,%r192,%r94,0f3f800000; bra $L24; $L23: .loc 1 208 0 shr.u32 %r194,%r89,31; set.u32.gt.s32 %r196,%r90,1086324735; neg.s32 %r197,%r196; cvt.u16.u32 %r200,%r194; cvt.u16.u32 %r201,%r197; and.b16 %r199,%r200,%r201; cvt.u32.u16 %r202,%r199; cvt.u16.u8 %r203,%r202; setp.ne.u16 %r204,%r203,0; @ %r204 bra $L25; .loc 1 210 0 fma.rn.f32 %r205,%r94,0fc3f1c275,0fc480230b; .loc 1 209 0 fma.rn.f32 %r206,%r205,%r94,0fc41f6441; fma.rn.f32 %r207,%r206,%r94,0fc320a2ea; fma.rn.f32 %r208,%r207,%r94,0fc18e104b; fma.rn.f32 %r209,%r208,%r94,0fbf4c9dd4; fma.rn.f32 %r87,%r209,%r94,0fbc21a092; .loc 1 212 0 fma.rn.f32 %r210,%r94,0fc1b38712,0f43ed43a7; fma.rn.f32 %r211,%r210,%r94,0f451f90ce; .loc 1 211 0 fma.rn.f32 %r212,%r211,%r94,0f4547fdbb; fma.rn.f32 %r213,%r212,%r94,0f44c01759; fma.rn.f32 %r214,%r213,%r94,0f43a2e571; fma.rn.f32 %r215,%r214,%r94,0f41f2b459; fma.rn.f32 %r88,%r215,%r94,0f3f800000; $L24: .loc 1 215 0 mov.b32 %r217,%r176; and.b32 %r216,%r217,-4096; mov.b32 %r95,%r216; .loc 1 216 0 neg.f32 %r219,%r95; fma.rn.f32 %r220,%r219,%r95,0fbf100000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r220; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r221,[%value_in]; } .loc 1 217 0 sub.f32 %r223,%r95,%r176; div.rn.f32 %r224,%r87,%r88; add.f32 %r225,%r176,%r95; fma.rn.f32 %r226,%r223,%r225,%r224; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r226; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r227,[%value_in]; } .loc 1 216 0 mul.f32 %r96,%r221,%r227; .loc 1 218 0 setp.le.s32 %r228,%r89,0; @ %r228 bra $L26; div.rn.f32 %r127,%r96,%r176; bra $L14; $L26: div.rn.f32 %r229,%r96,%r176; mov.f32 %r230,0f40000000; sub.f32 %r127,%r230,%r229; bra $L14; $L22: .loc 1 220 0 setp.gt.s32 %r231,%r89,0; @ %r231 bra $L27; $L25: mov.f32 %r127,0f40000000; bra $L14; $L27: mov.f32 %r127,0f00000000; $L14: .loc 1 222 0 mov.f32 %value,%r127; st.param.f32 [%value_out],%value; ret; } /889 0 0 0 644 928 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp10f .visible .func (.param .f32 %value_out) exp10f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_exp10.c" // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp10f .visible .func (.param .f32 %value_out) exp10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r23,%ar0; .loc 1 32 0 mov.f32 %r24,0f41200000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r23; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 33 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } /907 0 0 0 644 6365 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: expm1f .visible .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_expm1.c" // BEGIN GLOBAL FUNCTION DEF: expm1f .visible .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r27; .reg .f32 %r39; .reg .u32 %r47; .reg .u32 %r51; .reg .u32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r58; .reg .u32 %r59; .reg .f32 %r60; .reg .u32 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .f32 %r65; .reg .f32 %r68; .reg .f32 %r69; .reg .f32 %r70; .reg .f32 %r71; .reg .f32 %r72; .reg .f32 %r73; .reg .f32 %r74; .reg .f32 %r76; .reg .u32 %r93; .reg .f32 %r94; .reg .f32 %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r101; .reg .u32 %r102; .reg .u32 %r104; .reg .u32 %r105; .reg .u16 %r107; .reg .u16 %r108; .reg .u16 %r109; .reg .u32 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .f32 %r113; .reg .pred %r114; .reg .f32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .pred %r119; .reg .f32 %r120; .reg .pred %r121; .reg .f32 %r122; .reg .f32 %r124; .reg .pred %r125; .reg .f32 %r126; .reg .f32 %r127; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .f32 %r135; .reg .pred %r136; .reg .f32 %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .pred %r140; .reg .f32 %r141; .reg .pred %r142; .reg .pred %r143; .reg .f32 %r144; .reg .f32 %r145; .reg .f32 %r146; .reg .u32 %r147; .reg .pred %r148; .reg .f32 %r149; .reg .f32 %r150; .reg .f32 %r151; .reg .u32 %r152; .reg .f32 %r153; .reg .pred %r155; .reg .u32 %r156; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .f32 %r160; .reg .f32 %r161; .reg .f32 %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .u32 %r165; .reg .u32 %r166; .reg .f32 %r167; .reg .f32 %r168; .reg .f32 %r169; .reg .u32 %r170; mov.f32 %r95,%ar0; .loc 1 51 0 mov.b32 %r63,%r95; .loc 1 54 0 and.b32 %r61,%r63,2147483647; .loc 1 57 0 setp.le.u32 %r96,%r61,1100331075; @ %r96 bra $L2; .loc 1 58 0 setp.le.u32 %r97,%r61,2139095040; @ %r97 bra $L3; .loc 1 59 0 add.f32 %r94,%r95,%r95; bra $L1; $L3: .loc 1 60 0 setp.ne.u32 %r98,%r61,2139095040; @ %r98 bra $L5; .loc 1 61 0 setp.lt.s32 %r99,%r63,0; selp.f32 %r94,0fbf800000,%r95,%r99; bra $L1; $L5: .loc 1 62 0 not.b32 %r101,%r63; shr.u32 %r102,%r101,31; set.u32.gt.u32 %r104,%r61,1118925335; neg.s32 %r105,%r104; cvt.u16.u32 %r108,%r102; cvt.u16.u32 %r109,%r105; and.b16 %r107,%r108,%r109; cvt.u32.u16 %r110,%r107; cvt.u16.u8 %r111,%r110; setp.eq.u16 %r112,%r111,0; @ %r112 bra $L6; .loc 1 63 0 mov.f32 %r113,0f7149f2ca; mul.f32 %r94,%r113,0f7149f2ca; bra $L1; $L6: .loc 1 64 0 setp.ge.s32 %r114,%r63,0; @ %r114 bra $L7; .loc 1 65 0 add.f32 %r115,%r95,0f0da24260; setp.lt.f32 %r116,%r115,0f00000000; @ ! %r116 bra $L7; bra $L21; $L2: .loc 1 71 0 setp.le.u32 %r117,%r61,1051816472; @ %r117 bra $L8; .loc 1 72 0 setp.gt.u32 %r118,%r61,1065686417; @ %r118 bra $L7; .loc 1 73 0 setp.lt.s32 %r119,%r63,0; @ %r119 bra $L9; .loc 1 74 0 mov.f32 %r120,0f3f317180; sub.f32 %r56,%r95,%r120; mov.u32 %r59,1; mov.f32 %r57,0f3717f7d1; bra $L10; $L9: .loc 1 76 0 add.f32 %r56,%r95,0f3f317180; mov.u32 %r59,-1; mov.f32 %r57,0fb717f7d1; bra $L10; $L7: .loc 1 78 0 mul.f32 %r27,%r95,0f3fb8aa3b; setp.lt.s32 %r121,%r63,0; selp.f32 %r60,0fbf000000,0f3f000000,%r121; add.f32 %r122,%r27,%r60; cvt.rzi.s32.f32 %r59,%r122; .loc 1 79 0 cvt.rn.f32.s32 %r65,%r59; .loc 1 80 0 fma.rn.f32 %r56,%r65,0fbf317180,%r95; .loc 1 81 0 mul.f32 %r57,%r65,0f3717f7d1; $L10: .loc 1 83 0 sub.f32 %r95,%r56,%r57; .loc 1 84 0 sub.f32 %r124,%r56,%r95; sub.f32 %r58,%r124,%r57; bra $L12; $L8: .loc 1 86 0 setp.gt.u32 %r125,%r61,855638015; @ %r125 bra $L23; .loc 1 87 0 add.f32 %r62,%r95,0f7149f2ca; .loc 1 88 0 sub.f32 %r126,%r62,%r62; sub.f32 %r94,%r95,%r126; bra $L1; $L23: .loc 1 90 0 mov.u32 %r59,0; $L12: .loc 1 93 0 mul.f32 %r68,%r95,0f3f000000; .loc 1 94 0 mul.f32 %r69,%r95,%r68; .loc 1 95 0 fma.rn.f32 %r127,%r69,0fb457edbb,0f36867e54; fma.rn.f32 %r128,%r127,%r69,0fb8a670cd; fma.rn.f32 %r129,%r128,%r69,0f3ad00d01; fma.rn.f32 %r130,%r129,%r69,0fbd088889; fma.rn.f32 %r70,%r130,%r69,0f3f800000; .loc 1 96 0 neg.f32 %r131,%r68; fma.rn.f32 %r71,%r131,%r70,0f40400000; .loc 1 97 0 sub.f32 %r132,%r70,%r71; neg.f32 %r133,%r95; fma.rn.f32 %r134,%r133,%r71,0f40c00000; div.rn.f32 %r135,%r132,%r134; mul.f32 %r72,%r135,%r69; .loc 1 98 0 setp.ne.u32 %r136,%r59,0; @ %r136 bra $L13; neg.f32 %r137,%r69; fma.rn.f32 %r138,%r95,%r72,%r137; sub.f32 %r94,%r95,%r138; bra $L1; $L13: .loc 1 100 0 sub.f32 %r39,%r72,%r58; neg.f32 %r139,%r58; fma.rn.f32 %r73,%r39,%r95,%r139; .loc 1 101 0 sub.f32 %r74,%r73,%r69; .loc 1 102 0 setp.ne.u32 %r140,%r59,-1; @ %r140 bra $L14; sub.f32 %r141,%r95,%r74; fma.rn.f32 %r94,%r141,0f3f000000,0fbf000000; bra $L1; $L14: .loc 1 103 0 setp.ne.u32 %r142,%r59,1; @ %r142 bra $L15; .loc 1 104 0 setp.lt.f32 %r143,%r95,0fbe800000; @ ! %r143 bra $L25; add.f32 %r144,%r95,0f3f000000; sub.f32 %r145,%r74,%r144; mul.f32 %r94,%r145,0fc0000000; bra $L1; $L25: .loc 1 105 0 sub.f32 %r146,%r95,%r74; fma.rn.f32 %r94,%r146,0f40000000,0f3f800000; bra $L1; $L15: shl.b32 %r93,%r59,23; .loc 1 107 0 add.u32 %r147,%r59,1; setp.le.u32 %r148,%r147,57; @ %r148 bra $L18; .loc 1 109 0 sub.f32 %r149,%r74,%r95; mov.f32 %r151,0f3f800000; sub.f32 %r150,%r151,%r149; .loc 1 111 0 mov.b32 %r152,%r150; add.u32 %r47,%r93,%r152; .loc 1 112 0 mov.b32 %r153,%r47; sub.f32 %r94,%r153,%r151; bra $L1; $L18: .loc 1 115 0 setp.gt.s32 %r155,%r59,22; @ %r155 bra $L19; .loc 1 117 0 mov.u32 %r157,16777216; shr.s32 %r156,%r157,%r59; mov.u32 %r159,1065353216; sub.u32 %r158,%r159,%r156; .loc 1 118 0 sub.f32 %r160,%r74,%r95; mov.b32 %r162,%r158; sub.f32 %r161,%r162,%r160; .loc 1 120 0 mov.b32 %r163,%r161; add.u32 %r51,%r93,%r163; mov.b32 %r94,%r51; bra $L1; $L19: .loc 1 123 0 mov.u32 %r165,127; sub.u32 %r164,%r165,%r59; shl.b32 %r166,%r164,23; .loc 1 124 0 mov.b32 %r168,%r166; add.f32 %r167,%r74,%r168; sub.f32 %r76,%r95,%r167; .loc 1 125 0 add.f32 %r169,%r76,0f3f800000; .loc 1 127 0 mov.b32 %r170,%r169; add.u32 %r55,%r93,%r170; mov.b32 %r94,%r55; bra $L1; $L21: .loc 1 61 0 mov.f32 %r94,0fbf800000; $L1: .loc 1 131 0 mov.f32 %value,%r94; st.param.f32 [%value_out],%value; ret; } lib_a-sf_fabs.o/0 0 0 644 622 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fabsf .visible .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_fabs.c" // BEGIN GLOBAL FUNCTION DEF: fabsf .visible .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .f32 %r25; .reg .u32 %r26; mov.f32 %r25,%ar0; .loc 1 31 0 mov.b32 %r26,%r25; and.b32 %r22,%r26,2147483647; .loc 1 32 0 mov.b32 %value,%r22; .loc 1 33 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_fdim.o/0 0 0 644 1581 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fdimf .visible .func (.param .f32 %value_out) fdimf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_fdim.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fdimf .visible .func (.param .f32 %value_out) fdimf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .f32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 17 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } .loc 1 18 0 setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 19 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 20 0 setp.eq.u32 %r33,%r28,1; @ %r33 bra $L5; .loc 1 23 0 setp.gt.f32 %r34,%r25,%r26; @ ! %r34 bra $L11; sub.f32 %r25,%r25,%r26; bra $L2; $L4: .loc 1 19 0 mov.f32 %r25,%r26; bra $L2; $L5: .loc 1 21 0 mov.f32 %r25,0f7f800000; bra $L2; $L11: .loc 1 23 0 mov.f32 %r25,0f00000000; $L2: .loc 1 24 0 mov.f32 %value,%r25; st.param.f32 [%value_out],%value; ret; } /925 0 0 0 644 699 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_finite.c" // BEGIN GLOBAL FUNCTION DEF: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.le.s32 %r31,%r29,2139095039; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /944 0 0 0 644 2159 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: floorf .visible .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_floor.c" // BEGIN GLOBAL FUNCTION DEF: floorf .visible .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r22; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .f32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .pred %r56; mov.f32 %r38,%ar0; .loc 1 42 0 mov.b32 %r22,%r38; .loc 1 43 0 and.b32 %r34,%r22,2147483647; .loc 1 44 0 shr.u32 %r39,%r34,23; add.u32 %r35,%r39,-127; .loc 1 45 0 setp.gt.s32 %r40,%r35,22; @ %r40 bra $L2; .loc 1 42 0 mov.u32 %r33,%r22; .loc 1 46 0 setp.ge.s32 %r41,%r35,0; @ %r41 bra $L3; .loc 1 47 0 add.f32 %r42,%r38,0f7149f2ca; setp.gt.f32 %r43,%r42,0f00000000; @ ! %r43 bra $L17; .loc 1 48 0 setp.ge.s32 %r44,%r22,0; @ %r44 bra $L10; .loc 1 49 0 setp.eq.u32 %r45,%r34,0; selp.f32 %r37,%r38,0fbf800000,%r45; bra $L1; $L3: .loc 1 53 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r35; .loc 1 54 0 and.b32 %r47,%r22,%r36; setp.eq.u32 %r48,%r47,0; @ %r48 bra $L12; .loc 1 55 0 add.f32 %r49,%r38,0f7149f2ca; setp.gt.f32 %r50,%r49,0f00000000; @ ! %r50 bra $L18; .loc 1 56 0 setp.ge.s32 %r51,%r33,0; @ %r51 bra $L8; mov.u32 %r53,8388608; shr.s32 %r52,%r53,%r35; add.u32 %r33,%r33,%r52; $L8: .loc 1 57 0 not.b32 %r54,%r36; and.b32 %r55,%r54,%r33; mov.b32 %r37,%r55; bra $L1; $L2: .loc 1 61 0 setp.le.u32 %r56,%r34,2139095039; @ %r56 bra $L14; add.f32 %r37,%r38,%r38; bra $L1; $L17: mov.f32 %r37,%r38; bra $L1; $L10: mov.f32 %r37,0f00000000; bra $L1; $L18: mov.f32 %r37,%r38; .loc 1 65 0 bra $L1; $L12: .loc 1 54 0 mov.f32 %r37,%r38; bra $L1; $L14: mov.f32 %r37,%r38; $L1: .loc 1 66 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_fma.o/ 0 0 0 644 942 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmaf .visible .func (.param .f32 %value_out) fmaf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2); .file 1 "../../../../../../newlib/libm/common/sf_fma.c" // BEGIN GLOBAL FUNCTION DEF: fmaf .visible .func (.param .f32 %value_out) fmaf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .f32 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %ar2; ld.param.f32 %ar2,[%in_ar2]; .reg .f32 %r27; .reg .f32 %r28; .reg .f32 %r29; .reg .f64 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r34; mov.f32 %r27,%ar0; mov.f32 %r28,%ar1; mov.f32 %r29,%ar2; .loc 1 25 0 cvt.f64.f32 %r31,%r27; cvt.f64.f32 %r32,%r29; cvt.f64.f32 %r33,%r28; fma.rn.f64 %r34,%r31,%r33,%r32; cvt.rn.f32.f64 %value,%r34; .loc 1 26 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_fmax.o/0 0 0 644 1442 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fmaxf .visible .func (.param .f32 %value_out) fmaxf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_fmax.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fmaxf .visible .func (.param .f32 %value_out) fmaxf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 17 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 19 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 22 0 setp.gt.f32 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f32 %r24,%r26; bra $L1; $L4: .loc 1 20 0 mov.f32 %r24,%r25; bra $L1; $L5: mov.f32 %r24,%r25; $L1: .loc 1 23 0 mov.f32 %value,%r24; st.param.f32 [%value_out],%value; ret; } lib_a-sf_fmin.o/0 0 0 644 1442 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fminf .visible .func (.param .f32 %value_out) fminf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_fmin.c" // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: fminf .visible .func (.param .f32 %value_out) fminf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r24; .reg .f32 %r25; .reg .f32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .pred %r33; mov.f32 %r25,%ar0; mov.f32 %r26,%ar1; .loc 1 17 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r25; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } setp.eq.u32 %r29,%r28,0; @ %r29 bra $L2; .loc 1 19 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r31,[%value_in]; } setp.eq.u32 %r32,%r31,0; @ %r32 bra $L4; .loc 1 22 0 setp.lt.f32 %r33,%r25,%r26; @ %r33 bra $L5; $L2: mov.f32 %r24,%r26; bra $L1; $L4: .loc 1 20 0 mov.f32 %r24,%r25; bra $L1; $L5: mov.f32 %r24,%r25; $L1: .loc 1 23 0 mov.f32 %value,%r24; st.param.f32 [%value_out],%value; ret; } /962 0 0 0 644 1176 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r26; .reg .u32 %r27; .reg .f32 %r28; .reg .u32 %r29; .reg .pred %r30; .reg .u32 %r31; .reg .pred %r32; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; mov.f32 %r28,%ar0; .loc 1 16 0 mov.b32 %r29,%r28; and.b32 %r26,%r29,2147483647; setp.eq.u32 %r30,%r26,0; @ %r30 bra $L3; .loc 1 18 0 add.u32 %r31,%r26,-8388608; setp.le.u32 %r32,%r31,2130706431; @ %r32 bra $L4; .loc 1 21 0 add.u32 %r33,%r26,-1; setp.le.u32 %r34,%r33,8388606; @ %r34 bra $L5; .loc 1 24 0 set.u32.eq.u32 %r36,%r26,2139095040; neg.s32 %r27,%r36; bra $L1; $L3: .loc 1 17 0 mov.u32 %r27,2; bra $L1; $L4: .loc 1 20 0 mov.u32 %r27,4; bra $L1; $L5: .loc 1 23 0 mov.u32 %r27,3; $L1: .loc 1 28 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } /985 0 0 0 644 1886 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/sf_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u16 %r47; .reg .u16 %r48; .reg .u16 %r49; .reg .u32 %r50; .reg .u16 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r31,%r38; .loc 1 34 0 and.b32 %r32,%r31,2147483647; .loc 1 35 0 mov.u32 %r40,0; st.u32 [%r39],%r40; .loc 1 36 0 set.u32.gt.s32 %r42,%r32,2139095039; neg.s32 %r43,%r42; set.u32.eq.u32 %r45,%r32,0; neg.s32 %r46,%r45; cvt.u16.u32 %r48,%r43; cvt.u16.u32 %r49,%r46; or.b16 %r47,%r48,%r49; cvt.u32.u16 %r50,%r47; cvt.u16.u8 %r51,%r50; setp.ne.u16 %r52,%r51,0; @ %r52 bra $L4; .loc 1 37 0 setp.gt.s32 %r53,%r32,8388607; @ %r53 bra $L5; .loc 1 38 0 mul.f32 %r54,%r38,0f4c000000; .loc 1 39 0 mov.b32 %r31,%r54; .loc 1 40 0 and.b32 %r32,%r31,2147483647; mov.u32 %r36,-25; bra $L3; $L5: mov.u32 %r36,%r40; $L3: .loc 1 43 0 shr.s32 %r55,%r32,23; add.u32 %r56,%r55,-126; add.u32 %r57,%r56,%r36; st.u32 [%r39],%r57; .loc 1 44 0 and.b32 %r58,%r31,-2139095041; or.b32 %r59,%r58,1056964608; .loc 1 45 0 mov.b32 %r37,%r59; .loc 1 46 0 bra $L1; $L4: .loc 1 36 0 mov.f32 %r37,%r38; $L1: .loc 1 47 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /1003 0 0 0 644 1243 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ilogbf .visible .func (.param .u32 %value_out) ilogbf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_ilogb.c" // BEGIN GLOBAL FUNCTION DEF: ilogbf .visible .func (.param .u32 %value_out) ilogbf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r26; .reg .u32 %r27; .reg .u32 %r29; .reg .u32 %r30; .reg .f32 %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r35; .reg .pred %r36; .reg .u32 %r37; mov.f32 %r31,%ar0; .loc 1 28 0 mov.b32 %r26,%r31; .loc 1 29 0 and.b32 %r27,%r26,2147483647; .loc 1 30 0 setp.eq.u32 %r32,%r27,0; @ %r32 bra $L5; .loc 1 32 0 setp.gt.s32 %r33,%r27,8388607; @ %r33 bra $L3; .loc 1 33 0 shl.b32 %r29,%r27,8; mov.u32 %r30,-126; $L4: add.u32 %r30,%r30,-1; add.u32 %r29,%r29,%r29; setp.gt.s32 %r35,%r29,0; @ %r35 bra $L4; bra $L1; $L3: .loc 1 39 0 setp.gt.s32 %r36,%r27,2139095039; @ %r36 bra $L6; .loc 1 40 0 shr.s32 %r37,%r27,23; add.u32 %r30,%r37,-127; bra $L1; $L5: .loc 1 31 0 mov.u32 %r30,-2147483647; bra $L1; $L6: .loc 1 39 0 mov.u32 %r30,2147483647; $L1: .loc 1 41 0 mov.u32 %value,%r30; st.param.u32 [%value_out],%value; ret; } /1021 0 0 0 644 433 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: infinityf .visible .func (.param .f32 %value_out) infinityf; .file 1 "../../../../../../newlib/libm/common/sf_infinity.c" // BEGIN GLOBAL FUNCTION DEF: infinityf .visible .func (.param .f32 %value_out) infinityf { .reg .f32 %value; .loc 1 13 0 mov.f32 %value,0f7f800000; .loc 1 14 0 st.param.f32 [%value_out],%value; ret; } /1042 0 0 0 644 694 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 21 0 mov.b32 %r23,%r27; .loc 1 22 0 and.b32 %r29,%r23,2147483647; .loc 1 23 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 24 0 st.param.u32 [%value_out],%value; ret; } /1060 0 0 0 644 703 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isinff.c" // BEGIN GLOBAL FUNCTION DEF: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 13 0 mov.b32 %r23,%r27; .loc 1 14 0 and.b32 %r29,%r23,2147483647; .loc 1 15 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 16 0 st.param.u32 [%value_out],%value; ret; } /1079 0 0 0 644 694 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /1097 0 0 0 644 703 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isnanf.c" // BEGIN GLOBAL FUNCTION DEF: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 23 0 mov.b32 %r23,%r27; .loc 1 24 0 and.b32 %r29,%r23,2147483647; .loc 1 25 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 26 0 st.param.u32 [%value_out],%value; ret; } /1116 0 0 0 644 2583 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/sf_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f32 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f32 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f32 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 26 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f32 %r37,%r32,0f00000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 27 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } mov.f32 %r32,%r50; .loc 1 28 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f32 %r54,%r32,0f00000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 30 0 mov.f32 %value,%r32; st.param.f32 [%value_out],%value; ret; } /1134 0 0 0 644 2785 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llrintf .visible .func (.param .u64 %value_out) llrintf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_llrint.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: TWO23 .const .align 4 .u32 TWO23[2] = {1258291200,3405774848 }; // BEGIN GLOBAL FUNCTION DEF: llrintf .visible .func (.param .u64 %value_out) llrintf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u32 %r22; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .u32 %r40; .reg .u32 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .f32 %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .f32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; mov.f32 %r48,%ar0; .loc 1 53 0 mov.b32 %r45,%r48; .loc 1 59 0 shr.u32 %r49,%r45,23; and.b32 %r50,%r49,255; add.u32 %r40,%r50,-127; .loc 1 61 0 setp.gt.s32 %r51,%r40,62; @ %r51 bra $L2; .loc 1 63 0 setp.ge.s32 %r52,%r40,-1; @ %r52 bra $L3; $L7: .loc 1 64 0 mov.u64 %r47,0; bra $L1; $L3: .loc 1 56 0 shr.u32 %r22,%r45,31; .loc 1 65 0 setp.le.s32 %r53,%r40,22; @ %r53 bra $L5; .loc 1 66 0 and.b32 %r54,%r45,8388607; or.b32 %r55,%r54,8388608; cvt.u64.u32 %r56,%r55; add.u32 %r57,%r50,-150; shl.b64 %r47,%r56,%r57; bra $L6; $L5: .loc 1 69 0 cvta.const.u64 %r58,TWO23; cvt.s64.s32 %r59,%r22; shl.b64 %r60,%r59,2; add.u64 %r61,%r58,%r60; ld.f32 %r30,[%r61]; add.f32 %r31,%r30,%r48; st.f32 [%frame],%r31; .loc 1 70 0 ld.f32 %r32,[%frame]; sub.f32 %r62,%r32,%r30; .loc 1 71 0 mov.b32 %r46,%r62; .loc 1 74 0 and.b32 %r63,%r46,2147483647; setp.eq.u32 %r64,%r63,0; @ %r64 bra $L7; .loc 1 77 0 and.b32 %r43,%r46,8388607; .loc 1 78 0 or.b32 %r65,%r43,8388608; .loc 1 76 0 shr.u32 %r66,%r46,23; and.b32 %r67,%r66,255; .loc 1 79 0 mov.u32 %r70,150; sub.u32 %r69,%r70,%r67; shr.u32 %r71,%r65,%r69; cvt.u64.u32 %r47,%r71; bra $L6; $L2: .loc 1 84 0 cvt.rzi.s64.f32 %r47,%r48; bra $L1; $L6: .loc 1 86 0 setp.eq.u32 %r72,%r22,0; @ %r72 bra $L1; neg.s64 %r47,%r47; $L1: .loc 1 87 0 mov.u64 %value,%r47; st.param.u64 [%value_out],%value; ret; } /1153 0 0 0 644 1865 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llroundf .visible .func (.param .u64 %value_out) llroundf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_llround.c" // BEGIN GLOBAL FUNCTION DEF: llroundf .visible .func (.param .u64 %value_out) llroundf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u64 %r40; .reg .f32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r57; mov.f32 %r41,%ar0; .loc 1 23 0 mov.b32 %r36,%r41; .loc 1 24 0 shr.u32 %r42,%r36,23; and.b32 %r43,%r42,255; add.u32 %r35,%r43,-127; .loc 1 25 0 setp.lt.s32 %r44,%r36,0; selp.u32 %r34,-1,1,%r44; .loc 1 29 0 setp.gt.s32 %r45,%r35,62; @ %r45 bra $L3; .loc 1 31 0 setp.ge.s32 %r46,%r35,0; @ %r46 bra $L4; .loc 1 32 0 setp.ne.u32 %r47,%r35,-1; @ %r47 bra $L9; cvt.s64.s32 %r40,%r34; bra $L1; $L4: .loc 1 26 0 and.b32 %r37,%r36,8388607; .loc 1 27 0 or.b32 %r38,%r37,8388608; .loc 1 33 0 setp.le.s32 %r48,%r35,22; @ %r48 bra $L6; .loc 1 34 0 cvt.u64.u32 %r49,%r38; add.u32 %r50,%r43,-150; shl.b64 %r33,%r49,%r50; bra $L7; $L6: .loc 1 37 0 mov.u32 %r52,4194304; shr.s32 %r51,%r52,%r35; add.u32 %r53,%r51,%r38; .loc 1 38 0 mov.u32 %r55,23; sub.u32 %r54,%r55,%r35; shr.u32 %r56,%r53,%r54; cvt.u64.u32 %r33,%r56; bra $L7; $L3: .loc 1 42 0 cvt.rzi.s64.f32 %r40,%r41; bra $L1; $L7: .loc 1 44 0 cvt.s64.s32 %r57,%r34; mul.lo.u64 %r40,%r57,%r33; bra $L1; $L9: .loc 1 32 0 mov.u64 %r40,0; $L1: .loc 1 45 0 mov.u64 %value,%r40; st.param.u64 [%value_out],%value; ret; } /1173 0 0 0 644 5661 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log1pf .visible .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_log1p.c" // BEGIN GLOBAL FUNCTION DEF: log1pf .visible .func (.param .f32 %value_out) log1pf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r22; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r36; .reg .f32 %r48; .reg .f32 %r54; .reg .f32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .f32 %r61; .reg .u32 %r62; .reg .f32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r67; .reg .f32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .f32 %r84; .reg .pred %r85; .reg .f32 %r86; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r91; .reg .u32 %r92; .reg .u16 %r93; .reg .u16 %r94; .reg .u16 %r95; .reg .u32 %r96; .reg .u16 %r97; .reg .pred %r98; .reg .f32 %r99; .reg .u32 %r101; .reg .pred %r102; .reg .f32 %r103; .reg .pred %r104; .reg .u32 %r105; .reg .pred %r106; .reg .f32 %r107; .reg .f32 %r108; .reg .f32 %r109; .reg .f32 %r110; .reg .u32 %r111; .reg .pred %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .f32 %r116; .reg .f32 %r117; .reg .pred %r118; .reg .pred %r119; .reg .pred %r120; .reg .f32 %r121; .reg .f32 %r123; .reg .pred %r124; .reg .f32 %r125; .reg .f32 %r126; .reg .f32 %r127; .reg .f32 %r128; .reg .f32 %r129; .reg .f32 %r130; .reg .f32 %r131; .reg .f32 %r132; .reg .f32 %r133; .reg .f32 %r134; .reg .f32 %r135; .reg .f32 %r136; .reg .pred %r137; .reg .f32 %r138; .reg .f32 %r139; .reg .f32 %r140; .reg .f32 %r141; .reg .f32 %r142; .reg .f32 %r143; mov.f32 %r79,%ar0; .loc 1 50 0 mov.b32 %r58,%r79; .loc 1 54 0 setp.le.s32 %r80,%r58,2139095039; @ %r80 bra $L2; add.f32 %r78,%r79,%r79; bra $L1; $L2: .loc 1 55 0 setp.gt.s32 %r81,%r58,1054086102; @ %r81 bra $L4; .loc 1 51 0 and.b32 %r62,%r58,2147483647; .loc 1 56 0 setp.le.s32 %r82,%r62,1065353215; @ %r82 bra $L5; .loc 1 57 0 setp.neu.f32 %r83,%r79,0fbf800000; @ %r83 bra $L6; mov.f32 %r84,0fcc000000; div.rn.f32 %r78,%r84,0f00000000; bra $L1; $L6: .loc 1 58 0 sub.f32 %r22,%r79,%r79; div.rn.f32 %r78,%r22,%r22; bra $L1; $L5: .loc 1 60 0 setp.gt.s32 %r85,%r62,822083583; @ %r85 bra $L7; .loc 1 61 0 add.f32 %r86,%r79,0f4c000000; set.u32.gt.f32 %r88,%r86,0f00000000; neg.s32 %r89,%r88; .loc 1 62 0 set.u32.le.s32 %r91,%r62,612368383; neg.s32 %r92,%r91; cvt.u16.u32 %r94,%r89; cvt.u16.u32 %r95,%r92; and.b16 %r93,%r94,%r95; cvt.u32.u16 %r96,%r93; cvt.u16.u8 %r97,%r96; setp.ne.u16 %r98,%r97,0; @ %r98 bra $L19; .loc 1 65 0 mul.f32 %r99,%r79,%r79; fma.rn.f32 %r78,%r99,0fbf000000,%r79; bra $L1; $L7: .loc 1 67 0 add.u32 %r101,%r58,1097468384; setp.le.u32 %r102,%r101,1097468384; @ %r102 bra $L8; .loc 1 94 0 mul.f32 %r103,%r79,0f3f000000; mul.f32 %r64,%r103,%r79; .loc 1 68 0 mov.u32 %r57,0; bra $L9; $L4: .loc 1 71 0 setp.gt.s32 %r104,%r58,1509949439; @ %r104 bra $L10; $L8: .loc 1 72 0 add.f32 %r63,%r79,0f3f800000; .loc 1 73 0 mov.b32 %r58,%r63; .loc 1 74 0 shr.s32 %r105,%r58,23; add.u32 %r57,%r105,-127; .loc 1 76 0 setp.le.s32 %r106,%r57,0; @ %r106 bra $L11; sub.f32 %r107,%r63,%r79; mov.f32 %r108,0f3f800000; sub.f32 %r61,%r108,%r107; bra $L12; $L11: mov.f32 %r110,0f3f800000; sub.f32 %r109,%r63,%r110; sub.f32 %r61,%r79,%r109; $L12: .loc 1 77 0 div.rn.f32 %r54,%r61,%r63; bra $L13; $L10: .loc 1 81 0 shr.s32 %r111,%r58,23; add.u32 %r57,%r111,-127; .loc 1 82 0 mov.f32 %r54,0f00000000; $L13: .loc 1 84 0 and.b32 %r59,%r58,8388607; .loc 1 85 0 setp.gt.s32 %r112,%r59,3474678; @ %r112 bra $L14; .loc 1 86 0 or.b32 %r113,%r59,1065353216; mov.b32 %r55,%r113; bra $L15; $L14: .loc 1 88 0 add.u32 %r57,%r57,1; .loc 1 89 0 or.b32 %r114,%r59,1056964608; mov.b32 %r55,%r114; .loc 1 90 0 mov.u32 %r115,8388608; sub.u32 %r32,%r115,%r59; shr.s32 %r59,%r32,2; $L15: .loc 1 92 0 mov.f32 %r116,0f3f800000; sub.f32 %r79,%r55,%r116; .loc 1 94 0 mul.f32 %r117,%r79,0f3f000000; mul.f32 %r64,%r117,%r79; .loc 1 95 0 setp.ne.u32 %r118,%r59,0; @ %r118 bra $L9; .loc 1 96 0 setp.neu.f32 %r119,%r79,0f00000000; @ %r119 bra $L16; setp.eq.u32 %r120,%r57,0; @ %r120 bra $L20; .loc 1 97 0 cvt.rn.f32.s32 %r34,%r57; fma.rn.f32 %r121,%r34,0f3717f7d1,%r54; fma.rn.f32 %r78,%r34,0f3f317180,%r121; bra $L1; $L16: .loc 1 98 0 fma.rn.f32 %r123,%r79,0fbf2aaaab,0f3f800000; mul.f32 %r67,%r123,%r64; .loc 1 99 0 setp.ne.u32 %r124,%r57,0; @ %r124 bra $L17; sub.f32 %r78,%r79,%r67; bra $L1; $L17: .loc 1 100 0 cvt.rn.f32.s32 %r36,%r57; fma.rn.f32 %r125,%r36,0f3717f7d1,%r54; sub.f32 %r126,%r67,%r125; sub.f32 %r127,%r126,%r79; neg.f32 %r128,%r127; fma.rn.f32 %r78,%r36,0f3f317180,%r128; bra $L1; $L9: .loc 1 102 0 add.f32 %r129,%r79,0f40000000; div.rn.f32 %r65,%r79,%r129; .loc 1 103 0 mul.f32 %r66,%r65,%r65; .loc 1 104 0 fma.rn.f32 %r130,%r66,0f3e178897,0f3e1cd04f; fma.rn.f32 %r131,%r130,%r66,0f3e3a3325; fma.rn.f32 %r132,%r131,%r66,0f3e638e29; fma.rn.f32 %r133,%r132,%r66,0f3e924925; fma.rn.f32 %r134,%r133,%r66,0f3ecccccd; fma.rn.f32 %r135,%r134,%r66,0f3f2aaaab; fma.rn.f32 %r136,%r135,%r66,%r64; mul.f32 %r77,%r136,%r65; .loc 1 105 0 setp.ne.u32 %r137,%r57,0; @ %r137 bra $L18; sub.f32 %r138,%r64,%r77; sub.f32 %r78,%r79,%r138; bra $L1; $L18: .loc 1 106 0 cvt.rn.f32.s32 %r48,%r57; fma.rn.f32 %r139,%r48,0f3717f7d1,%r54; add.f32 %r140,%r139,%r77; sub.f32 %r141,%r64,%r140; sub.f32 %r142,%r141,%r79; neg.f32 %r143,%r142; fma.rn.f32 %r78,%r48,0f3f317180,%r143; bra $L1; $L19: .loc 1 63 0 mov.f32 %r78,%r79; bra $L1; $L20: .loc 1 96 0 mov.f32 %r78,0f00000000; $L1: .loc 1 107 0 mov.f32 %value,%r78; st.param.f32 [%value_out],%value; ret; } lib_a-sf_log2.o/0 0 0 644 811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: log2f .visible .func (.param .f32 %value_out) log2f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_log2.c" // BEGIN GLOBAL FUNCTION DECL: logf .extern .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: log2f .visible .func (.param .f32 %value_out) log2f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r24,%ar0; .loc 1 33 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),logf,(%out_arg1); ld.param.f32 %r26,[%value_in]; } div.rn.f32 %value,%r26,0f3f317218; .loc 1 34 0 st.param.f32 [%value_out],%value; ret; } lib_a-sf_logb.o/0 0 0 644 1506 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: logbf .visible .func (.param .f32 %value_out) logbf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_logb.c" // BEGIN GLOBAL FUNCTION DEF: logbf .visible .func (.param .f32 %value_out) logbf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r31; .reg .f32 %r32; .reg .f32 %r33; .reg .pred %r34; .reg .f32 %r35; .reg .pred %r36; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .u32 %r41; .reg .u32 %r42; mov.f32 %r33,%ar0; .loc 1 33 0 mov.b32 %r27,%r33; .loc 1 34 0 and.b32 %r28,%r27,2147483647; .loc 1 35 0 setp.ne.u32 %r34,%r28,0; @ %r34 bra $L2; .loc 1 39 0 mov.f32 %r35,0fbf800000; div.rn.f32 %r32,%r35,0f00000000; bra $L1; $L2: .loc 1 41 0 setp.gt.s32 %r36,%r28,8388607; @ %r36 bra $L4; .loc 1 42 0 shl.b32 %r31,%r28,8; mov.u32 %r30,-126; $L5: add.u32 %r30,%r30,-1; add.u32 %r31,%r31,%r31; setp.gt.s32 %r38,%r31,0; @ %r38 bra $L5; .loc 1 43 0 cvt.rn.f32.s32 %r32,%r30; bra $L1; $L4: .loc 1 45 0 setp.eq.u32 %r39,%r28,2139095040; @ %r39 bra $L6; .loc 1 46 0 setp.gt.s32 %r40,%r28,2139095040; @ %r40 bra $L7; .loc 1 47 0 shr.s32 %r41,%r28,23; add.u32 %r42,%r41,-127; cvt.rn.f32.s32 %r32,%r42; bra $L1; $L6: .loc 1 45 0 mov.f32 %r32,0f7f800000; bra $L1; $L7: .loc 1 46 0 mov.f32 %r32,%r33; $L1: .loc 1 48 0 mov.f32 %value,%r32; st.param.f32 [%value_out],%value; ret; } /1191 0 0 0 644 2820 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lrintf .visible .func (.param .u64 %value_out) lrintf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_lrint.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: TWO23 .const .align 4 .u32 TWO23[2] = {1258291200,3405774848 }; // BEGIN GLOBAL FUNCTION DEF: lrintf .visible .func (.param .u64 %value_out) lrintf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u32 %r22; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r32; .reg .u32 %r41; .reg .u32 %r44; .reg .u32 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .f32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .f32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .pred %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; mov.f32 %r49,%ar0; .loc 1 53 0 mov.b32 %r46,%r49; .loc 1 59 0 shr.u32 %r50,%r46,23; and.b32 %r51,%r50,255; add.u32 %r41,%r51,-127; .loc 1 61 0 setp.gt.s32 %r52,%r41,62; @ %r52 bra $L2; .loc 1 63 0 setp.ge.s32 %r53,%r41,-1; @ %r53 bra $L3; $L7: .loc 1 64 0 mov.u64 %r48,0; bra $L1; $L3: .loc 1 56 0 shr.u32 %r22,%r46,31; .loc 1 65 0 setp.le.s32 %r54,%r41,22; @ %r54 bra $L5; .loc 1 66 0 and.b32 %r55,%r46,8388607; or.b32 %r56,%r55,8388608; cvt.u64.u32 %r57,%r56; add.u32 %r58,%r51,-150; shl.b64 %r48,%r57,%r58; bra $L6; $L5: .loc 1 69 0 cvta.const.u64 %r59,TWO23; cvt.s64.s32 %r60,%r22; shl.b64 %r61,%r60,2; add.u64 %r62,%r59,%r61; ld.f32 %r30,[%r62]; add.f32 %r31,%r30,%r49; st.f32 [%frame],%r31; .loc 1 70 0 ld.f32 %r32,[%frame]; sub.f32 %r63,%r32,%r30; .loc 1 71 0 mov.b32 %r47,%r63; .loc 1 74 0 cvt.u64.u32 %r64,%r47; and.b64 %r65,%r64,-2147483649; setp.eq.u64 %r66,%r65,0; @ %r66 bra $L7; .loc 1 77 0 and.b32 %r44,%r47,8388607; .loc 1 78 0 or.b32 %r67,%r44,8388608; .loc 1 76 0 shr.u32 %r68,%r47,23; and.b32 %r69,%r68,255; .loc 1 79 0 mov.u32 %r72,150; sub.u32 %r71,%r72,%r69; shr.u32 %r73,%r67,%r71; cvt.u64.u32 %r48,%r73; bra $L6; $L2: .loc 1 84 0 cvt.rzi.s64.f32 %r48,%r49; bra $L1; $L6: .loc 1 86 0 setp.eq.u32 %r74,%r22,0; @ %r74 bra $L1; neg.s64 %r48,%r48; $L1: .loc 1 87 0 mov.u64 %value,%r48; st.param.u64 [%value_out],%value; ret; } /1209 0 0 0 644 1860 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lroundf .visible .func (.param .u64 %value_out) lroundf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_lround.c" // BEGIN GLOBAL FUNCTION DEF: lroundf .visible .func (.param .u64 %value_out) lroundf (.param .f32 %in_ar0) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u64 %r40; .reg .f32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r57; mov.f32 %r41,%ar0; .loc 1 26 0 mov.b32 %r36,%r41; .loc 1 27 0 shr.u32 %r42,%r36,23; and.b32 %r43,%r42,255; add.u32 %r35,%r43,-127; .loc 1 28 0 setp.lt.s32 %r44,%r36,0; selp.u32 %r34,-1,1,%r44; .loc 1 32 0 setp.gt.s32 %r45,%r35,62; @ %r45 bra $L3; .loc 1 34 0 setp.ge.s32 %r46,%r35,0; @ %r46 bra $L4; .loc 1 35 0 setp.ne.u32 %r47,%r35,-1; @ %r47 bra $L9; cvt.s64.s32 %r40,%r34; bra $L1; $L4: .loc 1 29 0 and.b32 %r37,%r36,8388607; .loc 1 30 0 or.b32 %r38,%r37,8388608; .loc 1 36 0 setp.le.s32 %r48,%r35,22; @ %r48 bra $L6; .loc 1 37 0 cvt.u64.u32 %r49,%r38; add.u32 %r50,%r43,-150; shl.b64 %r33,%r49,%r50; bra $L7; $L6: .loc 1 40 0 mov.u32 %r52,4194304; shr.s32 %r51,%r52,%r35; add.u32 %r53,%r51,%r38; .loc 1 41 0 mov.u32 %r55,23; sub.u32 %r54,%r55,%r35; shr.u32 %r56,%r53,%r54; cvt.u64.u32 %r33,%r56; bra $L7; $L3: .loc 1 45 0 cvt.rzi.s64.f32 %r40,%r41; bra $L1; $L7: .loc 1 47 0 cvt.s64.s32 %r57,%r34; mul.lo.u64 %r40,%r57,%r33; bra $L1; $L9: .loc 1 35 0 mov.u64 %r40,0; $L1: .loc 1 48 0 mov.u64 %value,%r40; st.param.u64 [%value_out],%value; ret; } lib_a-sf_modf.o/0 0 0 644 1776 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_modf.c" // BEGIN GLOBAL FUNCTION DEF: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r31; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .f32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r35,%r38; .loc 1 34 0 shr.s32 %r40,%r35,23; and.b32 %r41,%r40,255; add.u32 %r34,%r41,-127; .loc 1 35 0 setp.gt.s32 %r42,%r34,22; @ %r42 bra $L2; .loc 1 36 0 setp.ge.s32 %r43,%r34,0; @ %r43 bra $L3; .loc 1 37 0 and.b32 %r44,%r35,-2147483648; mov.b32 %r45,%r44; st.f32 [%r39],%r45; .loc 1 38 0 mov.f32 %r37,%r38; bra $L1; $L3: .loc 1 40 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r34; .loc 1 41 0 and.b32 %r47,%r35,%r36; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L5; .loc 1 43 0 st.f32 [%r39],%r38; .loc 1 45 0 and.b32 %r49,%r35,-2147483648; mov.b32 %r37,%r49; .loc 1 46 0 bra $L1; $L5: .loc 1 48 0 not.b32 %r50,%r36; and.b32 %r51,%r50,%r35; mov.b32 %r31,%r51; st.f32 [%r39],%r31; .loc 1 49 0 sub.f32 %r37,%r38,%r31; bra $L1; $L2: .loc 1 54 0 st.f32 [%r39],%r38; .loc 1 56 0 and.b32 %r52,%r35,-2147483648; mov.b32 %r37,%r52; $L1: .loc 1 59 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_nan.o/ 0 0 0 644 497 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_nan.c" // BEGIN GLOBAL FUNCTION DEF: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 17 0 mov.f32 %value,0f7fc00000; .loc 1 18 0 st.param.f32 [%value_out],%value; ret; } /1228 0 0 0 644 825 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nearbyintf .visible .func (.param .f32 %value_out) nearbyintf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_nearbyint.c" // BEGIN GLOBAL FUNCTION DECL: rintf .extern .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: nearbyintf .visible .func (.param .f32 %value_out) nearbyintf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r25; mov.f32 %r23,%ar0; .loc 1 23 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r23; call (%value_in),rintf,(%out_arg1); ld.param.f32 %r25,[%value_in]; } .loc 1 24 0 mov.f32 %value,%r25; st.param.f32 [%value_out],%value; ret; } /1250 0 0 0 644 2810 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nextafterf .visible .func (.param .f32 %value_out) nextafterf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_nextafter.c" // BEGIN GLOBAL FUNCTION DEF: nextafterf .visible .func (.param .f32 %value_out) nextafterf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r33; .reg .u32 %r37; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .u32 %r42; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; .reg .u16 %r49; .reg .u16 %r50; .reg .u16 %r51; .reg .u32 %r52; .reg .u16 %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .pred %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .u32 %r67; .reg .u16 %r69; .reg .u16 %r70; .reg .u16 %r71; .reg .u32 %r72; .reg .u16 %r73; .reg .pred %r74; .reg .u32 %r75; .reg .pred %r76; mov.f32 %r40,%ar0; mov.f32 %r41,%ar1; .loc 1 27 0 mov.b32 %r31,%r40; .loc 1 28 0 mov.b32 %r37,%r41; .loc 1 29 0 and.b32 %r33,%r31,2147483647; .loc 1 30 0 and.b32 %r42,%r37,2147483647; .loc 1 33 0 set.u32.gt.s32 %r44,%r42,2139095040; neg.s32 %r45,%r44; .loc 1 32 0 set.u32.gt.s32 %r47,%r33,2139095040; neg.s32 %r48,%r47; cvt.u16.u32 %r50,%r45; cvt.u16.u32 %r51,%r48; or.b16 %r49,%r50,%r51; cvt.u32.u16 %r52,%r49; cvt.u16.u8 %r53,%r52; setp.eq.u16 %r54,%r53,0; @ %r54 bra $L2; .loc 1 34 0 add.f32 %r39,%r40,%r41; bra $L1; $L2: .loc 1 35 0 setp.eq.f32 %r55,%r40,%r41; @ %r55 bra $L10; .loc 1 36 0 setp.ne.u32 %r56,%r33,0; @ %r56 bra $L4; .loc 1 37 0 and.b32 %r57,%r37,-2147483648; or.b32 %r58,%r57,1; mov.b32 %r39,%r58; .loc 1 38 0 mul.f32 %r38,%r39,%r39; .loc 1 39 0 setp.neu.f32 %r59,%r39,%r38; selp.f32 %r39,%r39,%r38,%r59; bra $L1; $L4: .loc 1 41 0 setp.lt.s32 %r60,%r31,0; @ %r60 bra $L5; .loc 1 42 0 setp.le.s32 %r61,%r31,%r37; @ %r61 bra $L6; .loc 1 43 0 add.u32 %r30,%r31,-1; bra $L7; $L6: .loc 1 45 0 add.u32 %r30,%r31,1; bra $L7; $L5: .loc 1 48 0 not.b32 %r63,%r37; shr.u32 %r64,%r63,31; set.u32.gt.s32 %r66,%r31,%r37; neg.s32 %r67,%r66; cvt.u16.u32 %r70,%r64; cvt.u16.u32 %r71,%r67; or.b16 %r69,%r70,%r71; cvt.u32.u16 %r72,%r69; cvt.u16.u8 %r73,%r72; setp.eq.u16 %r74,%r73,0; @ %r74 bra $L8; .loc 1 49 0 add.u32 %r30,%r31,-1; bra $L7; $L8: .loc 1 51 0 add.u32 %r30,%r31,1; $L7: .loc 1 54 0 and.b32 %r75,%r30,2139095040; .loc 1 55 0 setp.ne.u32 %r76,%r75,2139095040; @ %r76 bra $L9; add.f32 %r39,%r40,%r40; bra $L1; $L9: mov.b32 %r39,%r30; bra $L1; $L10: .loc 1 35 0 mov.f32 %r39,%r40; $L1: .loc 1 65 0 mov.f32 %value,%r39; st.param.f32 [%value_out],%value; ret; } /1272 0 0 0 644 928 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: pow10f .visible .func (.param .f32 %value_out) pow10f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_pow10.c" // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: pow10f .visible .func (.param .f32 %value_out) pow10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r23,%ar0; .loc 1 32 0 mov.f32 %r24,0f41200000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r23; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 33 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } /1290 0 0 0 644 7551 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: remquof .visible .func (.param .f32 %value_out) remquof (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/common/sf_remquo.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN VAR DEF: Zero .const .align 4 .u32 Zero[2] = {0,2147483648 }; // BEGIN GLOBAL FUNCTION DEF: remquof .visible .func (.param .f32 %value_out) remquof (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u64 %in_ar2) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r34; .reg .f32 %r37; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r47; .reg .f32 %r50; .reg .f32 %r52; .reg .u32 %r54; .reg .f32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r81; .reg .u32 %r84; .reg .f32 %r86; .reg .f32 %r87; .reg .f32 %r88; .reg .u64 %r89; .reg .u32 %r91; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u16 %r96; .reg .u16 %r97; .reg .u16 %r98; .reg .u32 %r100; .reg .u32 %r101; .reg .u16 %r103; .reg .u16 %r105; .reg .u32 %r106; .reg .u16 %r107; .reg .pred %r108; .reg .u32 %r109; .reg .pred %r110; .reg .pred %r111; .reg .u32 %r112; .reg .u64 %r113; .reg .u32 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .pred %r118; .reg .pred %r119; .reg .pred %r121; .reg .u32 %r122; .reg .pred %r123; .reg .pred %r124; .reg .pred %r126; .reg .u32 %r127; .reg .pred %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r132; .reg .u32 %r133; .reg .pred %r134; .reg .pred %r135; .reg .pred %r139; .reg .pred %r140; .reg .pred %r141; .reg .pred %r142; .reg .pred %r143; .reg .u64 %r144; .reg .u32 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u64 %r148; .reg .pred %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .f32 %r157; .reg .pred %r158; .reg .pred %r159; .reg .pred %r160; .reg .u32 %r161; .reg .pred %r162; .reg .pred %r163; .reg .pred %r164; .reg .u32 %r165; .reg .pred %r166; .reg .u32 %r167; .reg .pred %r168; .reg .pred %r170; mov.f32 %r87,%ar0; mov.f32 %r88,%ar1; mov.u64 %r89,%ar2; .loc 1 42 0 mov.b32 %r63,%r87; .loc 1 43 0 mov.b32 %r64,%r88; .loc 1 46 0 and.b32 %r58,%r63,2147483647; .loc 1 47 0 and.b32 %r66,%r64,2147483647; .loc 1 50 0 set.u32.eq.u32 %r91,%r66,0; neg.s32 %r92,%r91; set.u32.gt.s32 %r94,%r66,2139095040; neg.s32 %r95,%r94; cvt.u16.u32 %r97,%r92; cvt.u16.u32 %r98,%r95; or.b16 %r96,%r97,%r98; set.u32.gt.s32 %r100,%r58,2139095039; neg.s32 %r101,%r100; cvt.u16.u32 %r105,%r101; or.b16 %r103,%r96,%r105; cvt.u32.u16 %r106,%r103; cvt.u16.u8 %r107,%r106; setp.eq.u16 %r108,%r107,0; @ %r108 bra $L2; .loc 1 51 0 mov.u32 %r109,0; st.u32 [%r89],%r109; .loc 1 52 0 mul.f32 %r37,%r87,%r88; div.rn.f32 %r86,%r37,%r37; bra $L1; $L2: .loc 1 44 0 xor.b32 %r34,%r63,%r64; .loc 1 45 0 and.b32 %r65,%r63,-2147483648; .loc 1 54 0 setp.lt.s32 %r110,%r58,%r66; @ %r110 bra $L34; .loc 1 57 0 setp.ne.u32 %r111,%r58,%r66; @ %r111 bra $L5; .loc 1 58 0 mov.u32 %r112,1; st.u32 [%r89],%r112; .loc 1 59 0 cvta.const.u64 %r113,Zero; shr.u32 %r114,%r65,31; cvt.u64.u32 %r115,%r114; shl.b64 %r116,%r115,2; add.u64 %r117,%r113,%r116; ld.f32 %r86,[%r117]; bra $L1; $L5: .loc 1 63 0 setp.gt.s32 %r118,%r58,8388607; @ %r118 bra $L6; .loc 1 64 0 shl.b32 %r69,%r58,8; setp.eq.u32 %r119,%r69,0; @ %r119 bra $L35; mov.u32 %r68,-126; $L8: add.u32 %r68,%r68,-1; add.u32 %r69,%r69,%r69; setp.gt.s32 %r121,%r69,0; @ %r121 bra $L8; bra $L7; $L6: .loc 1 65 0 shr.s32 %r122,%r58,23; add.u32 %r68,%r122,-127; bra $L7; $L35: .loc 1 64 0 mov.u32 %r68,-126; $L7: .loc 1 68 0 setp.gt.s32 %r123,%r66,8388607; @ %r123 bra $L9; .loc 1 69 0 shl.b32 %r72,%r66,8; setp.eq.u32 %r124,%r72,0; @ %r124 bra $L36; mov.u32 %r71,-126; $L11: add.u32 %r71,%r71,-1; add.u32 %r72,%r72,%r72; setp.gt.s32 %r126,%r72,0; @ %r126 bra $L11; bra $L10; $L9: .loc 1 70 0 shr.s32 %r127,%r66,23; add.u32 %r71,%r127,-127; bra $L10; $L36: .loc 1 69 0 mov.u32 %r71,-126; $L10: .loc 1 73 0 setp.lt.s32 %r128,%r68,-126; @ %r128 bra $L12; .loc 1 74 0 and.b32 %r42,%r63,8388607; or.b32 %r57,%r42,8388608; bra $L13; $L12: .loc 1 76 0 mov.u32 %r130,-126; sub.u32 %r129,%r130,%r68; .loc 1 77 0 shl.b32 %r57,%r58,%r129; $L13: .loc 1 79 0 setp.lt.s32 %r170,%r71,-126; @ %r170 bra $L14; .loc 1 80 0 and.b32 %r43,%r64,8388607; or.b32 %r59,%r43,8388608; bra $L15; $L14: .loc 1 82 0 mov.u32 %r133,-126; sub.u32 %r132,%r133,%r71; .loc 1 83 0 shl.b32 %r59,%r66,%r132; $L15: .loc 1 87 0 sub.u32 %r75,%r68,%r71; .loc 1 89 0 add.u32 %r77,%r75,-1; setp.eq.u32 %r134,%r75,0; @ %r134 bra $L37; .loc 1 88 0 mov.u32 %r60,0; $L19: .loc 1 90 0 sub.u32 %r81,%r57,%r59; .loc 1 91 0 setp.ge.s32 %r135,%r81,0; @ %r135 bra $L17; add.u32 %r57,%r57,%r57; bra $L18; $L17: .loc 1 92 0 add.u32 %r57,%r81,%r81; add.u32 %r60,%r60,1; $L18: .loc 1 93 0 add.u32 %r60,%r60,%r60; .loc 1 89 0 add.u32 %r77,%r77,-1; setp.ne.u32 %r139,%r77,-1; @ %r139 bra $L19; bra $L16; $L37: .loc 1 88 0 mov.u32 %r60,%r75; $L16: .loc 1 95 0 sub.u32 %r78,%r57,%r59; .loc 1 96 0 setp.lt.s32 %r140,%r78,0; @ %r140 bra $L20; add.u32 %r60,%r60,1; mov.u32 %r57,%r78; $L20: .loc 1 99 0 setp.eq.u32 %r141,%r57,0; @ %r141 bra $L21; .loc 1 103 0 setp.le.s32 %r142,%r57,8388607; @ %r142 bra $L22; bra $L23; $L21: .loc 1 100 0 setp.ge.s32 %r143,%r34,0; @ %r143 bra $L24; neg.s32 %r61,%r60; bra $L25; $L24: mov.u32 %r61,%r60; $L25: st.u32 [%r89],%r61; .loc 1 101 0 cvta.const.u64 %r144,Zero; shr.u32 %r145,%r65,31; cvt.u64.u32 %r146,%r145; shl.b64 %r147,%r146,2; add.u64 %r148,%r144,%r147; ld.f32 %r86,[%r148]; bra $L1; $L22: .loc 1 104 0 add.u32 %r57,%r57,%r57; .loc 1 105 0 add.u32 %r71,%r71,-1; .loc 1 103 0 setp.le.s32 %r150,%r57,8388607; @ %r150 bra $L22; setp.lt.s32 %r170,%r71,-126; $L23: .loc 1 107 0 @ %r170 bra $L26; .loc 1 108 0 add.u32 %r47,%r57,-8388608; add.u32 %r152,%r71,127; shl.b32 %r153,%r152,23; or.b32 %r58,%r153,%r47; bra $L4; $L26: .loc 1 110 0 mov.u32 %r155,-126; sub.u32 %r154,%r155,%r71; .loc 1 111 0 shr.s32 %r58,%r57,%r154; bra $L4; $L34: .loc 1 55 0 mov.u32 %r60,0; $L4: .loc 1 114 0 mov.b32 %r56,%r58; .loc 1 115 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r88; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r157,[%value_in]; } .loc 1 116 0 setp.lt.f32 %r158,%r157,0f01000000; @ ! %r158 bra $L50; .loc 1 117 0 add.f32 %r50,%r56,%r56; setp.gt.f32 %r159,%r50,%r157; @ %r159 bra $L29; setp.neu.f32 %r160,%r50,%r157; @ %r160 bra $L30; and.b32 %r161,%r60,1; setp.eq.u32 %r162,%r161,0; @ %r162 bra $L30; $L29: .loc 1 118 0 add.u32 %r60,%r60,1; .loc 1 119 0 sub.f32 %r56,%r56,%r157; bra $L30; $L50: .loc 1 121 0 mul.f32 %r52,%r157,0f3f000000; setp.lt.f32 %r163,%r52,%r56; @ %r163 bra $L31; setp.neu.f32 %r164,%r52,%r56; @ %r164 bra $L30; and.b32 %r165,%r60,1; setp.eq.u32 %r166,%r165,0; @ %r166 bra $L30; $L31: .loc 1 122 0 add.u32 %r60,%r60,1; .loc 1 123 0 sub.f32 %r56,%r56,%r157; $L30: .loc 1 126 0 mov.b32 %r167,%r56; xor.b32 %r54,%r65,%r167; mov.b32 %r86,%r54; .loc 1 127 0 and.b32 %r84,%r60,2147483647; .loc 1 128 0 setp.ge.s32 %r168,%r34,0; @ %r168 bra $L32; neg.s32 %r62,%r84; bra $L33; $L32: mov.u32 %r62,%r84; $L33: st.u32 [%r89],%r62; $L1: .loc 1 130 0 mov.f32 %value,%r86; st.param.f32 [%value_out],%value; ret; } lib_a-sf_rint.o/0 0 0 644 3491 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rintf .visible .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_rint.c" // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: TWO23 .const .align 4 .u32 TWO23[2] = {1258291200,3405774848 }; // BEGIN GLOBAL FUNCTION DEF: rintf .visible .func (.param .f32 %value_out) rintf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; } .reg .u32 %r22; .reg .f32 %r33; .reg .f32 %r34; .reg .f32 %r35; .reg .u32 %r38; .reg .f32 %r47; .reg .f32 %r48; .reg .f32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .f32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .pred %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .f32 %r78; .reg .f32 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .pred %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .f32 %r97; mov.f32 %r63,%ar0; .loc 1 39 0 mov.b32 %r22,%r63; .loc 1 41 0 and.b32 %r52,%r22,2147483647; .loc 1 42 0 shr.u32 %r64,%r52,23; add.u32 %r53,%r64,-127; .loc 1 43 0 setp.gt.s32 %r65,%r53,22; @ %r65 bra $L2; .loc 1 44 0 setp.eq.u32 %r66,%r52,0; @ %r66 bra $L3; .loc 1 39 0 mov.u32 %r50,%r22; .loc 1 40 0 shr.u32 %r51,%r22,31; .loc 1 46 0 setp.ge.s32 %r67,%r53,0; @ %r67 bra $L4; .loc 1 47 0 and.b32 %r57,%r22,8388607; .loc 1 51 0 cvta.const.u64 %r68,TWO23; cvt.s64.s32 %r69,%r51; shl.b64 %r70,%r69,2; add.u64 %r71,%r68,%r70; ld.f32 %r33,[%r71]; .loc 1 49 0 neg.s32 %r72,%r57; shr.u32 %r74,%r72,9; and.b32 %r75,%r74,4194304; .loc 1 48 0 and.b32 %r76,%r22,-1048576; .loc 1 49 0 or.b32 %r77,%r75,%r76; .loc 1 51 0 mov.b32 %r78,%r77; add.f32 %r34,%r33,%r78; st.f32 [%frame],%r34; .loc 1 52 0 ld.f32 %r35,[%frame]; sub.f32 %r79,%r35,%r33; .loc 1 54 0 mov.b32 %r81,%r79; and.b32 %r80,%r81,2147483647; shl.b32 %r82,%r51,31; or.b32 %r38,%r80,%r82; mov.b32 %r63,%r38; .loc 1 55 0 bra $L3; $L4: .loc 1 57 0 mov.u32 %r83,8388607; shr.s32 %r54,%r83,%r53; .loc 1 58 0 and.b32 %r84,%r50,%r54; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L3; .loc 1 59 0 shr.u32 %r55,%r54,1; .loc 1 60 0 and.b32 %r86,%r50,%r55; setp.eq.u32 %r87,%r86,0; @ %r87 bra $L5; not.b32 %r88,%r55; and.b32 %r89,%r88,%r50; mov.u32 %r91,2097152; shr.s32 %r90,%r91,%r53; or.b32 %r50,%r89,%r90; bra $L5; $L2: .loc 1 63 0 setp.le.u32 %r92,%r52,2139095039; @ %r92 bra $L3; add.f32 %r63,%r63,%r63; bra $L3; $L5: .loc 1 68 0 cvta.const.u64 %r93,TWO23; cvt.s64.s32 %r94,%r51; shl.b64 %r95,%r94,2; add.u64 %r96,%r93,%r95; ld.f32 %r47,[%r96]; mov.b32 %r97,%r50; add.f32 %r48,%r47,%r97; st.f32 [%frame],%r48; .loc 1 69 0 ld.f32 %r49,[%frame]; sub.f32 %r63,%r49,%r47; $L3: .loc 1 70 0 mov.f32 %value,%r63; st.param.f32 [%value_out],%value; ret; } /1309 0 0 0 644 1705 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: roundf .visible .func (.param .f32 %value_out) roundf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_round.c" // BEGIN GLOBAL FUNCTION DEF: roundf .visible .func (.param .f32 %value_out) roundf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .f32 %r35; .reg .f32 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .pred %r40; .reg .pred %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; mov.f32 %r36,%ar0; .loc 1 25 0 mov.b32 %r32,%r36; .loc 1 28 0 shr.u32 %r37,%r32,23; and.b32 %r38,%r37,255; add.u32 %r31,%r38,-127; .loc 1 30 0 setp.gt.s32 %r39,%r31,22; @ %r39 bra $L2; .loc 1 32 0 setp.ge.s32 %r40,%r31,0; @ %r40 bra $L3; .loc 1 34 0 and.b32 %r30,%r32,-2147483648; .loc 1 35 0 setp.ne.u32 %r41,%r31,-1; @ %r41 bra $L4; .loc 1 37 0 or.b32 %r30,%r30,1065353216; bra $L4; $L3: .loc 1 41 0 mov.u32 %r42,8388607; shr.s32 %r33,%r42,%r31; .loc 1 42 0 and.b32 %r43,%r32,%r33; setp.eq.u32 %r44,%r43,0; @ %r44 bra $L6; .loc 1 46 0 mov.u32 %r46,4194304; shr.s32 %r45,%r46,%r31; add.u32 %r34,%r45,%r32; .loc 1 47 0 not.b32 %r47,%r33; and.b32 %r30,%r47,%r34; bra $L4; $L2: .loc 1 52 0 setp.ne.u32 %r48,%r31,128; @ %r48 bra $L7; .loc 1 54 0 add.f32 %r35,%r36,%r36; bra $L1; $L4: .loc 1 58 0 mov.b32 %r35,%r30; .loc 1 59 0 bra $L1; $L6: .loc 1 44 0 mov.f32 %r35,%r36; bra $L1; $L7: mov.f32 %r35,%r36; $L1: .loc 1 60 0 mov.f32 %value,%r35; st.param.f32 [%value_out],%value; ret; } /1327 0 0 0 644 3642 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalblnf .visible .func (.param .f32 %value_out) scalblnf (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_scalbln.c" // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalblnf .visible .func (.param .f32 %value_out) scalblnf (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r28; .reg .u32 %r46; .reg .u32 %r47; .reg .f32 %r52; .reg .f32 %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .pred %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u32 %r62; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r67; .reg .u32 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u16 %r71; .reg .u32 %r72; .reg .u16 %r73; .reg .pred %r74; .reg .f32 %r75; .reg .f32 %r77; .reg .pred %r78; .reg .f32 %r79; .reg .f32 %r81; .reg .pred %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .f32 %r87; .reg .f32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .f32 %r94; mov.f32 %r53,%ar0; mov.u64 %r54,%ar1; .loc 1 36 0 mov.b32 %r46,%r53; .loc 1 37 0 shr.s32 %r55,%r46,23; and.b32 %r47,%r55,255; .loc 1 38 0 setp.ne.u32 %r56,%r47,0; @ %r56 bra $L2; .loc 1 39 0 and.b32 %r57,%r46,2147483647; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L9; .loc 1 40 0 mul.f32 %r53,%r53,0f4c000000; .loc 1 41 0 mov.b32 %r46,%r53; .loc 1 42 0 shr.s32 %r59,%r46,23; and.b32 %r60,%r59,255; add.u32 %r47,%r60,-25; bra $L4; $L2: .loc 1 44 0 setp.ne.u32 %r61,%r47,255; @ %r61 bra $L4; add.f32 %r52,%r53,%r53; bra $L1; $L4: .loc 1 45 0 cvt.u32.u64 %r62,%r54; add.u32 %r28,%r47,%r62; .loc 1 46 0 set.u32.gt.s64 %r64,%r54,50000; neg.s32 %r65,%r64; set.u32.gt.s32 %r67,%r28,254; neg.s32 %r68,%r67; cvt.u16.u32 %r70,%r65; cvt.u16.u32 %r71,%r68; or.b16 %r69,%r70,%r71; cvt.u32.u16 %r72,%r69; cvt.u16.u8 %r73,%r72; setp.eq.u16 %r74,%r73,0; @ %r74 bra $L5; .loc 1 47 0 mov.f32 %r75,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r75; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r77,[%value_in]; } mul.f32 %r52,%r77,0f7149f2ca; bra $L1; $L5: .loc 1 48 0 setp.ge.s64 %r78,%r54,-50000; @ %r78 bra $L6; .loc 1 49 0 mov.f32 %r79,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r79; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r81,[%value_in]; } mul.f32 %r52,%r81,0f0da24260; bra $L1; $L6: .loc 1 50 0 setp.le.s32 %r82,%r28,0; @ %r82 bra $L7; .loc 1 51 0 and.b32 %r83,%r46,-2139095041; shl.b32 %r84,%r28,23; or.b32 %r85,%r83,%r84; mov.b32 %r52,%r85; bra $L1; $L7: .loc 1 52 0 setp.ge.s32 %r86,%r28,-24; @ %r86 bra $L8; .loc 1 53 0 mov.f32 %r87,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r87; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r53; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r89,[%value_in]; } mul.f32 %r52,%r89,0f0da24260; bra $L1; $L8: .loc 1 54 0 add.u32 %r90,%r28,25; .loc 1 55 0 shl.b32 %r91,%r90,23; and.b32 %r92,%r46,-2139095041; or.b32 %r93,%r91,%r92; .loc 1 56 0 mov.b32 %r94,%r93; mul.f32 %r52,%r94,0f33000000; bra $L1; $L9: .loc 1 39 0 mov.f32 %r52,%r53; $L1: .loc 1 57 0 mov.f32 %value,%r52; st.param.f32 [%value_out],%value; ret; } /1347 0 0 0 644 3414 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .f32 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .f32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .pred %r64; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .f32 %r75; mov.f32 %r47,%ar0; mov.u32 %r48,%ar1; .loc 1 46 0 mov.b32 %r22,%r47; .loc 1 47 0 and.b32 %r42,%r22,2147483647; .loc 1 49 0 setp.eq.u32 %r49,%r42,0; @ %r49 bra $L11; .loc 1 51 0 setp.le.u32 %r50,%r42,2139095039; @ %r50 bra $L3; .loc 1 52 0 add.f32 %r46,%r47,%r47; bra $L1; $L3: .loc 1 53 0 setp.gt.u32 %r51,%r42,8388607; @ %r51 bra $L4; .loc 1 54 0 mul.f32 %r47,%r47,0f4c000000; .loc 1 57 0 setp.lt.s32 %r52,%r48,-50000; @ %r52 bra $L5; .loc 1 55 0 mov.b32 %r41,%r47; .loc 1 56 0 shr.s32 %r53,%r41,23; and.b32 %r54,%r53,255; add.u32 %r40,%r54,-25; bra $L6; $L5: .loc 1 57 0 mul.f32 %r46,%r47,0f0da24260; bra $L1; $L4: .loc 1 46 0 mov.u32 %r41,%r22; .loc 1 48 0 shr.u32 %r40,%r42,23; $L6: .loc 1 59 0 add.u32 %r43,%r40,%r48; .loc 1 60 0 setp.le.s32 %r55,%r43,254; @ %r55 bra $L7; mov.f32 %r56,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r56; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r58,[%value_in]; } mul.f32 %r46,%r58,0f7149f2ca; bra $L1; $L7: .loc 1 61 0 setp.le.s32 %r59,%r43,0; @ %r59 bra $L8; .loc 1 62 0 and.b32 %r60,%r41,-2139095041; shl.b32 %r61,%r43,23; or.b32 %r62,%r60,%r61; mov.b32 %r46,%r62; bra $L1; $L8: .loc 1 63 0 setp.ge.s32 %r63,%r43,-22; @ %r63 bra $L9; .loc 1 64 0 setp.le.s32 %r64,%r48,50000; @ %r64 bra $L10; .loc 1 65 0 mov.f32 %r65,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r65; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r67,[%value_in]; } mul.f32 %r46,%r67,0f7149f2ca; bra $L1; $L10: .loc 1 66 0 mov.f32 %r68,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r70,[%value_in]; } mul.f32 %r46,%r70,0f0da24260; bra $L1; $L9: .loc 1 68 0 add.u32 %r71,%r43,25; .loc 1 69 0 shl.b32 %r72,%r71,23; and.b32 %r73,%r41,-2139095041; or.b32 %r74,%r72,%r73; .loc 1 70 0 mov.b32 %r75,%r74; mul.f32 %r46,%r75,0f33000000; bra $L1; $L11: .loc 1 50 0 mov.f32 %r46,%r47; $L1: .loc 1 71 0 mov.f32 %value,%r46; st.param.f32 [%value_out],%value; ret; } /1366 0 0 0 644 1295 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: significandf .visible .func (.param .f32 %value_out) significandf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_signif.c" // BEGIN GLOBAL FUNCTION DECL: ilogbf .extern .func (.param .u32 %value_out) ilogbf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalbf .extern .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: significandf .visible .func (.param .f32 %value_out) significandf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r26; .reg .u32 %r28; .reg .u32 %r31; .reg .f32 %r32; .reg .f32 %r33; mov.f32 %r26,%ar0; .loc 1 25 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; call (%value_in),ilogbf,(%out_arg1); ld.param.u32 %r28,[%value_in]; } neg.s32 %r31,%r28; cvt.rn.f32.s32 %r32,%r31; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r26; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r32; call (%value_in),__ieee754_scalbf,(%out_arg1,%out_arg2); ld.param.f32 %r33,[%value_in]; } .loc 1 26 0 mov.f32 %value,%r33; st.param.f32 [%value_out],%value; ret; } lib_a-sf_sin.o/ 0 0 0 644 4290 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sinf .visible .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_sin.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_sinf .extern .func (.param .f32 %value_out) __kernel_sinf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .extern .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __kernel_cosf .extern .func (.param .f32 %value_out) __kernel_cosf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: sinf .visible .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .pred %r39; .reg .f32 %r41; .reg .u32 %r42; .reg .f32 %r43; .reg .pred %r44; .reg .u32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .f32 %r52; .reg .u32 %r54; .reg .f32 %r55; .reg .f32 %r56; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .u32 %r63; .reg .f32 %r64; .reg .f32 %r65; .reg .f32 %r66; .reg .f32 %r68; .reg .f32 %r69; mov.f32 %r38,%ar0; .loc 1 28 0 mov.b32 %r34,%r38; .loc 1 31 0 and.b32 %r35,%r34,2147483647; .loc 1 32 0 setp.gt.s32 %r39,%r35,1061752792; @ %r39 bra $L2; mov.u32 %r42,0; mov.f32 %r41,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r42; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r43,[%value_in]; } mov.f32 %r37,%r43; bra $L1; $L2: .loc 1 35 0 setp.le.s32 %r44,%r35,2139095039; @ %r44 bra $L4; sub.f32 %r37,%r38,%r38; bra $L1; $L4: .loc 1 39 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2f,(%out_arg1,%out_arg2); ld.param.u32 %r47,[%value_in]; } .loc 1 40 0 and.b32 %r48,%r47,3; setp.eq.u32 %r49,%r48,1; @ %r49 bra $L6; setp.eq.u32 %r50,%r48,2; @ %r50 bra $L7; setp.eq.u32 %r51,%r48,0; @ ! %r51 bra $L9; .loc 1 41 0 ld.f32 %r55,[%frame+4]; mov.u32 %r54,1; ld.f32 %r52,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r52; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r55; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r54; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r56,[%value_in]; } mov.f32 %r37,%r56; bra $L1; $L6: .loc 1 42 0 ld.f32 %r59,[%frame+4]; ld.f32 %r57,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r57; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r59; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r60,[%value_in]; } mov.f32 %r37,%r60; bra $L1; $L7: .loc 1 43 0 ld.f32 %r64,[%frame+4]; mov.u32 %r63,1; ld.f32 %r61,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r61; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r63; call (%value_in),__kernel_sinf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r65,[%value_in]; } neg.f32 %r37,%r65; bra $L1; $L9: .loc 1 45 0 ld.f32 %r68,[%frame+4]; ld.f32 %r66,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r66; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r68; call (%value_in),__kernel_cosf,(%out_arg1,%out_arg2); ld.param.f32 %r69,[%value_in]; } neg.f32 %r37,%r69; $L1: .loc 1 48 0 mov.f32 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-sf_tan.o/ 0 0 0 644 2867 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanf .visible .func (.param .f32 %value_out) tanf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_tan.c" // BEGIN GLOBAL FUNCTION DECL: __kernel_tanf .extern .func (.param .f32 %value_out) __kernel_tanf (.param .f32 %in_ar0, .param .f32 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ieee754_rem_pio2f .extern .func (.param .u32 %value_out) __ieee754_rem_pio2f (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: tanf .visible .func (.param .f32 %value_out) tanf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r28; .reg .u32 %r29; .reg .f32 %r31; .reg .f32 %r32; .reg .pred %r33; .reg .f32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .pred %r38; .reg .u32 %r41; .reg .f32 %r42; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .f32 %r49; .reg .f32 %r50; mov.f32 %r32,%ar0; .loc 1 28 0 mov.b32 %r28,%r32; .loc 1 31 0 and.b32 %r29,%r28,2147483647; .loc 1 32 0 setp.gt.s32 %r33,%r29,1061752794; @ %r33 bra $L2; mov.u32 %r36,1; mov.f32 %r35,0f00000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r35; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r36; call (%value_in),__kernel_tanf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r37,[%value_in]; } mov.f32 %r31,%r37; bra $L1; $L2: .loc 1 35 0 setp.le.s32 %r38,%r29,2139095039; @ %r38 bra $L4; sub.f32 %r31,%r32,%r32; bra $L1; $L4: .loc 1 39 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_rem_pio2f,(%out_arg1,%out_arg2); ld.param.u32 %r41,[%value_in]; } .loc 1 40 0 add.u32 %r45,%r41,%r41; and.b32 %r46,%r45,2; mov.u32 %r48,1; sub.u32 %r47,%r48,%r46; ld.f32 %r49,[%frame+4]; ld.f32 %r42,[%frame]; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r49; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r47; call (%value_in),__kernel_tanf,(%out_arg1,%out_arg2,%out_arg3); ld.param.f32 %r50,[%value_in]; } mov.f32 %r31,%r50; $L1: .loc 1 43 0 mov.f32 %value,%r31; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-sf_tanh.o/0 0 0 644 2768 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanhf .visible .func (.param .f32 %value_out) tanhf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/sf_tanh.c" // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: expm1f .extern .func (.param .f32 %value_out) expm1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanhf .visible .func (.param .f32 %value_out) tanhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r31; .reg .u32 %r32; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .pred %r39; .reg .f32 %r40; .reg .pred %r41; .reg .pred %r43; .reg .pred %r44; .reg .f32 %r45; .reg .pred %r46; .reg .f32 %r48; .reg .f32 %r50; .reg .f32 %r51; .reg .f32 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r57; .reg .f32 %r59; .reg .f32 %r60; .reg .f32 %r61; .reg .f32 %r62; .reg .pred %r63; mov.f32 %r38,%ar0; .loc 1 34 0 mov.b32 %r31,%r38; .loc 1 35 0 and.b32 %r32,%r31,2147483647; .loc 1 38 0 setp.le.s32 %r39,%r32,2139095039; @ %r39 bra $L2; mov.f32 %r40,0f3f800000; div.rn.f32 %r36,%r40,%r38; .loc 1 39 0 setp.lt.s32 %r41,%r31,0; @ %r41 bra $L3; add.f32 %r37,%r36,0f3f800000; bra $L1; $L3: .loc 1 40 0 sub.f32 %r37,%r36,%r40; bra $L1; $L2: .loc 1 44 0 setp.gt.s32 %r43,%r32,1102053375; @ %r43 bra $L8; .loc 1 45 0 setp.gt.s32 %r44,%r32,603979775; @ %r44 bra $L6; .loc 1 46 0 add.f32 %r45,%r38,0f3f800000; mul.f32 %r37,%r45,%r38; bra $L1; $L6: .loc 1 47 0 setp.le.s32 %r46,%r32,1065353215; @ %r46 bra $L7; .loc 1 48 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r48,[%value_in]; } add.f32 %r50,%r48,%r48; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r50; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r51,[%value_in]; } .loc 1 49 0 add.f32 %r52,%r51,0f40000000; mov.f32 %r54,0f40000000; div.rn.f32 %r53,%r54,%r52; mov.f32 %r55,0f3f800000; sub.f32 %r37,%r55,%r53; bra $L5; $L7: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r57,[%value_in]; } mul.f32 %r59,%r57,0fc0000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r59; call (%value_in),expm1f,(%out_arg1); ld.param.f32 %r60,[%value_in]; } .loc 1 52 0 neg.f32 %r61,%r60; add.f32 %r62,%r60,0f40000000; div.rn.f32 %r37,%r61,%r62; bra $L5; $L8: .loc 1 56 0 mov.f32 %r37,0f3f800000; $L5: .loc 1 58 0 setp.ge.s32 %r63,%r31,0; @ %r63 bra $L1; neg.f32 %r37,%r37; $L1: .loc 1 59 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /1385 0 0 0 644 1183 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: truncf .visible .func (.param .f32 %value_out) truncf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_trunc.c" // BEGIN GLOBAL FUNCTION DEF: truncf .visible .func (.param .f32 %value_out) truncf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r29; .reg .f32 %r31; .reg .f32 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .pred %r35; .reg .pred %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; mov.f32 %r32,%ar0; .loc 1 23 0 mov.b32 %r27,%r32; .loc 1 29 0 shr.s32 %r33,%r27,23; and.b32 %r34,%r33,255; add.u32 %r29,%r34,-127; .loc 1 31 0 setp.gt.s32 %r35,%r29,22; @ %r35 bra $L4; .loc 1 33 0 setp.ge.s32 %r36,%r29,0; @ %r36 bra $L3; .loc 1 26 0 and.b32 %r37,%r27,-2147483648; .loc 1 36 0 mov.b32 %r31,%r37; bra $L1; $L3: .loc 1 40 0 mov.u32 %r39,8388607; shr.s32 %r38,%r39,%r29; not.b32 %r40,%r38; and.b32 %r41,%r40,%r27; mov.b32 %r31,%r41; bra $L1; $L4: mov.f32 %r31,%r32; $L1: .loc 1 52 0 mov.f32 %value,%r31; st.param.f32 [%value_out],%value; ret; } lib_a-sinhl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sinhl .visible .func (.param .f64 %value_out) sinhl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sinhl.c" // BEGIN GLOBAL FUNCTION DECL: sinh .extern .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sinhl .visible .func (.param .f64 %value_out) sinhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),sinh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-sinl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sinl .visible .func (.param .f64 %value_out) sinl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sinl.c" // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sinl .visible .func (.param .f64 %value_out) sinl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),sin,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-sqrtl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sqrtl .visible .func (.param .f64 %value_out) sqrtl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sqrtl.c" // BEGIN GLOBAL FUNCTION DECL: sqrt .extern .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sqrtl .visible .func (.param .f64 %value_out) sqrtl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),sqrt,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-tanhl.o/ 0 0 0 644 795 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanhl .visible .func (.param .f64 %value_out) tanhl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/tanhl.c" // BEGIN GLOBAL FUNCTION DECL: tanh .extern .func (.param .f64 %value_out) tanh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanhl .visible .func (.param .f64 %value_out) tanhl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),tanh,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-tanl.o/ 0 0 0 644 787 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tanl .visible .func (.param .f64 %value_out) tanl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/tanl.c" // BEGIN GLOBAL FUNCTION DECL: tan .extern .func (.param .f64 %value_out) tan (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tanl .visible .func (.param .f64 %value_out) tanl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),tan,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-tgammal.o/0 0 0 644 811 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tgammal .visible .func (.param .f64 %value_out) tgammal (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/tgammal.c" // BEGIN GLOBAL FUNCTION DECL: tgamma .extern .func (.param .f64 %value_out) tgamma (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: tgammal .visible .func (.param .f64 %value_out) tgammal (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),tgamma,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-truncl.o/ 0 0 0 644 803 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: truncl .visible .func (.param .f64 %value_out) truncl (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/truncl.c" // BEGIN GLOBAL FUNCTION DECL: trunc .extern .func (.param .f64 %value_out) trunc (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: truncl .visible .func (.param .f64 %value_out) truncl (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r25; mov.f64 %r23,%ar0; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; call (%value_in),trunc,(%out_arg1); ld.param.f64 %r25,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r25; st.param.f64 [%value_out],%value; ret; } lib_a-w_acos.o/ 0 0 0 644 4275 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acos .visible .func (.param .f64 %value_out) acos (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_acos.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acos .extern .func (.param .f64 %value_out) __ieee754_acos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {97,99,111,115,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: acos .visible .func (.param .f64 %value_out) acos (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .u64 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; mov.f64 %r34,%ar0; .loc 1 96 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__ieee754_acos,(%out_arg1); ld.param.f64 %r36,[%value_in]; } mov.f64 %r33,%r36; .loc 1 97 0 ld.global.u32 %r37,[__fdlib_version]; setp.eq.u32 %r38,%r37,-1; @ %r38 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.eq.u32 %r41,%r40,0; @ %r41 bra $L1; .loc 1 98 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r43,[%value_in]; } setp.gt.f64 %r44,%r43,0d3ff0000000000000; @ ! %r44 bra $L1; .loc 1 100 0 mov.u32 %r45,1; st.u32 [%frame],%r45; .loc 1 101 0 cvta.const.u64 %r46,$LC0; st.u64 [%frame+8],%r46; .loc 1 102 0 mov.u32 %r47,0; st.u32 [%frame+40],%r47; .loc 1 103 0 st.f64 [%frame+24],%r34; st.f64 [%frame+16],%r34; .loc 1 104 0 cvta.const.u64 %r48,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r48; call (%value_in),nan,(%out_arg1); ld.param.f64 %r49,[%value_in]; } st.f64 [%frame+32],%r49; .loc 1 105 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,33; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 107 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,33; st.u32 [%r57],%r58; $L5: .loc 1 110 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 112 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 116 0 mov.f64 %value,%r33; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_acosh.o/0 0 0 644 3766 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acosh .visible .func (.param .f64 %value_out) acosh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_acosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosh .extern .func (.param .f64 %value_out) __ieee754_acosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,99,111,115,104,0 }; // BEGIN GLOBAL FUNCTION DEF: acosh .visible .func (.param .f64 %value_out) acosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .u32 %r42; .reg .u64 %r43; .reg .u32 %r44; .reg .f64 %r45; .reg .f64 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u64 %r58; mov.f64 %r33,%ar0; .loc 1 100 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_acosh,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 101 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 102 0 setp.lt.f64 %r41,%r33,0d3ff0000000000000; @ ! %r41 bra $L1; .loc 1 104 0 mov.u32 %r42,1; st.u32 [%frame],%r42; .loc 1 105 0 cvta.const.u64 %r43,$LC0; st.u64 [%frame+8],%r43; .loc 1 106 0 mov.u32 %r44,0; st.u32 [%frame+40],%r44; .loc 1 107 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 108 0 mov.f64 %r46,0d0000000000000000; div.rn.f64 %r45,%r46,0d0000000000000000; st.f64 [%frame+32],%r45; .loc 1 109 0 ld.global.u32 %r47,[__fdlib_version]; setp.ne.u32 %r48,%r47,2; @ %r48 bra $L4; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r49,[%value_in]; } mov.u32 %r50,33; st.u32 [%r49],%r50; bra $L5; $L4: .loc 1 111 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r52,[%value_in]; } setp.ne.u32 %r53,%r52,0; @ %r53 bra $L5; .loc 1 112 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,33; st.u32 [%r54],%r55; $L5: .loc 1 114 0 ld.u32 %r56,[%frame+40]; setp.eq.u32 %r57,%r56,0; @ %r57 bra $L6; .loc 1 115 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r58],%r31; $L6: .loc 1 116 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 120 0 mov.f64 %value,%r32; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_asin.o/ 0 0 0 644 4278 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: asin .visible .func (.param .f64 %value_out) asin (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_asin.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_asin .extern .func (.param .f64 %value_out) __ieee754_asin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {97,115,105,110,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: asin .visible .func (.param .f64 %value_out) asin (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .u64 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; mov.f64 %r34,%ar0; .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__ieee754_asin,(%out_arg1); ld.param.f64 %r36,[%value_in]; } mov.f64 %r33,%r36; .loc 1 100 0 ld.global.u32 %r37,[__fdlib_version]; setp.eq.u32 %r38,%r37,-1; @ %r38 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.eq.u32 %r41,%r40,0; @ %r41 bra $L1; .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r43,[%value_in]; } setp.gt.f64 %r44,%r43,0d3ff0000000000000; @ ! %r44 bra $L1; .loc 1 103 0 mov.u32 %r45,1; st.u32 [%frame],%r45; .loc 1 104 0 cvta.const.u64 %r46,$LC0; st.u64 [%frame+8],%r46; .loc 1 105 0 mov.u32 %r47,0; st.u32 [%frame+40],%r47; .loc 1 106 0 st.f64 [%frame+24],%r34; st.f64 [%frame+16],%r34; .loc 1 107 0 cvta.const.u64 %r48,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r48; call (%value_in),nan,(%out_arg1); ld.param.f64 %r49,[%value_in]; } st.f64 [%frame+32],%r49; .loc 1 108 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,33; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 110 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,33; st.u32 [%r57],%r58; $L5: .loc 1 113 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 114 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 115 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 119 0 mov.f64 %value,%r33; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_atan2.o/0 0 0 644 1035 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan2 .visible .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_atan2.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2 .extern .func (.param .f64 %value_out) __ieee754_atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atan2 .visible .func (.param .f64 %value_out) atan2 (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),__ieee754_atan2,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 88 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-w_atanh.o/0 0 0 644 5184 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: atanh .visible .func (.param .f64 %value_out) atanh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_atanh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanh .extern .func (.param .f64 %value_out) __ieee754_atanh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,116,97,110,104,0 }; // BEGIN GLOBAL FUNCTION DEF: atanh .visible .func (.param .f64 %value_out) atanh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .f64 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .f64 %r47; .reg .pred %r48; .reg .pred %r49; .reg .u32 %r50; .reg .u64 %r51; .reg .u32 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .f64 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; mov.f64 %r38,%ar0; .loc 1 99 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),__ieee754_atanh,(%out_arg1); ld.param.f64 %r40,[%value_in]; } mov.f64 %r37,%r40; .loc 1 100 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 101 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r47,[%value_in]; } .loc 1 102 0 setp.ge.f64 %r48,%r47,0d3ff0000000000000; @ ! %r48 bra $L1; ld.global.u32 %r36,[__fdlib_version]; .loc 1 103 0 setp.gt.f64 %r49,%r47,0d3ff0000000000000; @ ! %r49 bra $L23; .loc 1 105 0 mov.u32 %r50,1; st.u32 [%frame],%r50; .loc 1 106 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 107 0 mov.u32 %r52,0; st.u32 [%frame+40],%r52; .loc 1 108 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 109 0 mov.f64 %r54,0d0000000000000000; div.rn.f64 %r53,%r54,0d0000000000000000; st.f64 [%frame+32],%r53; .loc 1 110 0 setp.ne.u32 %r55,%r36,2; @ %r55 bra $L6; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,33; st.u32 [%r56],%r57; bra $L7; $L6: .loc 1 112 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.eq.u32 %r60,%r59,0; @ ! %r60 bra $L7; .loc 1 113 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } mov.u32 %r62,33; st.u32 [%r61],%r62; bra $L7; $L23: .loc 1 117 0 mov.u32 %r63,2; st.u32 [%frame],%r63; .loc 1 118 0 cvta.const.u64 %r64,$LC0; st.u64 [%frame+8],%r64; .loc 1 119 0 mov.u32 %r65,0; st.u32 [%frame+40],%r65; .loc 1 120 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 121 0 div.rn.f64 %r66,%r38,0d0000000000000000; st.f64 [%frame+32],%r66; .loc 1 122 0 setp.ne.u32 %r67,%r36,2; @ %r67 bra $L9; .loc 1 123 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L7; $L9: .loc 1 124 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r71,[%value_in]; } setp.ne.u32 %r72,%r71,0; @ %r72 bra $L7; .loc 1 125 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } mov.u32 %r74,33; st.u32 [%r73],%r74; $L7: .loc 1 128 0 ld.u32 %r75,[%frame+40]; setp.eq.u32 %r76,%r75,0; @ %r76 bra $L11; .loc 1 129 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r77],%r34; $L11: .loc 1 130 0 ld.f64 %r37,[%frame+32]; $L1: .loc 1 134 0 mov.f64 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_cosh.o/ 0 0 0 644 4128 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: cosh .visible .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_cosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_cosh .extern .func (.param .f64 %value_out) __ieee754_cosh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {99,111,115,104,0 }; // BEGIN GLOBAL FUNCTION DEF: cosh .visible .func (.param .f64 %value_out) cosh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .f64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r52; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; mov.f64 %r33,%ar0; .loc 1 85 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_cosh,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 86 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 87 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r42,[%value_in]; } setp.gt.f64 %r43,%r42,0d408633ce8fb9f87d; @ ! %r43 bra $L1; .loc 1 95 0 mov.u32 %r44,3; st.u32 [%frame],%r44; .loc 1 96 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 97 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 98 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 99 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r47,%r25,0; @ %r47 bra $L4; .loc 1 100 0 mov.f64 %r48,0d47efffffe0000000; st.f64 [%frame+32],%r48; bra $L5; $L4: .loc 1 102 0 mov.f64 %r49,0d7ff0000000000000; st.f64 [%frame+32],%r49; .loc 1 103 0 setp.ne.u32 %r50,%r25,2; @ %r50 bra $L5; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r51,[%value_in]; } mov.u32 %r52,34; st.u32 [%r51],%r52; bra $L6; $L5: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r54,[%value_in]; } setp.ne.u32 %r55,%r54,0; @ %r55 bra $L6; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,34; st.u32 [%r56],%r57; $L6: .loc 1 108 0 ld.u32 %r58,[%frame+40]; setp.eq.u32 %r59,%r58,0; @ %r59 bra $L7; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r60],%r31; $L7: .loc 1 110 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 114 0 mov.f64 %value,%r32; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_drem.o/ 0 0 0 644 1012 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: drem .visible .func (.param .f64 %value_out) drem (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_drem.c" // BEGIN GLOBAL FUNCTION DECL: remainder .extern .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: drem .visible .func (.param .f64 %value_out) drem (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r27; mov.f64 %r23,%ar0; mov.f64 %r24,%ar1; .loc 1 14 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; call (%value_in),remainder,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 15 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-w_exp.o/ 0 0 0 644 5369 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: exp .visible .func (.param .f64 %value_out) exp (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_exp.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_exp .extern .func (.param .f64 %value_out) __ieee754_exp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {101,120,112,0 }; // BEGIN GLOBAL FUNCTION DEF: exp .visible .func (.param .f64 %value_out) exp (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r30; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .pred %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .f64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r39,%ar0; .loc 1 88 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__ieee754_exp,(%out_arg1); ld.param.f64 %r41,[%value_in]; } mov.f64 %r38,%r41; .loc 1 89 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L1; .loc 1 90 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),finite,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L1; .loc 1 91 0 setp.gt.f64 %r47,%r39,0d40862e42fefa39ef; @ ! %r47 bra $L27; .loc 1 99 0 mov.u32 %r48,3; st.u32 [%frame],%r48; .loc 1 100 0 cvta.const.u64 %r49,$LC0; st.u64 [%frame+8],%r49; .loc 1 101 0 mov.u32 %r50,0; st.u32 [%frame+40],%r50; .loc 1 102 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 103 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r51,%r24,0; @ %r51 bra $L5; .loc 1 104 0 mov.f64 %r52,0d47efffffe0000000; st.f64 [%frame+32],%r52; bra $L6; $L5: .loc 1 106 0 mov.f64 %r53,0d7ff0000000000000; st.f64 [%frame+32],%r53; .loc 1 107 0 setp.ne.u32 %r54,%r24,2; @ %r54 bra $L6; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; bra $L7; $L6: .loc 1 109 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L7; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,34; st.u32 [%r60],%r61; $L7: .loc 1 112 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L8; .loc 1 113 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r30,[%frame+40]; st.u32 [%r64],%r30; $L8: .loc 1 114 0 ld.f64 %r38,[%frame+32]; bra $L1; $L27: .loc 1 115 0 setp.lt.f64 %r65,%r39,0dc0874910d52d3051; @ ! %r65 bra $L1; .loc 1 117 0 mov.u32 %r66,4; st.u32 [%frame],%r66; .loc 1 118 0 cvta.const.u64 %r67,$LC0; st.u64 [%frame+8],%r67; .loc 1 119 0 mov.u32 %r68,0; st.u32 [%frame+40],%r68; .loc 1 120 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 121 0 mov.f64 %r69,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 122 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r71,%r70,2; @ %r71 bra $L10; .loc 1 123 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L11; $L10: .loc 1 124 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L11; .loc 1 125 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L11: .loc 1 127 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L12; .loc 1 128 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r81],%r37; $L12: .loc 1 129 0 ld.f64 %r38,[%frame+32]; $L1: .loc 1 134 0 mov.f64 %value,%r38; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_exp2.o/ 0 0 0 644 921 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp2 .visible .func (.param .f64 %value_out) exp2 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_exp2.c" // BEGIN GLOBAL FUNCTION DECL: pow .extern .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp2 .visible .func (.param .f64 %value_out) exp2 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r23; .reg .f64 %r24; .reg .f64 %r26; mov.f64 %r23,%ar0; .loc 1 67 0 mov.f64 %r24,0d4000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r23; call (%value_in),pow,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 68 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } lib_a-w_fmod.o/ 0 0 0 644 4606 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: fmod .visible .func (.param .f64 %value_out) fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_fmod.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmod .extern .func (.param .f64 %value_out) __ieee754_fmod (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {102,109,111,100,0 }; // BEGIN GLOBAL FUNCTION DEF: fmod .visible .func (.param .f64 %value_out) fmod (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r25; .reg .u32 %r32; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u16 %r55; .reg .u16 %r56; .reg .u16 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; mov.f64 %r37,%ar0; mov.f64 %r38,%ar1; .loc 1 81 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r38; call (%value_in),__ieee754_fmod,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } mov.f64 %r36,%r41; .loc 1 82 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r48,[%value_in]; } set.u32.ne.u32 %r50,%r48,0; neg.s32 %r51,%r50; .loc 1 83 0 set.u32.eq.f64 %r53,%r38,0d0000000000000000; neg.s32 %r54,%r53; cvt.u16.u32 %r56,%r51; cvt.u16.u32 %r57,%r54; and.b16 %r55,%r56,%r57; cvt.u32.u16 %r58,%r55; cvt.u16.u8 %r59,%r58; setp.eq.u16 %r60,%r59,0; @ %r60 bra $L1; .loc 1 85 0 mov.u32 %r61,1; st.u32 [%frame],%r61; .loc 1 86 0 cvta.const.u64 %r62,$LC0; st.u64 [%frame+8],%r62; .loc 1 87 0 st.f64 [%frame+16],%r37; .loc 1 88 0 st.f64 [%frame+24],%r38; .loc 1 89 0 mov.u32 %r63,0; st.u32 [%frame+40],%r63; .loc 1 90 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r64,%r25,0; @ %r64 bra $L3; .loc 1 91 0 st.f64 [%frame+32],%r37; bra $L4; $L3: .loc 1 93 0 mov.f64 %r66,0d0000000000000000; div.rn.f64 %r65,%r66,0d0000000000000000; st.f64 [%frame+32],%r65; .loc 1 94 0 setp.ne.u32 %r67,%r25,2; @ %r67 bra $L4; .loc 1 95 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L5; $L4: .loc 1 96 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r71,[%value_in]; } setp.ne.u32 %r72,%r71,0; @ %r72 bra $L5; .loc 1 97 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } mov.u32 %r74,33; st.u32 [%r73],%r74; $L5: .loc 1 99 0 ld.u32 %r75,[%frame+40]; setp.eq.u32 %r76,%r75,0; @ %r76 bra $L6; .loc 1 100 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r77],%r32; $L6: .loc 1 101 0 ld.f64 %r36,[%frame+32]; $L1: .loc 1 105 0 mov.f64 %value,%r36; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_gamma.o/0 0 0 644 5504 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gamma .visible .func (.param .f64 %value_out) gamma (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .extern .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: gamma .visible .func (.param .f64 %value_out) gamma (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .f64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r78; .reg .pred %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .u64 %r84; mov.f64 %r40,%ar0; .loc 1 185 0 ld.global.u64 %r44,[_impure_ptr]; add.u64 %r43,%r44,224; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; call (%value_in),__ieee754_gamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r45,[%value_in]; } mov.f64 %r39,%r45; .loc 1 186 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L1; .loc 1 187 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r45; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.ne.u32 %r50,%r49,0; @ %r50 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } setp.eq.u32 %r53,%r52,0; @ %r53 bra $L1; .loc 1 194 0 cvta.const.u64 %r54,$LC0; st.u64 [%frame+8],%r54; .loc 1 195 0 st.u32 [%frame+40],%r49; .loc 1 196 0 st.f64 [%frame+24],%r40; st.f64 [%frame+16],%r40; .loc 1 197 0 ld.global.u32 %r56,[__fdlib_version]; setp.ne.u32 %r57,%r56,0; @ %r57 bra $L3; .loc 1 198 0 mov.f64 %r58,0d47efffffe0000000; st.f64 [%frame+32],%r58; bra $L4; $L3: .loc 1 200 0 mov.f64 %r59,0d7ff0000000000000; st.f64 [%frame+32],%r59; $L4: .loc 1 201 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),floor,(%out_arg1); ld.param.f64 %r61,[%value_in]; } setp.neu.f64 %r62,%r61,%r40; @ %r62 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f64 %r63,%r40,0d0000000000000000; @ ! %r63 bra $L6; .loc 1 203 0 mov.u32 %r64,2; st.u32 [%frame],%r64; .loc 1 204 0 setp.ne.u32 %r65,%r38,2; @ %r65 bra $L8; .loc 1 205 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } mov.u32 %r67,33; st.u32 [%r66],%r67; bra $L9; $L8: .loc 1 206 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r69,[%value_in]; } setp.eq.u32 %r70,%r69,0; @ ! %r70 bra $L9; .loc 1 207 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } mov.u32 %r72,33; st.u32 [%r71],%r72; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 211 0 mov.u32 %r73,3; st.u32 [%frame],%r73; .loc 1 212 0 setp.ne.u32 %r74,%r38,2; @ %r74 bra $L11; .loc 1 213 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,34; st.u32 [%r75],%r76; bra $L9; $L11: .loc 1 214 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r78,[%value_in]; } setp.ne.u32 %r79,%r78,0; @ %r79 bra $L9; .loc 1 215 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r80,[%value_in]; } mov.u32 %r81,34; st.u32 [%r80],%r81; $L9: .loc 1 218 0 ld.u32 %r82,[%frame+40]; setp.eq.u32 %r83,%r82,0; @ %r83 bra $L13; .loc 1 219 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r84,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r84],%r37; $L13: .loc 1 220 0 ld.f64 %r39,[%frame+32]; $L1: .loc 1 224 0 mov.f64 %value,%r39; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_hypot.o/0 0 0 644 4404 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: hypot .visible .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_hypot.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypot .extern .func (.param .f64 %value_out) __ieee754_hypot (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {104,121,112,111,116,0 }; // BEGIN GLOBAL FUNCTION DEF: hypot .visible .func (.param .f64 %value_out) hypot (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r26; .reg .u32 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r50; .reg .u64 %r51; .reg .pred %r53; .reg .f64 %r54; .reg .f64 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; mov.f64 %r34,%ar0; mov.f64 %r35,%ar1; .loc 1 77 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; call (%value_in),__ieee754_hypot,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } mov.f64 %r33,%r38; .loc 1 78 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; .loc 1 79 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),finite,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.ne.u32 %r43,%r42,0; @ %r43 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r34; call (%value_in),finite,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),finite,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,0; @ %r49 bra $L1; .loc 1 87 0 mov.u32 %r50,3; st.u32 [%frame],%r50; .loc 1 88 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 89 0 st.u32 [%frame+40],%r42; .loc 1 90 0 st.f64 [%frame+16],%r34; .loc 1 91 0 st.f64 [%frame+24],%r35; .loc 1 92 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r53,%r26,0; @ %r53 bra $L3; .loc 1 93 0 mov.f64 %r54,0d47efffffe0000000; st.f64 [%frame+32],%r54; bra $L4; $L3: .loc 1 95 0 mov.f64 %r55,0d7ff0000000000000; st.f64 [%frame+32],%r55; .loc 1 96 0 setp.ne.u32 %r56,%r26,2; @ %r56 bra $L4; .loc 1 97 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; bra $L5; $L4: .loc 1 98 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r60,[%value_in]; } setp.ne.u32 %r61,%r60,0; @ %r61 bra $L5; .loc 1 99 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } mov.u32 %r63,34; st.u32 [%r62],%r63; $L5: .loc 1 101 0 ld.u32 %r64,[%frame+40]; setp.eq.u32 %r65,%r64,0; @ %r65 bra $L6; .loc 1 102 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r66],%r32; $L6: .loc 1 103 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 107 0 mov.f64 %value,%r33; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_j0.o/ 0 0 0 644 8703 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j0 .visible .func (.param .f64 %value_out) j0 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_j0.c" // BEGIN GLOBAL FUNCTION DECL: y0 .visible .func (.param .f64 %value_out) y0 (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0 .extern .func (.param .f64 %value_out) __ieee754_j0 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0 .extern .func (.param .f64 %value_out) __ieee754_y0 (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {106,48,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[3] = {121,48,0 }; // BEGIN GLOBAL FUNCTION DEF: j0 .visible .func (.param .f64 %value_out) j0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .f64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .f64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; mov.f64 %r33,%ar0; .loc 1 141 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_j0,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 142 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 143 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r42,[%value_in]; } setp.gt.f64 %r43,%r42,0d434921fb54442d18; @ ! %r43 bra $L1; .loc 1 145 0 mov.u32 %r44,5; st.u32 [%frame],%r44; .loc 1 146 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 147 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 148 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 149 0 mov.f64 %r47,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 150 0 ld.global.u32 %r48,[__fdlib_version]; setp.ne.u32 %r49,%r48,2; @ %r49 bra $L4; .loc 1 151 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r50,[%value_in]; } mov.u32 %r51,34; st.u32 [%r50],%r51; bra $L5; $L4: .loc 1 152 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.ne.u32 %r54,%r53,0; @ %r54 bra $L5; .loc 1 153 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; $L5: .loc 1 155 0 ld.u32 %r57,[%frame+40]; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L6; .loc 1 156 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r59],%r31; $L6: .loc 1 157 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 161 0 mov.f64 %value,%r32; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y0 .visible .func (.param .f64 %value_out) y0 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r30; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .pred %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .f64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r39,%ar0; .loc 1 175 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__ieee754_y0,(%out_arg1); ld.param.f64 %r41,[%value_in]; } mov.f64 %r38,%r41; .loc 1 176 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L17; .loc 1 177 0 setp.le.f64 %r47,%r39,0d0000000000000000; @ ! %r47 bra $L43; .loc 1 185 0 mov.u32 %r48,1; st.u32 [%frame],%r48; .loc 1 186 0 cvta.const.u64 %r49,$LC1; st.u64 [%frame+8],%r49; .loc 1 187 0 mov.u32 %r50,0; st.u32 [%frame+40],%r50; .loc 1 188 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 189 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r51,%r24,0; @ %r51 bra $L21; .loc 1 190 0 mov.f64 %r52,0dc7efffffe0000000; st.f64 [%frame+32],%r52; bra $L22; $L21: .loc 1 192 0 mov.f64 %r53,0dfff0000000000000; st.f64 [%frame+32],%r53; .loc 1 193 0 setp.ne.u32 %r54,%r24,2; @ %r54 bra $L22; .loc 1 194 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,33; st.u32 [%r55],%r56; bra $L23; $L22: .loc 1 195 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L23; .loc 1 196 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,33; st.u32 [%r60],%r61; $L23: .loc 1 198 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L24; .loc 1 199 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r30,[%frame+40]; st.u32 [%r64],%r30; $L24: .loc 1 200 0 ld.f64 %r38,[%frame+32]; bra $L17; $L43: .loc 1 202 0 setp.gt.f64 %r65,%r39,0d434921fb54442d18; @ ! %r65 bra $L17; .loc 1 204 0 mov.u32 %r66,5; st.u32 [%frame],%r66; .loc 1 205 0 cvta.const.u64 %r67,$LC1; st.u64 [%frame+8],%r67; .loc 1 206 0 mov.u32 %r68,0; st.u32 [%frame+40],%r68; .loc 1 207 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 208 0 mov.f64 %r69,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 209 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r71,%r70,2; @ %r71 bra $L26; .loc 1 210 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L27; $L26: .loc 1 211 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L27; .loc 1 212 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L27: .loc 1 214 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L28; .loc 1 215 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r81],%r37; $L28: .loc 1 216 0 ld.f64 %r38,[%frame+32]; $L17: .loc 1 220 0 mov.f64 %value,%r38; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_j1.o/ 0 0 0 644 8667 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j1 .visible .func (.param .f64 %value_out) j1 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_j1.c" // BEGIN GLOBAL FUNCTION DECL: y1 .visible .func (.param .f64 %value_out) y1 (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1 .extern .func (.param .f64 %value_out) __ieee754_j1 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1 .extern .func (.param .f64 %value_out) __ieee754_y1 (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {106,49,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[3] = {121,49,0 }; // BEGIN GLOBAL FUNCTION DEF: j1 .visible .func (.param .f64 %value_out) j1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .f64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .f64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; mov.f64 %r33,%ar0; .loc 1 35 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_j1,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 36 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 37 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r42,[%value_in]; } setp.gt.f64 %r43,%r42,0d434921fb54442d18; @ ! %r43 bra $L1; .loc 1 39 0 mov.u32 %r44,5; st.u32 [%frame],%r44; .loc 1 40 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 41 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 42 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 43 0 mov.f64 %r47,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 44 0 ld.global.u32 %r48,[__fdlib_version]; setp.ne.u32 %r49,%r48,2; @ %r49 bra $L4; .loc 1 45 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r50,[%value_in]; } mov.u32 %r51,34; st.u32 [%r50],%r51; bra $L5; $L4: .loc 1 46 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.ne.u32 %r54,%r53,0; @ %r54 bra $L5; .loc 1 47 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; $L5: .loc 1 49 0 ld.u32 %r57,[%frame+40]; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L6; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r59],%r31; $L6: .loc 1 51 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 55 0 mov.f64 %value,%r32; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y1 .visible .func (.param .f64 %value_out) y1 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r30; .reg .u32 %r37; .reg .f64 %r38; .reg .f64 %r39; .reg .f64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .pred %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .f64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r39,%ar0; .loc 1 69 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__ieee754_y1,(%out_arg1); ld.param.f64 %r41,[%value_in]; } mov.f64 %r38,%r41; .loc 1 70 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.eq.u32 %r46,%r45,0; @ %r46 bra $L17; .loc 1 71 0 setp.le.f64 %r47,%r39,0d0000000000000000; @ ! %r47 bra $L43; .loc 1 79 0 mov.u32 %r48,1; st.u32 [%frame],%r48; .loc 1 80 0 cvta.const.u64 %r49,$LC1; st.u64 [%frame+8],%r49; .loc 1 81 0 mov.u32 %r50,0; st.u32 [%frame+40],%r50; .loc 1 82 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 83 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r51,%r24,0; @ %r51 bra $L21; .loc 1 84 0 mov.f64 %r52,0dc7efffffe0000000; st.f64 [%frame+32],%r52; bra $L22; $L21: .loc 1 86 0 mov.f64 %r53,0dfff0000000000000; st.f64 [%frame+32],%r53; .loc 1 87 0 setp.ne.u32 %r54,%r24,2; @ %r54 bra $L22; .loc 1 88 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,33; st.u32 [%r55],%r56; bra $L23; $L22: .loc 1 89 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L23; .loc 1 90 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,33; st.u32 [%r60],%r61; $L23: .loc 1 92 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L24; .loc 1 93 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r30,[%frame+40]; st.u32 [%r64],%r30; $L24: .loc 1 94 0 ld.f64 %r38,[%frame+32]; bra $L17; $L43: .loc 1 96 0 setp.gt.f64 %r65,%r39,0d434921fb54442d18; @ ! %r65 bra $L17; .loc 1 98 0 mov.u32 %r66,5; st.u32 [%frame],%r66; .loc 1 99 0 cvta.const.u64 %r67,$LC1; st.u64 [%frame+8],%r67; .loc 1 100 0 mov.u32 %r68,0; st.u32 [%frame+40],%r68; .loc 1 101 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 102 0 mov.f64 %r69,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 103 0 ld.global.u32 %r70,[__fdlib_version]; setp.ne.u32 %r71,%r70,2; @ %r71 bra $L26; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L27; $L26: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L27; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L27: .loc 1 108 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L28; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r81],%r37; $L28: .loc 1 110 0 ld.f64 %r38,[%frame+32]; $L17: .loc 1 114 0 mov.f64 %value,%r38; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_jn.o/ 0 0 0 644 9264 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: jn .visible .func (.param .f64 %value_out) jn (.param .u32 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_jn.c" // BEGIN GLOBAL FUNCTION DECL: yn .visible .func (.param .f64 %value_out) yn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_jn .extern .func (.param .f64 %value_out) __ieee754_jn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabs .extern .func (.param .f64 %value_out) fabs (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_yn .extern .func (.param .f64 %value_out) __ieee754_yn (.param .u32 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {106,110,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[3] = {121,110,0 }; // BEGIN GLOBAL FUNCTION DEF: jn .visible .func (.param .f64 %value_out) jn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r32; .reg .f64 %r33; .reg .u32 %r34; .reg .f64 %r35; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .f64 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u32 %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; mov.u32 %r34,%ar0; mov.f64 %r35,%ar1; .loc 1 57 0 { .param .f64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r34; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r35; call (%value_in),__ieee754_jn,(%out_arg1,%out_arg2); ld.param.f64 %r38,[%value_in]; } mov.f64 %r33,%r38; .loc 1 58 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 59 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),fabs,(%out_arg1); ld.param.f64 %r45,[%value_in]; } setp.gt.f64 %r46,%r45,0d434921fb54442d18; @ ! %r46 bra $L1; .loc 1 61 0 mov.u32 %r47,5; st.u32 [%frame],%r47; .loc 1 62 0 cvta.const.u64 %r48,$LC0; st.u64 [%frame+8],%r48; .loc 1 63 0 mov.u32 %r49,0; st.u32 [%frame+40],%r49; .loc 1 64 0 cvt.rn.f64.s32 %r50,%r34; st.f64 [%frame+16],%r50; .loc 1 65 0 st.f64 [%frame+24],%r35; .loc 1 66 0 mov.f64 %r51,0d0000000000000000; st.f64 [%frame+32],%r51; .loc 1 67 0 ld.global.u32 %r52,[__fdlib_version]; setp.ne.u32 %r53,%r52,2; @ %r53 bra $L4; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,34; st.u32 [%r54],%r55; bra $L5; $L4: .loc 1 69 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L5; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; $L5: .loc 1 72 0 ld.u32 %r61,[%frame+40]; setp.eq.u32 %r62,%r61,0; @ %r62 bra $L6; .loc 1 73 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r63],%r32; $L6: .loc 1 74 0 ld.f64 %r33,[%frame+32]; $L1: .loc 1 78 0 mov.f64 %value,%r33; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: yn .visible .func (.param .f64 %value_out) yn (.param .u32 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r25; .reg .u32 %r31; .reg .u32 %r39; .reg .f64 %r40; .reg .u32 %r41; .reg .f64 %r42; .reg .f64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .f64 %r55; .reg .pred %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .f64 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .u64 %r87; mov.u32 %r41,%ar0; mov.f64 %r42,%ar1; .loc 1 92 0 { .param .f64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r41; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r42; call (%value_in),__ieee754_yn,(%out_arg1,%out_arg2); ld.param.f64 %r45,[%value_in]; } mov.f64 %r40,%r45; .loc 1 93 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L17; .loc 1 94 0 setp.le.f64 %r51,%r42,0d0000000000000000; @ ! %r51 bra $L43; .loc 1 102 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 103 0 cvta.const.u64 %r53,$LC1; st.u64 [%frame+8],%r53; .loc 1 104 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 105 0 cvt.rn.f64.s32 %r55,%r41; st.f64 [%frame+16],%r55; .loc 1 106 0 st.f64 [%frame+24],%r42; .loc 1 107 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r56,%r25,0; @ %r56 bra $L21; .loc 1 108 0 mov.f64 %r57,0dc7efffffe0000000; st.f64 [%frame+32],%r57; bra $L22; $L21: .loc 1 110 0 mov.f64 %r58,0dfff0000000000000; st.f64 [%frame+32],%r58; .loc 1 111 0 setp.ne.u32 %r59,%r25,2; @ %r59 bra $L22; .loc 1 112 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,33; st.u32 [%r60],%r61; bra $L23; $L22: .loc 1 113 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r63,[%value_in]; } setp.ne.u32 %r64,%r63,0; @ %r64 bra $L23; .loc 1 114 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; $L23: .loc 1 116 0 ld.u32 %r67,[%frame+40]; setp.eq.u32 %r68,%r67,0; @ %r68 bra $L24; .loc 1 117 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r69,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r69],%r31; $L24: .loc 1 118 0 ld.f64 %r40,[%frame+32]; bra $L17; $L43: .loc 1 120 0 setp.gt.f64 %r70,%r42,0d434921fb54442d18; @ ! %r70 bra $L17; .loc 1 122 0 mov.u32 %r71,5; st.u32 [%frame],%r71; .loc 1 123 0 cvta.const.u64 %r72,$LC1; st.u64 [%frame+8],%r72; .loc 1 124 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 125 0 cvt.rn.f64.s32 %r74,%r41; st.f64 [%frame+16],%r74; .loc 1 126 0 st.f64 [%frame+24],%r42; .loc 1 127 0 mov.f64 %r75,0d0000000000000000; st.f64 [%frame+32],%r75; .loc 1 128 0 ld.global.u32 %r76,[__fdlib_version]; setp.ne.u32 %r77,%r76,2; @ %r77 bra $L26; .loc 1 129 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r78,[%value_in]; } mov.u32 %r79,34; st.u32 [%r78],%r79; bra $L27; $L26: .loc 1 130 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r81,[%value_in]; } setp.ne.u32 %r82,%r81,0; @ %r82 bra $L27; .loc 1 131 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } mov.u32 %r84,34; st.u32 [%r83],%r84; $L27: .loc 1 133 0 ld.u32 %r85,[%frame+40]; setp.eq.u32 %r86,%r85,0; @ %r86 bra $L28; .loc 1 134 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r87,[%value_in]; } ld.u32 %r39,[%frame+40]; st.u32 [%r87],%r39; $L28: .loc 1 135 0 ld.f64 %r40,[%frame+32]; $L17: .loc 1 139 0 mov.f64 %value,%r40; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } /1403 0 0 0 644 5504 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgamma .visible .func (.param .f64 %value_out) lgamma (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .extern .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {108,103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: lgamma .visible .func (.param .f64 %value_out) lgamma (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r37; .reg .u32 %r38; .reg .f64 %r39; .reg .f64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .f64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .f64 %r58; .reg .f64 %r59; .reg .f64 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r78; .reg .pred %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .u64 %r84; mov.f64 %r40,%ar0; .loc 1 39 0 ld.global.u64 %r44,[_impure_ptr]; add.u64 %r43,%r44,224; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; call (%value_in),__ieee754_lgamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r45,[%value_in]; } mov.f64 %r39,%r45; .loc 1 40 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L1; .loc 1 41 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r45; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.ne.u32 %r50,%r49,0; @ %r50 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } setp.eq.u32 %r53,%r52,0; @ %r53 bra $L1; .loc 1 48 0 cvta.const.u64 %r54,$LC0; st.u64 [%frame+8],%r54; .loc 1 49 0 st.u32 [%frame+40],%r49; .loc 1 50 0 st.f64 [%frame+16],%r40; .loc 1 51 0 st.f64 [%frame+24],%r40; .loc 1 52 0 ld.global.u32 %r56,[__fdlib_version]; setp.ne.u32 %r57,%r56,0; @ %r57 bra $L3; .loc 1 53 0 mov.f64 %r58,0d47efffffe0000000; st.f64 [%frame+32],%r58; bra $L4; $L3: .loc 1 55 0 mov.f64 %r59,0d7ff0000000000000; st.f64 [%frame+32],%r59; $L4: .loc 1 56 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r40; call (%value_in),floor,(%out_arg1); ld.param.f64 %r61,[%value_in]; } setp.neu.f64 %r62,%r61,%r40; @ %r62 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f64 %r63,%r40,0d0000000000000000; @ ! %r63 bra $L6; .loc 1 58 0 mov.u32 %r64,2; st.u32 [%frame],%r64; .loc 1 59 0 setp.ne.u32 %r65,%r38,2; @ %r65 bra $L8; .loc 1 60 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } mov.u32 %r67,33; st.u32 [%r66],%r67; bra $L9; $L8: .loc 1 61 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r69,[%value_in]; } setp.eq.u32 %r70,%r69,0; @ ! %r70 bra $L9; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } mov.u32 %r72,33; st.u32 [%r71],%r72; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 67 0 mov.u32 %r73,3; st.u32 [%frame],%r73; .loc 1 68 0 setp.ne.u32 %r74,%r38,2; @ %r74 bra $L11; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,34; st.u32 [%r75],%r76; bra $L9; $L11: .loc 1 70 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r78,[%value_in]; } setp.ne.u32 %r79,%r78,0; @ %r79 bra $L9; .loc 1 71 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r80,[%value_in]; } mov.u32 %r81,34; st.u32 [%r80],%r81; $L9: .loc 1 74 0 ld.u32 %r82,[%frame+40]; setp.eq.u32 %r83,%r82,0; @ %r83 bra $L13; .loc 1 75 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r84,[%value_in]; } ld.u32 %r37,[%frame+40]; st.u32 [%r84],%r37; $L13: .loc 1 76 0 ld.f64 %r39,[%frame+32]; $L1: .loc 1 80 0 mov.f64 %value,%r39; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_log.o/ 0 0 0 644 5339 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: log .visible .func (.param .f64 %value_out) log (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_log.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_log .extern .func (.param .f64 %value_out) __ieee754_log (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {108,111,103,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: log .visible .func (.param .f64 %value_out) log (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u64 %r70; .reg .f64 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r76; .reg .u32 %r77; mov.f64 %r36,%ar0; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__ieee754_log,(%out_arg1); ld.param.f64 %r38,[%value_in]; } mov.f64 %r35,%r38; .loc 1 77 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; setp.gt.f64 %r44,%r36,0d0000000000000000; @ %r44 bra $L1; .loc 1 84 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 85 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 86 0 st.f64 [%frame+16],%r36; .loc 1 87 0 st.f64 [%frame+24],%r36; .loc 1 88 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r47,%r24,0; @ %r47 bra $L3; .loc 1 89 0 mov.f64 %r48,0dc7efffffe0000000; st.f64 [%frame+32],%r48; .loc 1 92 0 setp.eq.f64 %r49,%r36,0d0000000000000000; @ %r49 bra $L4; bra $L21; $L3: .loc 1 91 0 mov.f64 %r50,0dfff0000000000000; st.f64 [%frame+32],%r50; .loc 1 92 0 setp.neu.f64 %r51,%r36,0d0000000000000000; @ %r51 bra $L6; .loc 1 94 0 mov.u32 %r52,2; st.u32 [%frame],%r52; .loc 1 95 0 setp.ne.u32 %r53,%r24,2; @ %r53 bra $L7; .loc 1 96 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,34; st.u32 [%r54],%r55; bra $L8; $L7: .loc 1 97 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L8; .loc 1 98 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; bra $L8; $L6: .loc 1 102 0 mov.u32 %r61,1; st.u32 [%frame],%r61; .loc 1 103 0 setp.ne.u32 %r62,%r24,2; @ %r62 bra $L9; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L10; $L9: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.ne.u32 %r67,%r66,0; @ %r67 bra $L10; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; $L10: .loc 1 108 0 cvta.const.u64 %r70,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; call (%value_in),nan,(%out_arg1); ld.param.f64 %r71,[%value_in]; } st.f64 [%frame+32],%r71; $L8: .loc 1 110 0 ld.u32 %r72,[%frame+40]; setp.eq.u32 %r73,%r72,0; @ %r73 bra $L11; .loc 1 111 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r74],%r34; $L11: .loc 1 112 0 ld.f64 %r35,[%frame+32]; bra $L1; $L4: .loc 1 94 0 mov.u32 %r76,2; st.u32 [%frame],%r76; bra $L7; $L21: .loc 1 102 0 mov.u32 %r77,1; st.u32 [%frame],%r77; bra $L9; $L1: .loc 1 114 0 mov.f64 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_log10.o/0 0 0 644 5378 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: log10 .visible .func (.param .f64 %value_out) log10 (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_log10.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10 .extern .func (.param .f64 %value_out) __ieee754_log10 (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {108,111,103,49,48,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: log10 .visible .func (.param .f64 %value_out) log10 (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r34; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .pred %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u64 %r70; .reg .f64 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r76; .reg .u32 %r77; mov.f64 %r36,%ar0; .loc 1 73 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__ieee754_log10,(%out_arg1); ld.param.f64 %r38,[%value_in]; } mov.f64 %r35,%r38; .loc 1 74 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 75 0 setp.le.f64 %r44,%r36,0d0000000000000000; @ ! %r44 bra $L1; .loc 1 82 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 83 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 84 0 st.f64 [%frame+16],%r36; .loc 1 85 0 st.f64 [%frame+24],%r36; .loc 1 86 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r47,%r24,0; @ %r47 bra $L4; .loc 1 87 0 mov.f64 %r48,0dc7efffffe0000000; st.f64 [%frame+32],%r48; .loc 1 90 0 setp.eq.f64 %r49,%r36,0d0000000000000000; @ %r49 bra $L5; bra $L23; $L4: .loc 1 89 0 mov.f64 %r50,0dfff0000000000000; st.f64 [%frame+32],%r50; .loc 1 90 0 setp.neu.f64 %r51,%r36,0d0000000000000000; @ %r51 bra $L7; .loc 1 92 0 mov.u32 %r52,2; st.u32 [%frame],%r52; .loc 1 93 0 setp.ne.u32 %r53,%r24,2; @ %r53 bra $L8; .loc 1 94 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,34; st.u32 [%r54],%r55; bra $L9; $L8: .loc 1 95 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L9; .loc 1 96 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; bra $L9; $L7: .loc 1 100 0 mov.u32 %r61,1; st.u32 [%frame],%r61; .loc 1 101 0 setp.ne.u32 %r62,%r24,2; @ %r62 bra $L10; .loc 1 102 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L11; $L10: .loc 1 103 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.ne.u32 %r67,%r66,0; @ %r67 bra $L11; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; $L11: .loc 1 106 0 cvta.const.u64 %r70,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; call (%value_in),nan,(%out_arg1); ld.param.f64 %r71,[%value_in]; } st.f64 [%frame+32],%r71; $L9: .loc 1 108 0 ld.u32 %r72,[%frame+40]; setp.eq.u32 %r73,%r72,0; @ %r73 bra $L12; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r74],%r34; $L12: .loc 1 110 0 ld.f64 %r35,[%frame+32]; bra $L1; $L5: .loc 1 92 0 mov.u32 %r76,2; st.u32 [%frame],%r76; bra $L8; $L23: .loc 1 100 0 mov.u32 %r77,1; st.u32 [%frame],%r77; bra $L10; $L1: .loc 1 114 0 mov.f64 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_pow.o/ 0 0 0 644 15556 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: pow .visible .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_pow.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_pow .extern .func (.param .f64 %value_out) __ieee754_pow (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {112,111,119,0 }; // BEGIN GLOBAL FUNCTION DEF: pow .visible .func (.param .f64 %value_out) pow (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r32; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r46; .reg .u32 %r51; .reg .u32 %r58; .reg .u32 %r68; .reg .u32 %r77; .reg .u32 %r78; .reg .f64 %r79; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r82; .reg .f64 %r85; .reg .u32 %r86; .reg .pred %r87; .reg .u32 %r89; .reg .pred %r90; .reg .u32 %r92; .reg .pred %r93; .reg .pred %r94; .reg .u32 %r95; .reg .u64 %r96; .reg .f64 %r98; .reg .u32 %r100; .reg .u32 %r101; .reg .u32 %r103; .reg .u32 %r104; .reg .u16 %r105; .reg .u16 %r106; .reg .u16 %r107; .reg .u32 %r108; .reg .u16 %r109; .reg .pred %r110; .reg .u32 %r112; .reg .pred %r113; .reg .u64 %r114; .reg .u32 %r115; .reg .u32 %r116; .reg .pred %r117; .reg .u64 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u32 %r121; .reg .u64 %r122; .reg .u32 %r123; .reg .f64 %r124; .reg .u32 %r125; .reg .pred %r126; .reg .u32 %r128; .reg .pred %r129; .reg .u64 %r130; .reg .u32 %r131; .reg .u32 %r132; .reg .pred %r133; .reg .u64 %r134; .reg .u32 %r136; .reg .pred %r137; .reg .pred %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .pred %r142; .reg .f64 %r143; .reg .f64 %r144; .reg .pred %r145; .reg .u64 %r146; .reg .u32 %r147; .reg .u32 %r149; .reg .pred %r150; .reg .u64 %r151; .reg .u32 %r152; .reg .u32 %r153; .reg .pred %r154; .reg .u64 %r155; .reg .u32 %r157; .reg .pred %r158; .reg .u32 %r160; .reg .pred %r161; .reg .u32 %r163; .reg .pred %r164; .reg .u32 %r166; .reg .pred %r167; .reg .u32 %r168; .reg .u64 %r169; .reg .pred %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .f64 %r174; .reg .pred %r175; .reg .u64 %r176; .reg .u32 %r177; .reg .u32 %r179; .reg .pred %r180; .reg .u64 %r181; .reg .u32 %r182; .reg .u32 %r183; .reg .pred %r184; .reg .u64 %r185; .reg .u32 %r186; .reg .u64 %r187; .reg .pred %r190; .reg .f64 %r191; .reg .pred %r192; .reg .f64 %r194; .reg .pred %r195; .reg .f64 %r196; .reg .f64 %r197; .reg .pred %r198; .reg .f64 %r200; .reg .pred %r201; .reg .f64 %r202; .reg .pred %r204; .reg .u64 %r205; .reg .u32 %r206; .reg .u32 %r208; .reg .pred %r209; .reg .u64 %r210; .reg .u32 %r211; .reg .u32 %r212; .reg .pred %r213; .reg .u64 %r214; .reg .pred %r215; .reg .u32 %r217; .reg .pred %r218; .reg .u32 %r220; .reg .pred %r221; .reg .u32 %r222; .reg .u64 %r223; .reg .u32 %r224; .reg .f64 %r225; .reg .u32 %r226; .reg .pred %r227; .reg .u64 %r228; .reg .u32 %r229; .reg .u32 %r231; .reg .pred %r232; .reg .u64 %r233; .reg .u32 %r234; .reg .u32 %r235; .reg .pred %r236; .reg .u64 %r237; .reg .u32 %r239; mov.f64 %r81,%ar0; mov.f64 %r82,%ar1; .loc 1 85 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r82; call (%value_in),__ieee754_pow,(%out_arg1,%out_arg2); ld.param.f64 %r85,[%value_in]; } mov.f64 %r80,%r85; .loc 1 86 0 ld.global.u32 %r86,[__fdlib_version]; setp.eq.u32 %r87,%r86,-1; @ %r87 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r89,[%value_in]; } setp.eq.u32 %r90,%r89,0; @ %r90 bra $L1; .loc 1 87 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r92,[%value_in]; } setp.ne.u32 %r93,%r92,0; @ %r93 bra $L3; .loc 1 88 0 setp.neu.f64 %r94,%r82,0d0000000000000000; @ %r94 bra $L1; .loc 1 91 0 mov.u32 %r95,1; st.u32 [%frame],%r95; .loc 1 92 0 cvta.const.u64 %r96,$LC0; st.u64 [%frame+8],%r96; .loc 1 93 0 st.u32 [%frame+40],%r92; .loc 1 94 0 st.f64 [%frame+16],%r81; .loc 1 95 0 st.f64 [%frame+24],%r82; .loc 1 96 0 mov.f64 %r98,0d3ff0000000000000; st.f64 [%frame+32],%r98; .loc 1 97 0 ld.global.u32 %r78,[__fdlib_version]; set.u32.eq.u32 %r100,%r78,-1; neg.s32 %r101,%r100; set.u32.eq.u32 %r103,%r78,2; neg.s32 %r104,%r103; cvt.u16.u32 %r106,%r101; cvt.u16.u32 %r107,%r104; or.b16 %r105,%r106,%r107; cvt.u32.u16 %r108,%r105; cvt.u16.u8 %r109,%r108; setp.ne.u16 %r110,%r109,0; @ %r110 bra $L35; .loc 1 99 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r112,[%value_in]; } setp.ne.u32 %r113,%r112,0; @ %r113 bra $L5; .loc 1 100 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r114,[%value_in]; } mov.u32 %r115,33; st.u32 [%r114],%r115; $L5: .loc 1 102 0 ld.u32 %r116,[%frame+40]; setp.ne.u32 %r117,%r116,0; @ %r117 bra $L6; ld.f64 %r80,[%frame+32]; bra $L1; $L6: .loc 1 103 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r118,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r118],%r32; ld.f64 %r80,[%frame+32]; bra $L1; $L35: mov.f64 %r80,%r98; .loc 1 104 0 bra $L1; $L3: .loc 1 108 0 setp.neu.f64 %r119,%r81,0d0000000000000000; @ %r119 bra $L7; .loc 1 109 0 setp.neu.f64 %r120,%r82,0d0000000000000000; @ %r120 bra $L8; .loc 1 112 0 mov.u32 %r121,1; st.u32 [%frame],%r121; .loc 1 113 0 cvta.const.u64 %r122,$LC0; st.u64 [%frame+8],%r122; .loc 1 114 0 mov.u32 %r123,0; st.u32 [%frame+40],%r123; .loc 1 115 0 st.f64 [%frame+16],%r81; .loc 1 116 0 st.f64 [%frame+24],%r82; .loc 1 117 0 mov.f64 %r124,0d0000000000000000; st.f64 [%frame+32],%r124; .loc 1 118 0 ld.global.u32 %r125,[__fdlib_version]; setp.ne.u32 %r126,%r125,0; @ %r126 bra $L36; .loc 1 119 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r128,[%value_in]; } setp.ne.u32 %r129,%r128,0; @ %r129 bra $L10; .loc 1 120 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r130,[%value_in]; } mov.u32 %r131,33; st.u32 [%r130],%r131; $L10: .loc 1 122 0 ld.u32 %r132,[%frame+40]; setp.ne.u32 %r133,%r132,0; @ %r133 bra $L11; ld.f64 %r80,[%frame+32]; bra $L1; $L11: .loc 1 123 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r134,[%value_in]; } ld.u32 %r38,[%frame+40]; st.u32 [%r134],%r38; ld.f64 %r80,[%frame+32]; bra $L1; $L36: mov.f64 %r80,0d3ff0000000000000; .loc 1 124 0 bra $L1; $L8: .loc 1 126 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),finite,(%out_arg1); ld.param.u32 %r136,[%value_in]; } setp.eq.u32 %r137,%r136,0; @ %r137 bra $L1; setp.lt.f64 %r138,%r82,0d0000000000000000; @ ! %r138 bra $L1; .loc 1 128 0 mov.u32 %r139,1; st.u32 [%frame],%r139; .loc 1 129 0 cvta.const.u64 %r140,$LC0; st.u64 [%frame+8],%r140; .loc 1 130 0 mov.u32 %r141,0; st.u32 [%frame+40],%r141; .loc 1 131 0 st.f64 [%frame+16],%r81; .loc 1 132 0 st.f64 [%frame+24],%r82; .loc 1 133 0 ld.global.u32 %r40,[__fdlib_version]; setp.ne.u32 %r142,%r40,0; @ %r142 bra $L13; .loc 1 134 0 mov.f64 %r143,0d0000000000000000; st.f64 [%frame+32],%r143; bra $L14; $L13: .loc 1 136 0 mov.f64 %r144,0dfff0000000000000; st.f64 [%frame+32],%r144; .loc 1 137 0 setp.ne.u32 %r145,%r40,2; @ %r145 bra $L14; .loc 1 138 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r146,[%value_in]; } mov.u32 %r147,33; st.u32 [%r146],%r147; bra $L15; $L14: .loc 1 139 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r149,[%value_in]; } setp.ne.u32 %r150,%r149,0; @ %r150 bra $L15; .loc 1 140 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r151,[%value_in]; } mov.u32 %r152,33; st.u32 [%r151],%r152; $L15: .loc 1 142 0 ld.u32 %r153,[%frame+40]; setp.eq.u32 %r154,%r153,0; @ %r154 bra $L16; .loc 1 143 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r155,[%value_in]; } ld.u32 %r46,[%frame+40]; st.u32 [%r155],%r46; $L16: .loc 1 144 0 ld.f64 %r80,[%frame+32]; bra $L1; $L7: .loc 1 148 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r85; call (%value_in),finite,(%out_arg1); ld.param.u32 %r157,[%value_in]; } setp.ne.u32 %r158,%r157,0; @ %r158 bra $L17; .loc 1 149 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),finite,(%out_arg1); ld.param.u32 %r160,[%value_in]; } setp.eq.u32 %r161,%r160,0; @ %r161 bra $L17; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),finite,(%out_arg1); ld.param.u32 %r163,[%value_in]; } setp.eq.u32 %r164,%r163,0; @ %r164 bra $L17; .loc 1 150 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r85; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r166,[%value_in]; } setp.ne.u32 %r167,%r166,0; @ %r167 bra $L18; .loc 1 152 0 mov.u32 %r168,1; st.u32 [%frame],%r168; .loc 1 153 0 cvta.const.u64 %r169,$LC0; st.u64 [%frame+8],%r169; .loc 1 154 0 st.u32 [%frame+40],%r166; .loc 1 155 0 st.f64 [%frame+16],%r81; .loc 1 156 0 st.f64 [%frame+24],%r82; .loc 1 157 0 ld.global.u32 %r51,[__fdlib_version]; setp.ne.u32 %r171,%r51,0; @ %r171 bra $L19; .loc 1 158 0 mov.f64 %r172,0d0000000000000000; st.f64 [%frame+32],%r172; bra $L20; $L19: .loc 1 160 0 mov.f64 %r174,0d0000000000000000; div.rn.f64 %r173,%r174,0d0000000000000000; st.f64 [%frame+32],%r173; .loc 1 161 0 setp.ne.u32 %r175,%r51,2; @ %r175 bra $L20; .loc 1 162 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r176,[%value_in]; } mov.u32 %r177,33; st.u32 [%r176],%r177; bra $L21; $L20: .loc 1 163 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r179,[%value_in]; } setp.ne.u32 %r180,%r179,0; @ %r180 bra $L21; .loc 1 164 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r181,[%value_in]; } mov.u32 %r182,33; st.u32 [%r181],%r182; $L21: .loc 1 166 0 ld.u32 %r183,[%frame+40]; setp.eq.u32 %r184,%r183,0; @ %r184 bra $L22; .loc 1 167 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r185,[%value_in]; } ld.u32 %r58,[%frame+40]; st.u32 [%r185],%r58; $L22: .loc 1 168 0 ld.f64 %r80,[%frame+32]; bra $L1; $L18: .loc 1 171 0 mov.u32 %r186,3; st.u32 [%frame],%r186; .loc 1 172 0 cvta.const.u64 %r187,$LC0; st.u64 [%frame+8],%r187; .loc 1 173 0 st.u32 [%frame+40],%r157; .loc 1 174 0 st.f64 [%frame+16],%r81; .loc 1 175 0 st.f64 [%frame+24],%r82; mul.f64 %r79,%r82,0d3fe0000000000000; .loc 1 176 0 ld.global.u32 %r239,[__fdlib_version]; setp.ne.u32 %r190,%r239,0; @ %r190 bra $L23; .loc 1 177 0 mov.f64 %r191,0d47efffffe0000000; st.f64 [%frame+32],%r191; .loc 1 179 0 setp.lt.f64 %r192,%r81,0d0000000000000000; @ ! %r192 bra $L24; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r79; call (%value_in),rint,(%out_arg1); ld.param.f64 %r194,[%value_in]; } setp.neu.f64 %r195,%r194,%r79; @ %r195 bra $L26; ld.global.u32 %r239,[__fdlib_version]; bra $L27; $L26: mov.f64 %r196,0dc7efffffe0000000; st.f64 [%frame+32],%r196; ld.global.u32 %r239,[__fdlib_version]; bra $L27; $L23: .loc 1 181 0 mov.f64 %r197,0d7ff0000000000000; st.f64 [%frame+32],%r197; .loc 1 183 0 setp.lt.f64 %r198,%r81,0d0000000000000000; @ ! %r198 bra $L27; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r79; call (%value_in),rint,(%out_arg1); ld.param.f64 %r200,[%value_in]; } setp.eq.f64 %r201,%r200,%r79; @ ! %r201 bra $L74; ld.global.u32 %r239,[__fdlib_version]; bra $L27; $L74: mov.f64 %r202,0dfff0000000000000; st.f64 [%frame+32],%r202; ld.global.u32 %r239,[__fdlib_version]; $L27: .loc 1 185 0 setp.ne.u32 %r204,%r239,2; @ %r204 bra $L24; .loc 1 186 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r205,[%value_in]; } mov.u32 %r206,34; st.u32 [%r205],%r206; bra $L30; $L24: .loc 1 187 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r208,[%value_in]; } setp.ne.u32 %r209,%r208,0; @ %r209 bra $L30; .loc 1 188 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r210,[%value_in]; } mov.u32 %r211,34; st.u32 [%r210],%r211; $L30: .loc 1 190 0 ld.u32 %r212,[%frame+40]; setp.eq.u32 %r213,%r212,0; @ %r213 bra $L31; .loc 1 191 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r214,[%value_in]; } ld.u32 %r68,[%frame+40]; st.u32 [%r214],%r68; $L31: .loc 1 192 0 ld.f64 %r80,[%frame+32]; bra $L1; $L17: .loc 1 196 0 setp.neu.f64 %r215,%r85,0d0000000000000000; @ %r215 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r81; call (%value_in),finite,(%out_arg1); ld.param.u32 %r217,[%value_in]; } setp.eq.u32 %r218,%r217,0; @ %r218 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r82; call (%value_in),finite,(%out_arg1); ld.param.u32 %r220,[%value_in]; } setp.eq.u32 %r221,%r220,0; @ %r221 bra $L1; .loc 1 198 0 mov.u32 %r222,4; st.u32 [%frame],%r222; .loc 1 199 0 cvta.const.u64 %r223,$LC0; st.u64 [%frame+8],%r223; .loc 1 200 0 mov.u32 %r224,0; st.u32 [%frame+40],%r224; .loc 1 201 0 st.f64 [%frame+16],%r81; .loc 1 202 0 st.f64 [%frame+24],%r82; .loc 1 203 0 mov.f64 %r225,0d0000000000000000; st.f64 [%frame+32],%r225; .loc 1 204 0 ld.global.u32 %r226,[__fdlib_version]; setp.ne.u32 %r227,%r226,2; @ %r227 bra $L32; .loc 1 205 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r228,[%value_in]; } mov.u32 %r229,34; st.u32 [%r228],%r229; bra $L33; $L32: .loc 1 206 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r231,[%value_in]; } setp.ne.u32 %r232,%r231,0; @ %r232 bra $L33; .loc 1 207 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r233,[%value_in]; } mov.u32 %r234,34; st.u32 [%r233],%r234; $L33: .loc 1 209 0 ld.u32 %r235,[%frame+40]; setp.eq.u32 %r236,%r235,0; @ %r236 bra $L34; .loc 1 210 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r237,[%value_in]; } ld.u32 %r77,[%frame+40]; st.u32 [%r237],%r77; $L34: .loc 1 211 0 ld.f64 %r80,[%frame+32]; $L1: .loc 1 215 0 mov.f64 %value,%r80; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } /1421 0 0 0 644 4336 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: remainder .visible .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_remainder.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainder .extern .func (.param .f64 %value_out) __ieee754_remainder (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[10] = {114,101,109,97,105,110,100,101,114,0 }; // BEGIN GLOBAL FUNCTION DEF: remainder .visible .func (.param .f64 %value_out) remainder (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r31; .reg .f64 %r35; .reg .f64 %r36; .reg .f64 %r37; .reg .f64 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r49; .reg .u32 %r50; .reg .u16 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .u32 %r54; .reg .u16 %r55; .reg .pred %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; mov.f64 %r36,%ar0; mov.f64 %r37,%ar1; .loc 1 68 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r36; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r37; call (%value_in),__ieee754_remainder,(%out_arg1,%out_arg2); ld.param.f64 %r40,[%value_in]; } mov.f64 %r35,%r40; .loc 1 69 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r44,[%value_in]; } .loc 1 70 0 set.u32.eq.f64 %r46,%r37,0d0000000000000000; neg.s32 %r47,%r46; .loc 1 69 0 set.u32.ne.u32 %r49,%r44,0; neg.s32 %r50,%r49; .loc 1 70 0 cvt.u16.u32 %r52,%r47; cvt.u16.u32 %r53,%r50; and.b16 %r51,%r52,%r53; cvt.u32.u16 %r54,%r51; cvt.u16.u8 %r55,%r54; setp.eq.u16 %r56,%r55,0; @ %r56 bra $L1; .loc 1 72 0 mov.u32 %r57,1; st.u32 [%frame],%r57; .loc 1 73 0 cvta.const.u64 %r58,$LC0; st.u64 [%frame+8],%r58; .loc 1 74 0 mov.u32 %r59,0; st.u32 [%frame+40],%r59; .loc 1 75 0 st.f64 [%frame+16],%r36; .loc 1 76 0 st.f64 [%frame+24],%r37; .loc 1 77 0 mov.f64 %r61,0d0000000000000000; div.rn.f64 %r60,%r61,0d0000000000000000; st.f64 [%frame+32],%r60; .loc 1 78 0 ld.global.u32 %r62,[__fdlib_version]; setp.ne.u32 %r63,%r62,2; @ %r63 bra $L3; .loc 1 79 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,33; st.u32 [%r64],%r65; bra $L4; $L3: .loc 1 80 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r67,[%value_in]; } setp.ne.u32 %r68,%r67,0; @ %r68 bra $L4; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r69,[%value_in]; } mov.u32 %r70,33; st.u32 [%r69],%r70; $L4: .loc 1 83 0 ld.u32 %r71,[%frame+40]; setp.eq.u32 %r72,%r71,0; @ %r72 bra $L5; .loc 1 84 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r73],%r31; $L5: .loc 1 85 0 ld.f64 %r35,[%frame+32]; $L1: .loc 1 89 0 mov.f64 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_scalb.o/0 0 0 644 7116 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: scalb .visible .func (.param .f64 %value_out) scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/w_scalb.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalb .extern .func (.param .f64 %value_out) __ieee754_scalb (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {115,99,97,108,98,0 }; // BEGIN GLOBAL FUNCTION DEF: scalb .visible .func (.param .f64 %value_out) scalb (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r32; .reg .u32 %r43; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r52; .reg .u32 %r53; .reg .pred %r54; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .pred %r67; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .u32 %r81; .reg .u32 %r82; .reg .u32 %r84; .reg .u32 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .u32 %r89; .reg .u16 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u32 %r94; .reg .f64 %r95; .reg .f64 %r97; .reg .u32 %r98; .reg .pred %r99; .reg .u64 %r100; .reg .u32 %r101; .reg .u32 %r103; .reg .pred %r104; .reg .u64 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .u32 %r111; .reg .pred %r112; .reg .u64 %r113; .reg .u32 %r114; mov.f64 %r48,%ar0; mov.f64 %r49,%ar1; .loc 1 51 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r48; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r49; call (%value_in),__ieee754_scalb,(%out_arg1,%out_arg2); ld.param.f64 %r52,[%value_in]; } mov.f64 %r47,%r52; .loc 1 52 0 ld.global.u32 %r53,[__fdlib_version]; setp.eq.u32 %r54,%r53,-1; @ %r54 bra $L1; .loc 1 53 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),finite,(%out_arg1); ld.param.u32 %r56,[%value_in]; } setp.ne.u32 %r57,%r56,0; @ %r57 bra $L3; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r52; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.eq.u32 %r60,%r59,0; @ %r60 bra $L3; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r48; call (%value_in),finite,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.eq.u32 %r63,%r62,0; @ %r63 bra $L3; .loc 1 55 0 mov.u32 %r64,3; st.u32 [%frame],%r64; .loc 1 56 0 cvta.const.u64 %r65,$LC0; st.u64 [%frame+8],%r65; .loc 1 57 0 st.u32 [%frame+40],%r56; .loc 1 58 0 st.f64 [%frame+16],%r48; .loc 1 59 0 st.f64 [%frame+24],%r49; .loc 1 60 0 setp.gt.f64 %r67,%r48,0d0000000000000000; selp.f64 %r46,0d7ff0000000000000,0dfff0000000000000,%r67; st.f64 [%frame+32],%r46; .loc 1 61 0 ld.global.u32 %r68,[__fdlib_version]; setp.ne.u32 %r69,%r68,2; @ %r69 bra $L5; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,34; st.u32 [%r70],%r71; bra $L6; $L5: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r73,[%value_in]; } setp.ne.u32 %r74,%r73,0; @ %r74 bra $L6; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,34; st.u32 [%r75],%r76; $L6: .loc 1 66 0 ld.u32 %r77,[%frame+40]; setp.eq.u32 %r78,%r77,0; @ %r78 bra $L7; .loc 1 67 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r79],%r32; $L7: .loc 1 68 0 ld.f64 %r47,[%frame+32]; bra $L1; $L3: .loc 1 70 0 set.u32.eq.f64 %r81,%r52,0d0000000000000000; neg.s32 %r82,%r81; set.u32.neu.f64 %r84,%r48,%r52; neg.s32 %r85,%r84; cvt.u16.u32 %r87,%r82; cvt.u16.u32 %r88,%r85; and.b16 %r86,%r87,%r88; cvt.u32.u16 %r89,%r86; cvt.u16.u8 %r90,%r89; setp.eq.u16 %r91,%r90,0; @ %r91 bra $L8; .loc 1 72 0 mov.u32 %r92,4; st.u32 [%frame],%r92; .loc 1 73 0 cvta.const.u64 %r93,$LC0; st.u64 [%frame+8],%r93; .loc 1 74 0 mov.u32 %r94,0; st.u32 [%frame+40],%r94; .loc 1 75 0 st.f64 [%frame+16],%r48; .loc 1 76 0 st.f64 [%frame+24],%r49; .loc 1 77 0 mov.f64 %r95,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r95; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r48; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r97,[%value_in]; } st.f64 [%frame+32],%r97; .loc 1 78 0 ld.global.u32 %r98,[__fdlib_version]; setp.ne.u32 %r99,%r98,2; @ %r99 bra $L9; .loc 1 79 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r100,[%value_in]; } mov.u32 %r101,34; st.u32 [%r100],%r101; bra $L10; $L9: .loc 1 80 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r103,[%value_in]; } setp.ne.u32 %r104,%r103,0; @ %r104 bra $L10; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r105,[%value_in]; } mov.u32 %r106,34; st.u32 [%r105],%r106; $L10: .loc 1 83 0 ld.u32 %r107,[%frame+40]; setp.eq.u32 %r108,%r107,0; @ %r108 bra $L11; .loc 1 84 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r109,[%value_in]; } ld.u32 %r43,[%frame+40]; st.u32 [%r109],%r43; $L11: .loc 1 85 0 ld.f64 %r47,[%frame+32]; bra $L1; $L8: .loc 1 88 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; call (%value_in),finite,(%out_arg1); ld.param.u32 %r111,[%value_in]; } setp.ne.u32 %r112,%r111,0; @ %r112 bra $L1; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r113,[%value_in]; } mov.u32 %r114,34; st.u32 [%r113],%r114; $L1: .loc 1 92 0 mov.f64 %value,%r47; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } /1442 0 0 0 644 1233 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sincos .visible .func sincos (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/math/w_sincos.c" // BEGIN GLOBAL FUNCTION DECL: sin .extern .func (.param .f64 %value_out) sin (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cos .extern .func (.param .f64 %value_out) cos (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sincos .visible .func sincos (.param .f64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .f64 %r28; .reg .f64 %r30; mov.f64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 18 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),sin,(%out_arg1); ld.param.f64 %r28,[%value_in]; } st.f64 [%r25],%r28; .loc 1 19 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r24; call (%value_in),cos,(%out_arg1); ld.param.f64 %r30,[%value_in]; } st.f64 [%r26],%r30; .loc 1 20 0 ret; } lib_a-w_sinh.o/ 0 0 0 644 4128 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sinh .visible .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_sinh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinh .extern .func (.param .f64 %value_out) __ieee754_sinh (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {115,105,110,104,0 }; // BEGIN GLOBAL FUNCTION DEF: sinh .visible .func (.param .f64 %value_out) sinh (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r34; .reg .f64 %r35; .reg .f64 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; mov.f64 %r35,%ar0; .loc 1 89 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),__ieee754_sinh,(%out_arg1); ld.param.f64 %r37,[%value_in]; } mov.f64 %r34,%r37; .loc 1 90 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; .loc 1 91 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),finite,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.ne.u32 %r42,%r41,0; @ %r42 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r35; call (%value_in),finite,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 99 0 mov.u32 %r46,3; st.u32 [%frame],%r46; .loc 1 100 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 101 0 st.u32 [%frame+40],%r41; .loc 1 102 0 st.f64 [%frame+24],%r35; st.f64 [%frame+16],%r35; .loc 1 103 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r49,%r25,0; @ %r49 bra $L3; .loc 1 104 0 setp.gt.f64 %r50,%r35,0d0000000000000000; selp.f64 %r32,0d47efffffe0000000,0dc7efffffe0000000,%r50; st.f64 [%frame+32],%r32; bra $L5; $L3: .loc 1 106 0 setp.gt.f64 %r51,%r35,0d0000000000000000; selp.f64 %r33,0d7ff0000000000000,0dfff0000000000000,%r51; st.f64 [%frame+32],%r33; .loc 1 107 0 setp.ne.u32 %r52,%r25,2; @ %r52 bra $L5; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r53,[%value_in]; } mov.u32 %r54,34; st.u32 [%r53],%r54; bra $L7; $L5: .loc 1 109 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r56,[%value_in]; } setp.ne.u32 %r57,%r56,0; @ %r57 bra $L7; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } mov.u32 %r59,34; st.u32 [%r58],%r59; $L7: .loc 1 112 0 ld.u32 %r60,[%frame+40]; setp.eq.u32 %r61,%r60,0; @ %r61 bra $L8; .loc 1 113 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r62],%r31; $L8: .loc 1 114 0 ld.f64 %r34,[%frame+32]; $L1: .loc 1 118 0 mov.f64 %value,%r34; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-w_sqrt.o/ 0 0 0 644 3910 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sqrt .visible .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_sqrt.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrt .extern .func (.param .f64 %value_out) __ieee754_sqrt (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {115,113,114,116,0 }; // BEGIN GLOBAL FUNCTION DEF: sqrt .visible .func (.param .f64 %value_out) sqrt (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r31; .reg .f64 %r32; .reg .f64 %r33; .reg .f64 %r35; .reg .u32 %r36; .reg .pred %r37; .reg .u32 %r39; .reg .pred %r40; .reg .pred %r41; .reg .u32 %r42; .reg .u64 %r43; .reg .u32 %r44; .reg .pred %r45; .reg .f64 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .pred %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; mov.f64 %r33,%ar0; .loc 1 69 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__ieee754_sqrt,(%out_arg1); ld.param.f64 %r35,[%value_in]; } mov.f64 %r32,%r35; .loc 1 70 0 ld.global.u32 %r36,[__fdlib_version]; setp.eq.u32 %r37,%r36,-1; @ %r37 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r39,[%value_in]; } setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 71 0 setp.lt.f64 %r41,%r33,0d0000000000000000; @ ! %r41 bra $L1; .loc 1 72 0 mov.u32 %r42,1; st.u32 [%frame],%r42; .loc 1 73 0 cvta.const.u64 %r43,$LC0; st.u64 [%frame+8],%r43; .loc 1 74 0 mov.u32 %r44,0; st.u32 [%frame+40],%r44; .loc 1 75 0 st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 76 0 ld.global.u32 %r24,[__fdlib_version]; setp.ne.u32 %r45,%r24,0; @ %r45 bra $L4; .loc 1 77 0 mov.f64 %r46,0d0000000000000000; st.f64 [%frame+32],%r46; bra $L5; $L4: .loc 1 79 0 mov.f64 %r48,0d0000000000000000; div.rn.f64 %r47,%r48,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 80 0 setp.ne.u32 %r49,%r24,2; @ %r49 bra $L5; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r50,[%value_in]; } mov.u32 %r51,33; st.u32 [%r50],%r51; bra $L6; $L5: .loc 1 82 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.ne.u32 %r54,%r53,0; @ %r54 bra $L6; .loc 1 83 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,33; st.u32 [%r55],%r56; $L6: .loc 1 85 0 ld.u32 %r57,[%frame+40]; setp.eq.u32 %r58,%r57,0; @ %r58 bra $L7; .loc 1 86 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r59],%r31; $L7: .loc 1 87 0 ld.f64 %r32,[%frame+32]; $L1: .loc 1 91 0 mov.f64 %value,%r32; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } /1460 0 0 0 644 3717 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tgamma .visible .func (.param .f64 %value_out) tgamma (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/math/w_tgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .extern .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_standard .extern .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: tgamma .visible .func (.param .f64 %value_out) tgamma (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r27; .reg .f64 %r28; .reg .f64 %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .pred %r35; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .f64 %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r52; .reg .f64 %r53; mov.f64 %r28,%ar0; .loc 1 31 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_gamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r31,[%value_in]; } mov.f64 %r27,%r31; .loc 1 32 0 ld.u32 %r32,[%frame]; setp.ge.s32 %r33,%r32,0; @ %r33 bra $L2; neg.f64 %r27,%r27; $L2: .loc 1 36 0 ld.global.u32 %r34,[__fdlib_version]; setp.eq.u32 %r35,%r34,-1; @ %r35 bra $L1; .loc 1 38 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r27; call (%value_in),finite,(%out_arg1); ld.param.u32 %r37,[%value_in]; } setp.ne.u32 %r38,%r37,0; @ %r38 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; call (%value_in),finite,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.eq.u32 %r41,%r40,0; @ %r41 bra $L1; .loc 1 39 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; call (%value_in),floor,(%out_arg1); ld.param.f64 %r43,[%value_in]; } setp.neu.f64 %r44,%r43,%r28; @ %r44 bra $L4; setp.le.f64 %r45,%r28,0d0000000000000000; @ ! %r45 bra $L4; .loc 1 40 0 mov.u32 %r48,41; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r28; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r48; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r49,[%value_in]; } mov.f64 %r27,%r49; bra $L1; $L4: .loc 1 42 0 mov.u32 %r52,40; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r28; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r28; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r52; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r53,[%value_in]; } mov.f64 %r27,%r53; $L1: .loc 1 46 0 mov.f64 %value,%r27; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-wf_acos.o/0 0 0 644 4350 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acosf .visible .func (.param .f32 %value_out) acosf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_acos.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acosf .extern .func (.param .f32 %value_out) __ieee754_acosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,99,111,115,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: acosf .visible .func (.param .f32 %value_out) acosf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r33; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .f32 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .f64 %r64; mov.f32 %r36,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__ieee754_acosf,(%out_arg1); ld.param.f32 %r38,[%value_in]; } mov.f32 %r35,%r38; .loc 1 36 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 37 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } setp.gt.f32 %r46,%r45,0f3f800000; @ ! %r46 bra $L1; .loc 1 39 0 mov.u32 %r47,1; st.u32 [%frame],%r47; .loc 1 40 0 cvta.const.u64 %r48,$LC0; st.u64 [%frame+8],%r48; .loc 1 41 0 mov.u32 %r49,0; st.u32 [%frame+40],%r49; .loc 1 42 0 cvt.f64.f32 %r25,%r36; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 43 0 cvta.const.u64 %r50,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r50; call (%value_in),nan,(%out_arg1); ld.param.f64 %r51,[%value_in]; } st.f64 [%frame+32],%r51; .loc 1 44 0 ld.global.u32 %r52,[__fdlib_version]; setp.ne.u32 %r53,%r52,2; @ %r53 bra $L4; .loc 1 45 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,33; st.u32 [%r54],%r55; bra $L5; $L4: .loc 1 46 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L5; .loc 1 47 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; $L5: .loc 1 49 0 ld.u32 %r61,[%frame+40]; setp.eq.u32 %r62,%r61,0; @ %r62 bra $L6; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r63],%r33; $L6: .loc 1 51 0 ld.f64 %r64,[%frame+32]; cvt.rn.f32.f64 %r35,%r64; $L1: .loc 1 55 0 mov.f32 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1478 0 0 0 644 3835 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: acoshf .visible .func (.param .f32 %value_out) acoshf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_acosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_acoshf .extern .func (.param .f32 %value_out) __ieee754_acoshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {97,99,111,115,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: acoshf .visible .func (.param .f32 %value_out) acoshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .f64 %r47; .reg .f64 %r48; .reg .u32 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r52; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .f64 %r61; mov.f32 %r35,%ar0; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_acoshf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 37 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 38 0 setp.lt.f32 %r43,%r35,0f3f800000; @ ! %r43 bra $L1; .loc 1 40 0 mov.u32 %r44,1; st.u32 [%frame],%r44; .loc 1 41 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 42 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 43 0 cvt.f64.f32 %r24,%r35; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 44 0 mov.f64 %r48,0d0000000000000000; div.rn.f64 %r47,%r48,0d0000000000000000; st.f64 [%frame+32],%r47; .loc 1 45 0 ld.global.u32 %r49,[__fdlib_version]; setp.ne.u32 %r50,%r49,2; @ %r50 bra $L4; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r51,[%value_in]; } mov.u32 %r52,33; st.u32 [%r51],%r52; bra $L5; $L4: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r54,[%value_in]; } setp.ne.u32 %r55,%r54,0; @ %r55 bra $L5; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,33; st.u32 [%r56],%r57; $L5: .loc 1 50 0 ld.u32 %r58,[%frame+40]; setp.eq.u32 %r59,%r58,0; @ %r59 bra $L6; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r60],%r32; $L6: .loc 1 52 0 ld.f64 %r61,[%frame+32]; cvt.rn.f32.f64 %r34,%r61; $L1: .loc 1 56 0 mov.f32 %value,%r34; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_asin.o/0 0 0 644 4351 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: asinf .visible .func (.param .f32 %value_out) asinf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_asin.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_asinf .extern .func (.param .f32 %value_out) __ieee754_asinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {97,115,105,110,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: asinf .visible .func (.param .f32 %value_out) asinf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r33; .reg .f32 %r35; .reg .f32 %r36; .reg .f32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r42; .reg .pred %r43; .reg .f32 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u64 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .f64 %r64; mov.f32 %r36,%ar0; .loc 1 37 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__ieee754_asinf,(%out_arg1); ld.param.f32 %r38,[%value_in]; } mov.f32 %r35,%r38; .loc 1 38 0 ld.global.u32 %r39,[__fdlib_version]; setp.eq.u32 %r40,%r39,-1; @ %r40 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r42,[%value_in]; } setp.eq.u32 %r43,%r42,0; @ %r43 bra $L1; .loc 1 39 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r36; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } setp.gt.f32 %r46,%r45,0f3f800000; @ ! %r46 bra $L1; .loc 1 41 0 mov.u32 %r47,1; st.u32 [%frame],%r47; .loc 1 42 0 cvta.const.u64 %r48,$LC0; st.u64 [%frame+8],%r48; .loc 1 43 0 mov.u32 %r49,0; st.u32 [%frame+40],%r49; .loc 1 44 0 cvt.f64.f32 %r25,%r36; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 45 0 cvta.const.u64 %r50,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r50; call (%value_in),nan,(%out_arg1); ld.param.f64 %r51,[%value_in]; } st.f64 [%frame+32],%r51; .loc 1 46 0 ld.global.u32 %r52,[__fdlib_version]; setp.ne.u32 %r53,%r52,2; @ %r53 bra $L4; .loc 1 47 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r54,[%value_in]; } mov.u32 %r55,33; st.u32 [%r54],%r55; bra $L5; $L4: .loc 1 48 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r57,[%value_in]; } setp.ne.u32 %r58,%r57,0; @ %r58 bra $L5; .loc 1 49 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; $L5: .loc 1 51 0 ld.u32 %r61,[%frame+40]; setp.eq.u32 %r62,%r61,0; @ %r62 bra $L6; .loc 1 52 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r63],%r33; $L6: .loc 1 53 0 ld.f64 %r64,[%frame+32]; cvt.rn.f32.f64 %r35,%r64; $L1: .loc 1 57 0 mov.f32 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1496 0 0 0 644 1043 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atan2f .visible .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_atan2.c" // BEGIN GLOBAL FUNCTION DECL: __ieee754_atan2f .extern .func (.param .f32 %value_out) __ieee754_atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atan2f .visible .func (.param .f32 %value_out) atan2f (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r27; mov.f32 %r23,%ar0; mov.f32 %r24,%ar1; .loc 1 31 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r23; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; call (%value_in),__ieee754_atan2f,(%out_arg1,%out_arg2); ld.param.f32 %r27,[%value_in]; } .loc 1 32 0 mov.f32 %value,%r27; st.param.f32 [%value_out],%value; ret; } /1514 0 0 0 644 5238 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: atanhf .visible .func (.param .f32 %value_out) atanhf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_atanh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_atanhf .extern .func (.param .f32 %value_out) __ieee754_atanhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {97,116,97,110,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: atanhf .visible .func (.param .f32 %value_out) atanhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .f64 %r37; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .f32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .pred %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .f64 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .f64 %r80; mov.f32 %r40,%ar0; .loc 1 34 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__ieee754_atanhf,(%out_arg1); ld.param.f32 %r42,[%value_in]; } mov.f32 %r39,%r42; .loc 1 35 0 ld.global.u32 %r43,[__fdlib_version]; setp.eq.u32 %r44,%r43,-1; @ %r44 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.eq.u32 %r47,%r46,0; @ %r47 bra $L1; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r49,[%value_in]; } .loc 1 37 0 setp.ge.f32 %r50,%r49,0f3f800000; @ ! %r50 bra $L1; cvt.f64.f32 %r37,%r40; ld.global.u32 %r38,[__fdlib_version]; .loc 1 38 0 setp.gt.f32 %r51,%r49,0f3f800000; @ ! %r51 bra $L23; .loc 1 40 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 41 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 42 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 43 0 st.f64 [%frame+24],%r37; st.f64 [%frame+16],%r37; .loc 1 44 0 mov.f64 %r56,0d0000000000000000; div.rn.f64 %r55,%r56,0d0000000000000000; st.f64 [%frame+32],%r55; .loc 1 45 0 setp.ne.u32 %r57,%r38,2; @ %r57 bra $L6; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } mov.u32 %r59,33; st.u32 [%r58],%r59; bra $L7; $L6: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r61,[%value_in]; } setp.eq.u32 %r62,%r61,0; @ ! %r62 bra $L7; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L7; $L23: .loc 1 52 0 mov.u32 %r65,2; st.u32 [%frame],%r65; .loc 1 53 0 cvta.const.u64 %r66,$LC0; st.u64 [%frame+8],%r66; .loc 1 54 0 mov.u32 %r67,0; st.u32 [%frame+40],%r67; .loc 1 55 0 st.f64 [%frame+24],%r37; st.f64 [%frame+16],%r37; .loc 1 56 0 div.rn.f64 %r68,%r37,0d0000000000000000; st.f64 [%frame+32],%r68; .loc 1 57 0 setp.ne.u32 %r69,%r38,2; @ %r69 bra $L9; .loc 1 58 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; bra $L7; $L9: .loc 1 59 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r73,[%value_in]; } setp.ne.u32 %r74,%r73,0; @ %r74 bra $L7; .loc 1 60 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r75,[%value_in]; } mov.u32 %r76,33; st.u32 [%r75],%r76; $L7: .loc 1 63 0 ld.u32 %r77,[%frame+40]; setp.eq.u32 %r78,%r77,0; @ %r78 bra $L11; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r79],%r34; $L11: .loc 1 65 0 ld.f64 %r80,[%frame+32]; cvt.rn.f32.f64 %r39,%r80; $L1: .loc 1 69 0 mov.f32 %value,%r39; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_cosh.o/0 0 0 644 4206 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: coshf .visible .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_cosh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_coshf .extern .func (.param .f32 %value_out) __ieee754_coshf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {99,111,115,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: coshf .visible .func (.param .f32 %value_out) coshf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r26; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .f64 %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .pred %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .f64 %r63; mov.f32 %r35,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_coshf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 36 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 37 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.gt.f32 %r45,%r44,0f42b2d4fc; @ ! %r45 bra $L1; .loc 1 45 0 mov.u32 %r46,3; st.u32 [%frame],%r46; .loc 1 46 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 47 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 48 0 cvt.f64.f32 %r25,%r35; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 49 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r49,%r26,0; @ %r49 bra $L4; .loc 1 50 0 mov.f64 %r50,0d47efffffe0000000; st.f64 [%frame+32],%r50; bra $L5; $L4: .loc 1 52 0 mov.f64 %r51,0d7ff0000000000000; st.f64 [%frame+32],%r51; .loc 1 53 0 setp.ne.u32 %r52,%r26,2; @ %r52 bra $L5; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r53,[%value_in]; } mov.u32 %r54,34; st.u32 [%r53],%r54; bra $L6; $L5: .loc 1 55 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r56,[%value_in]; } setp.ne.u32 %r57,%r56,0; @ %r57 bra $L6; .loc 1 56 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r58,[%value_in]; } mov.u32 %r59,34; st.u32 [%r58],%r59; $L6: .loc 1 58 0 ld.u32 %r60,[%frame+40]; setp.eq.u32 %r61,%r60,0; @ %r61 bra $L7; .loc 1 59 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r62],%r32; $L7: .loc 1 60 0 ld.f64 %r63,[%frame+32]; cvt.rn.f32.f64 %r34,%r63; $L1: .loc 1 64 0 mov.f32 %value,%r34; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_drem.o/0 0 0 644 1020 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: dremf .visible .func (.param .f32 %value_out) dremf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_drem.c" // BEGIN GLOBAL FUNCTION DECL: remainderf .extern .func (.param .f32 %value_out) remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: dremf .visible .func (.param .f32 %value_out) dremf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r27; mov.f32 %r23,%ar0; mov.f32 %r24,%ar1; .loc 1 18 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r23; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r24; call (%value_in),remainderf,(%out_arg1,%out_arg2); ld.param.f32 %r27,[%value_in]; } .loc 1 19 0 mov.f32 %value,%r27; st.param.f32 [%value_out],%value; ret; } lib_a-wf_exp.o/ 0 0 0 644 5503 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: expf .visible .func (.param .f32 %value_out) expf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_exp.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_expf .extern .func (.param .f32 %value_out) __ieee754_expf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {101,120,112,102,0 }; // BEGIN GLOBAL FUNCTION DEF: expf .visible .func (.param .f32 %value_out) expf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r33; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .f64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r43,%ar0; .loc 1 43 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__ieee754_expf,(%out_arg1); ld.param.f32 %r45,[%value_in]; } mov.f32 %r42,%r45; .loc 1 44 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L1; .loc 1 45 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L1; .loc 1 46 0 setp.gt.f32 %r51,%r43,0f42b17180; @ ! %r51 bra $L27; .loc 1 54 0 mov.u32 %r52,3; st.u32 [%frame],%r52; .loc 1 55 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 56 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 57 0 cvt.f64.f32 %r24,%r43; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 58 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r55,%r25,0; @ %r55 bra $L5; .loc 1 59 0 mov.f64 %r56,0d47efffffe0000000; st.f64 [%frame+32],%r56; bra $L6; $L5: .loc 1 61 0 mov.f64 %r57,0d7ff0000000000000; st.f64 [%frame+32],%r57; .loc 1 62 0 setp.ne.u32 %r58,%r25,2; @ %r58 bra $L6; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,34; st.u32 [%r59],%r60; bra $L7; $L6: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L7; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,34; st.u32 [%r64],%r65; $L7: .loc 1 67 0 ld.u32 %r66,[%frame+40]; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L8; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r68],%r31; $L8: .loc 1 69 0 ld.f64 %r69,[%frame+32]; cvt.rn.f32.f64 %r42,%r69; bra $L1; $L27: .loc 1 70 0 setp.lt.f32 %r70,%r43,0fc2cff1b5; @ ! %r70 bra $L1; .loc 1 72 0 mov.u32 %r71,4; st.u32 [%frame],%r71; .loc 1 73 0 cvta.const.u64 %r72,$LC0; st.u64 [%frame+8],%r72; .loc 1 74 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 75 0 cvt.f64.f32 %r33,%r43; st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 76 0 mov.f64 %r74,0d0000000000000000; st.f64 [%frame+32],%r74; .loc 1 77 0 ld.global.u32 %r75,[__fdlib_version]; setp.ne.u32 %r76,%r75,2; @ %r76 bra $L10; .loc 1 78 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L11; $L10: .loc 1 79 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L11; .loc 1 80 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L11: .loc 1 82 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L12; .loc 1 83 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r40,[%frame+40]; st.u32 [%r86],%r40; $L12: .loc 1 84 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r42,%r87; $L1: .loc 1 89 0 mov.f32 %value,%r42; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_exp2.o/0 0 0 644 921 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exp2f .visible .func (.param .f32 %value_out) exp2f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_exp2.c" // BEGIN GLOBAL FUNCTION DECL: powf .extern .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: exp2f .visible .func (.param .f32 %value_out) exp2f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %r23; .reg .f32 %r24; .reg .f32 %r26; mov.f32 %r23,%ar0; .loc 1 31 0 mov.f32 %r24,0f40000000; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r23; call (%value_in),powf,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 32 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } lib_a-wf_fmod.o/0 0 0 644 4727 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: fmodf .visible .func (.param .f32 %value_out) fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_fmod.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_fmodf .extern .func (.param .f32 %value_out) __ieee754_fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {102,109,111,100,102,0 }; // BEGIN GLOBAL FUNCTION DEF: fmodf .visible .func (.param .f32 %value_out) fmodf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r27; .reg .u32 %r34; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .f32 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u16 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u32 %r61; .reg .u16 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .f64 %r67; .reg .pred %r68; .reg .f64 %r69; .reg .f64 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; .reg .f64 %r82; mov.f32 %r40,%ar0; mov.f32 %r41,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r41; call (%value_in),__ieee754_fmodf,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } mov.f32 %r39,%r44; .loc 1 36 0 ld.global.u32 %r45,[__fdlib_version]; setp.eq.u32 %r46,%r45,-1; @ %r46 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r51,[%value_in]; } set.u32.ne.u32 %r53,%r51,0; neg.s32 %r54,%r53; .loc 1 37 0 set.u32.eq.f32 %r56,%r41,0f00000000; neg.s32 %r57,%r56; cvt.u16.u32 %r59,%r54; cvt.u16.u32 %r60,%r57; and.b16 %r58,%r59,%r60; cvt.u32.u16 %r61,%r58; cvt.u16.u8 %r62,%r61; setp.eq.u16 %r63,%r62,0; @ %r63 bra $L1; .loc 1 39 0 mov.u32 %r64,1; st.u32 [%frame],%r64; .loc 1 40 0 cvta.const.u64 %r65,$LC0; st.u64 [%frame+8],%r65; .loc 1 41 0 mov.u32 %r66,0; st.u32 [%frame+40],%r66; .loc 1 42 0 cvt.f64.f32 %r25,%r40; st.f64 [%frame+16],%r25; .loc 1 43 0 cvt.f64.f32 %r67,%r41; st.f64 [%frame+24],%r67; .loc 1 44 0 ld.global.u32 %r27,[__fdlib_version]; setp.ne.u32 %r68,%r27,0; @ %r68 bra $L3; .loc 1 45 0 st.f64 [%frame+32],%r25; bra $L4; $L3: .loc 1 47 0 mov.f64 %r70,0d0000000000000000; div.rn.f64 %r69,%r70,0d0000000000000000; st.f64 [%frame+32],%r69; .loc 1 48 0 setp.ne.u32 %r71,%r27,2; @ %r71 bra $L4; .loc 1 49 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,33; st.u32 [%r72],%r73; bra $L5; $L4: .loc 1 50 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L5; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,33; st.u32 [%r77],%r78; $L5: .loc 1 53 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L6; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r81],%r34; $L6: .loc 1 55 0 ld.f64 %r82,[%frame+32]; cvt.rn.f32.f64 %r39,%r82; $L1: .loc 1 59 0 mov.f32 %value,%r39; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1532 0 0 0 644 6004 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gammaf .visible .func (.param .f32 %value_out) gammaf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .extern .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: gammaf .visible .func (.param .f32 %value_out) gammaf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r36; .reg .u32 %r38; .reg .f64 %r39; .reg .f32 %r40; .reg .f32 %r41; .reg .u64 %r44; .reg .u64 %r45; .reg .f32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r50; .reg .pred %r51; .reg .u32 %r53; .reg .pred %r54; .reg .f32 %r56; .reg .pred %r57; .reg .pred %r58; .reg .u32 %r59; .reg .u64 %r60; .reg .pred %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .f64 %r77; .reg .f64 %r78; .reg .pred %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .pred %r88; .reg .u64 %r89; .reg .f64 %r90; mov.f32 %r41,%ar0; .loc 1 33 0 ld.global.u64 %r45,[_impure_ptr]; add.u64 %r44,%r45,224; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r44; call (%value_in),__ieee754_gammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r46,[%value_in]; } mov.f32 %r40,%r46; .loc 1 34 0 ld.global.u32 %r47,[__fdlib_version]; setp.eq.u32 %r48,%r47,-1; @ %r48 bra $L1; .loc 1 35 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r50,[%value_in]; } setp.ne.u32 %r51,%r50,0; @ %r51 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.eq.u32 %r54,%r53,0; @ %r54 bra $L1; .loc 1 42 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r56,[%value_in]; } setp.neu.f32 %r57,%r56,%r41; @ %r57 bra $L3; cvt.f64.f32 %r39,%r41; ld.global.u32 %r38,[__fdlib_version]; setp.le.f32 %r58,%r41,0f00000000; @ ! %r58 bra $L4; .loc 1 44 0 mov.u32 %r59,2; st.u32 [%frame],%r59; .loc 1 45 0 cvta.const.u64 %r60,$LC0; st.u64 [%frame+8],%r60; .loc 1 46 0 st.u32 [%frame+40],%r50; .loc 1 47 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 48 0 setp.ne.u32 %r62,%r38,0; @ %r62 bra $L6; .loc 1 49 0 mov.f64 %r63,0d47efffffe0000000; st.f64 [%frame+32],%r63; bra $L7; $L6: .loc 1 51 0 mov.f64 %r64,0d7ff0000000000000; st.f64 [%frame+32],%r64; .loc 1 52 0 setp.ne.u32 %r65,%r38,2; @ %r65 bra $L7; .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } mov.u32 %r67,33; st.u32 [%r66],%r67; bra $L8; $L7: .loc 1 54 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r69,[%value_in]; } setp.eq.u32 %r70,%r69,0; @ ! %r70 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } mov.u32 %r72,33; st.u32 [%r71],%r72; bra $L8; $L3: cvt.f64.f32 %r39,%r41; ld.global.u32 %r38,[__fdlib_version]; $L4: .loc 1 59 0 mov.u32 %r73,3; st.u32 [%frame],%r73; .loc 1 60 0 cvta.const.u64 %r74,$LC0; st.u64 [%frame+8],%r74; .loc 1 61 0 mov.u32 %r75,0; st.u32 [%frame+40],%r75; .loc 1 62 0 st.f64 [%frame+24],%r39; st.f64 [%frame+16],%r39; .loc 1 63 0 setp.ne.u32 %r76,%r38,0; @ %r76 bra $L10; .loc 1 64 0 mov.f64 %r77,0d47efffffe0000000; st.f64 [%frame+32],%r77; bra $L11; $L10: .loc 1 66 0 mov.f64 %r78,0d7ff0000000000000; st.f64 [%frame+32],%r78; .loc 1 67 0 setp.ne.u32 %r79,%r38,2; @ %r79 bra $L11; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r80,[%value_in]; } mov.u32 %r81,34; st.u32 [%r80],%r81; bra $L8; $L11: .loc 1 69 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r83,[%value_in]; } setp.ne.u32 %r84,%r83,0; @ %r84 bra $L8; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r85,[%value_in]; } mov.u32 %r86,34; st.u32 [%r85],%r86; $L8: .loc 1 73 0 ld.u32 %r87,[%frame+40]; setp.eq.u32 %r88,%r87,0; @ %r88 bra $L13; .loc 1 74 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r89,[%value_in]; } ld.u32 %r36,[%frame+40]; st.u32 [%r89],%r36; $L13: .loc 1 75 0 ld.f64 %r90,[%frame+32]; cvt.rn.f32.f64 %r40,%r90; $L1: .loc 1 79 0 mov.f32 %value,%r40; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1550 0 0 0 644 4537 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: hypotf .visible .func (.param .f32 %value_out) hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_hypot.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_hypotf .extern .func (.param .f32 %value_out) __ieee754_hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {104,121,112,111,116,102,0 }; // BEGIN GLOBAL FUNCTION DEF: hypotf .visible .func (.param .f32 %value_out) hypotf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r28; .reg .u32 %r34; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r65; .reg .pred %r66; .reg .u64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u64 %r71; .reg .f64 %r72; mov.f32 %r37,%ar0; mov.f32 %r38,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r38; call (%value_in),__ieee754_hypotf,(%out_arg1,%out_arg2); ld.param.f32 %r41,[%value_in]; } mov.f32 %r36,%r41; .loc 1 36 0 ld.global.u32 %r42,[__fdlib_version]; setp.eq.u32 %r43,%r42,-1; @ %r43 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r41; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r45,[%value_in]; } setp.ne.u32 %r46,%r45,0; @ %r46 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.eq.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.eq.u32 %r52,%r51,0; @ %r52 bra $L1; .loc 1 45 0 mov.u32 %r53,3; st.u32 [%frame],%r53; .loc 1 46 0 cvta.const.u64 %r54,$LC0; st.u64 [%frame+8],%r54; .loc 1 47 0 st.u32 [%frame+40],%r45; .loc 1 48 0 cvt.f64.f32 %r56,%r37; st.f64 [%frame+16],%r56; .loc 1 49 0 cvt.f64.f32 %r57,%r38; st.f64 [%frame+24],%r57; .loc 1 50 0 ld.global.u32 %r28,[__fdlib_version]; setp.ne.u32 %r58,%r28,0; @ %r58 bra $L3; .loc 1 51 0 mov.f64 %r59,0d47efffffe0000000; st.f64 [%frame+32],%r59; bra $L4; $L3: .loc 1 53 0 mov.f64 %r60,0d7ff0000000000000; st.f64 [%frame+32],%r60; .loc 1 54 0 setp.ne.u32 %r61,%r28,2; @ %r61 bra $L4; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } mov.u32 %r63,34; st.u32 [%r62],%r63; bra $L5; $L4: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r65,[%value_in]; } setp.ne.u32 %r66,%r65,0; @ %r66 bra $L5; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r67,[%value_in]; } mov.u32 %r68,34; st.u32 [%r67],%r68; $L5: .loc 1 59 0 ld.u32 %r69,[%frame+40]; setp.eq.u32 %r70,%r69,0; @ %r70 bra $L6; .loc 1 60 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r71,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r71],%r34; $L6: .loc 1 61 0 ld.f64 %r72,[%frame+32]; cvt.rn.f32.f64 %r36,%r72; $L1: .loc 1 65 0 mov.f32 %value,%r36; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_j0.o/ 0 0 0 644 8911 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j0f .visible .func (.param .f32 %value_out) j0f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_j0.c" // BEGIN GLOBAL FUNCTION DECL: y0f .visible .func (.param .f32 %value_out) y0f (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j0f .extern .func (.param .f32 %value_out) __ieee754_j0f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y0f .extern .func (.param .f32 %value_out) __ieee754_y0f (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {106,48,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {121,48,102,0 }; // BEGIN GLOBAL FUNCTION DEF: j0f .visible .func (.param .f32 %value_out) j0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .f64 %r62; mov.f32 %r35,%ar0; .loc 1 34 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_j0f,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 35 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.gt.f32 %r45,%r44,0f5a490fdb; @ ! %r45 bra $L1; .loc 1 38 0 mov.u32 %r46,5; st.u32 [%frame],%r46; .loc 1 39 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 40 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 41 0 cvt.f64.f32 %r25,%r35; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 42 0 mov.f64 %r49,0d0000000000000000; st.f64 [%frame+32],%r49; .loc 1 43 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 44 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,34; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 45 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; $L5: .loc 1 48 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 49 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 50 0 ld.f64 %r62,[%frame+32]; cvt.rn.f32.f64 %r34,%r62; $L1: .loc 1 54 0 mov.f32 %value,%r34; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y0f .visible .func (.param .f32 %value_out) y0f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r33; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .f64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r43,%ar0; .loc 1 68 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__ieee754_y0f,(%out_arg1); ld.param.f32 %r45,[%value_in]; } mov.f32 %r42,%r45; .loc 1 69 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L17; .loc 1 70 0 setp.le.f32 %r51,%r43,0f00000000; @ ! %r51 bra $L43; .loc 1 78 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 79 0 cvta.const.u64 %r53,$LC1; st.u64 [%frame+8],%r53; .loc 1 80 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 81 0 cvt.f64.f32 %r24,%r43; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 82 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r55,%r25,0; @ %r55 bra $L21; .loc 1 83 0 mov.f64 %r56,0dc7efffffe0000000; st.f64 [%frame+32],%r56; bra $L22; $L21: .loc 1 85 0 mov.f64 %r57,0dfff0000000000000; st.f64 [%frame+32],%r57; .loc 1 86 0 setp.ne.u32 %r58,%r25,2; @ %r58 bra $L22; .loc 1 87 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; bra $L23; $L22: .loc 1 88 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L23; .loc 1 89 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,33; st.u32 [%r64],%r65; $L23: .loc 1 91 0 ld.u32 %r66,[%frame+40]; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L24; .loc 1 92 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r68],%r31; $L24: .loc 1 93 0 ld.f64 %r69,[%frame+32]; cvt.rn.f32.f64 %r42,%r69; bra $L17; $L43: .loc 1 95 0 setp.gt.f32 %r70,%r43,0f5a490fdb; @ ! %r70 bra $L17; .loc 1 97 0 mov.u32 %r71,5; st.u32 [%frame],%r71; .loc 1 98 0 cvta.const.u64 %r72,$LC1; st.u64 [%frame+8],%r72; .loc 1 99 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 100 0 cvt.f64.f32 %r33,%r43; st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 101 0 mov.f64 %r74,0d0000000000000000; st.f64 [%frame+32],%r74; .loc 1 102 0 ld.global.u32 %r75,[__fdlib_version]; setp.ne.u32 %r76,%r75,2; @ %r76 bra $L26; .loc 1 103 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L27; $L26: .loc 1 104 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L27; .loc 1 105 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L27: .loc 1 107 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L28; .loc 1 108 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r40,[%frame+40]; st.u32 [%r86],%r40; $L28: .loc 1 109 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r42,%r87; $L17: .loc 1 113 0 mov.f32 %value,%r42; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_j1.o/ 0 0 0 644 8913 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: j1f .visible .func (.param .f32 %value_out) j1f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_j1.c" // BEGIN GLOBAL FUNCTION DECL: y1f .visible .func (.param .f32 %value_out) y1f (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_j1f .extern .func (.param .f32 %value_out) __ieee754_j1f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_y1f .extern .func (.param .f32 %value_out) __ieee754_y1f (.param .f32 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {106,49,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {121,49,102,0 }; // BEGIN GLOBAL FUNCTION DEF: j1f .visible .func (.param .f32 %value_out) j1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .f32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .f64 %r62; mov.f32 %r35,%ar0; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_j1f,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 37 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 38 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r44,[%value_in]; } setp.gt.f32 %r45,%r44,0f5a490fdb; @ ! %r45 bra $L1; .loc 1 40 0 mov.u32 %r46,5; st.u32 [%frame],%r46; .loc 1 41 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 42 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 43 0 cvt.f64.f32 %r25,%r35; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 44 0 mov.f64 %r49,0d0000000000000000; st.f64 [%frame+32],%r49; .loc 1 45 0 ld.global.u32 %r50,[__fdlib_version]; setp.ne.u32 %r51,%r50,2; @ %r51 bra $L4; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,34; st.u32 [%r52],%r53; bra $L5; $L4: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L5; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; $L5: .loc 1 50 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L6; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L6: .loc 1 52 0 ld.f64 %r62,[%frame+32]; cvt.rn.f32.f64 %r34,%r62; $L1: .loc 1 56 0 mov.f32 %value,%r34; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: y1f .visible .func (.param .f32 %value_out) y1f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r31; .reg .f64 %r33; .reg .u32 %r40; .reg .f32 %r42; .reg .f32 %r43; .reg .f32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .pred %r51; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f64 %r56; .reg .f64 %r57; .reg .pred %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .f64 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .f64 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r43,%ar0; .loc 1 70 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__ieee754_y1f,(%out_arg1); ld.param.f32 %r45,[%value_in]; } mov.f32 %r42,%r45; .loc 1 71 0 ld.global.u32 %r46,[__fdlib_version]; setp.eq.u32 %r47,%r46,-1; @ %r47 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r43; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L17; .loc 1 72 0 setp.le.f32 %r51,%r43,0f00000000; @ ! %r51 bra $L43; .loc 1 80 0 mov.u32 %r52,1; st.u32 [%frame],%r52; .loc 1 81 0 cvta.const.u64 %r53,$LC1; st.u64 [%frame+8],%r53; .loc 1 82 0 mov.u32 %r54,0; st.u32 [%frame+40],%r54; .loc 1 83 0 cvt.f64.f32 %r24,%r43; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 84 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r55,%r25,0; @ %r55 bra $L21; .loc 1 85 0 mov.f64 %r56,0dc7efffffe0000000; st.f64 [%frame+32],%r56; bra $L22; $L21: .loc 1 87 0 mov.f64 %r57,0dfff0000000000000; st.f64 [%frame+32],%r57; .loc 1 88 0 setp.ne.u32 %r58,%r25,2; @ %r58 bra $L22; .loc 1 89 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r59,[%value_in]; } mov.u32 %r60,33; st.u32 [%r59],%r60; bra $L23; $L22: .loc 1 90 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L23; .loc 1 91 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,33; st.u32 [%r64],%r65; $L23: .loc 1 93 0 ld.u32 %r66,[%frame+40]; setp.eq.u32 %r67,%r66,0; @ %r67 bra $L24; .loc 1 94 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } ld.u32 %r31,[%frame+40]; st.u32 [%r68],%r31; $L24: .loc 1 95 0 ld.f64 %r69,[%frame+32]; cvt.rn.f32.f64 %r42,%r69; bra $L17; $L43: .loc 1 97 0 setp.gt.f32 %r70,%r43,0f5a490fdb; @ ! %r70 bra $L17; .loc 1 99 0 mov.u32 %r71,5; st.u32 [%frame],%r71; .loc 1 100 0 cvta.const.u64 %r72,$LC1; st.u64 [%frame+8],%r72; .loc 1 101 0 mov.u32 %r73,0; st.u32 [%frame+40],%r73; .loc 1 102 0 cvt.f64.f32 %r33,%r43; st.f64 [%frame+24],%r33; st.f64 [%frame+16],%r33; .loc 1 103 0 mov.f64 %r74,0d0000000000000000; st.f64 [%frame+32],%r74; .loc 1 104 0 ld.global.u32 %r75,[__fdlib_version]; setp.ne.u32 %r76,%r75,2; @ %r76 bra $L26; .loc 1 105 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L27; $L26: .loc 1 106 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L27; .loc 1 107 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L27: .loc 1 109 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L28; .loc 1 110 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r40,[%frame+40]; st.u32 [%r86],%r40; $L28: .loc 1 111 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r42,%r87; $L17: .loc 1 115 0 mov.f32 %value,%r42; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_jn.o/ 0 0 0 644 9490 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: jnf .visible .func (.param .f32 %value_out) jnf (.param .u32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_jn.c" // BEGIN GLOBAL FUNCTION DECL: ynf .visible .func (.param .f32 %value_out) ynf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_jnf .extern .func (.param .f32 %value_out) __ieee754_jnf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: fabsf .extern .func (.param .f32 %value_out) fabsf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __ieee754_ynf .extern .func (.param .f32 %value_out) __ieee754_ynf (.param .u32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {106,110,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {121,110,102,0 }; // BEGIN GLOBAL FUNCTION DEF: jnf .visible .func (.param .f32 %value_out) jnf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r33; .reg .f32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .f32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .f64 %r52; .reg .f64 %r53; .reg .f64 %r54; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .f64 %r67; mov.u32 %r36,%ar0; mov.f32 %r37,%ar1; .loc 1 32 0 { .param .f32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r36; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r37; call (%value_in),__ieee754_jnf,(%out_arg1,%out_arg2); ld.param.f32 %r40,[%value_in]; } mov.f32 %r35,%r40; .loc 1 33 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 34 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),fabsf,(%out_arg1); ld.param.f32 %r47,[%value_in]; } setp.gt.f32 %r48,%r47,0f5a490fdb; @ ! %r48 bra $L1; .loc 1 36 0 mov.u32 %r49,5; st.u32 [%frame],%r49; .loc 1 37 0 cvta.const.u64 %r50,$LC0; st.u64 [%frame+8],%r50; .loc 1 38 0 mov.u32 %r51,0; st.u32 [%frame+40],%r51; .loc 1 39 0 cvt.rn.f64.s32 %r52,%r36; st.f64 [%frame+16],%r52; .loc 1 40 0 cvt.f64.f32 %r53,%r37; st.f64 [%frame+24],%r53; .loc 1 41 0 mov.f64 %r54,0d0000000000000000; st.f64 [%frame+32],%r54; .loc 1 42 0 ld.global.u32 %r55,[__fdlib_version]; setp.ne.u32 %r56,%r55,2; @ %r56 bra $L4; .loc 1 43 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,34; st.u32 [%r57],%r58; bra $L5; $L4: .loc 1 44 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r60,[%value_in]; } setp.ne.u32 %r61,%r60,0; @ %r61 bra $L5; .loc 1 45 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r62,[%value_in]; } mov.u32 %r63,34; st.u32 [%r62],%r63; $L5: .loc 1 47 0 ld.u32 %r64,[%frame+40]; setp.eq.u32 %r65,%r64,0; @ %r65 bra $L6; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r66,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r66],%r33; $L6: .loc 1 49 0 ld.f64 %r67,[%frame+32]; cvt.rn.f32.f64 %r35,%r67; $L1: .loc 1 53 0 mov.f32 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ynf .visible .func (.param .f32 %value_out) ynf (.param .u32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r26; .reg .u32 %r32; .reg .u32 %r42; .reg .f32 %r44; .reg .u32 %r45; .reg .f32 %r46; .reg .f32 %r49; .reg .u32 %r50; .reg .pred %r51; .reg .u32 %r53; .reg .pred %r54; .reg .pred %r55; .reg .u32 %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .f64 %r59; .reg .f64 %r60; .reg .pred %r61; .reg .f64 %r62; .reg .f64 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .f64 %r75; .reg .pred %r76; .reg .u32 %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .f64 %r80; .reg .f64 %r81; .reg .f64 %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u32 %r88; .reg .pred %r89; .reg .u64 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .pred %r93; .reg .u64 %r94; .reg .f64 %r95; mov.u32 %r45,%ar0; mov.f32 %r46,%ar1; .loc 1 67 0 { .param .f32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r45; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r46; call (%value_in),__ieee754_ynf,(%out_arg1,%out_arg2); ld.param.f32 %r49,[%value_in]; } mov.f32 %r44,%r49; .loc 1 68 0 ld.global.u32 %r50,[__fdlib_version]; setp.eq.u32 %r51,%r50,-1; @ %r51 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r46; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r53,[%value_in]; } setp.eq.u32 %r54,%r53,0; @ %r54 bra $L17; .loc 1 69 0 setp.le.f32 %r55,%r46,0f00000000; @ ! %r55 bra $L43; .loc 1 77 0 mov.u32 %r56,1; st.u32 [%frame],%r56; .loc 1 78 0 cvta.const.u64 %r57,$LC1; st.u64 [%frame+8],%r57; .loc 1 79 0 mov.u32 %r58,0; st.u32 [%frame+40],%r58; .loc 1 80 0 cvt.rn.f64.s32 %r59,%r45; st.f64 [%frame+16],%r59; .loc 1 81 0 cvt.f64.f32 %r60,%r46; st.f64 [%frame+24],%r60; .loc 1 82 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r61,%r26,0; @ %r61 bra $L21; .loc 1 83 0 mov.f64 %r62,0dc7efffffe0000000; st.f64 [%frame+32],%r62; bra $L22; $L21: .loc 1 85 0 mov.f64 %r63,0dfff0000000000000; st.f64 [%frame+32],%r63; .loc 1 86 0 setp.ne.u32 %r64,%r26,2; @ %r64 bra $L22; .loc 1 87 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L23; $L22: .loc 1 88 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.ne.u32 %r69,%r68,0; @ %r69 bra $L23; .loc 1 89 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; $L23: .loc 1 91 0 ld.u32 %r72,[%frame+40]; setp.eq.u32 %r73,%r72,0; @ %r73 bra $L24; .loc 1 92 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r74],%r32; $L24: .loc 1 93 0 ld.f64 %r75,[%frame+32]; cvt.rn.f32.f64 %r44,%r75; bra $L17; $L43: .loc 1 95 0 setp.gt.f32 %r76,%r46,0f5a490fdb; @ ! %r76 bra $L17; .loc 1 97 0 mov.u32 %r77,5; st.u32 [%frame],%r77; .loc 1 98 0 cvta.const.u64 %r78,$LC1; st.u64 [%frame+8],%r78; .loc 1 99 0 mov.u32 %r79,0; st.u32 [%frame+40],%r79; .loc 1 100 0 cvt.rn.f64.s32 %r80,%r45; st.f64 [%frame+16],%r80; .loc 1 101 0 cvt.f64.f32 %r81,%r46; st.f64 [%frame+24],%r81; .loc 1 102 0 mov.f64 %r82,0d0000000000000000; st.f64 [%frame+32],%r82; .loc 1 103 0 ld.global.u32 %r83,[__fdlib_version]; setp.ne.u32 %r84,%r83,2; @ %r84 bra $L26; .loc 1 104 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r85,[%value_in]; } mov.u32 %r86,34; st.u32 [%r85],%r86; bra $L27; $L26: .loc 1 105 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r88,[%value_in]; } setp.ne.u32 %r89,%r88,0; @ %r89 bra $L27; .loc 1 106 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r90,[%value_in]; } mov.u32 %r91,34; st.u32 [%r90],%r91; $L27: .loc 1 108 0 ld.u32 %r92,[%frame+40]; setp.eq.u32 %r93,%r92,0; @ %r93 bra $L28; .loc 1 109 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r94,[%value_in]; } ld.u32 %r42,[%frame+40]; st.u32 [%r94],%r42; $L28: .loc 1 110 0 ld.f64 %r95,[%frame+32]; cvt.rn.f32.f64 %r44,%r95; $L17: .loc 1 114 0 mov.f32 %value,%r44; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1568 0 0 0 644 5584 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgammaf .visible .func (.param .f32 %value_out) lgammaf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .extern .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {108,103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: lgammaf .visible .func (.param .f32 %value_out) lgammaf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r27; .reg .u32 %r38; .reg .u32 %r40; .reg .f32 %r41; .reg .f32 %r42; .reg .u64 %r45; .reg .u64 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .f64 %r60; .reg .f64 %r61; .reg .f32 %r63; .reg .pred %r64; .reg .pred %r65; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .f64 %r87; mov.f32 %r42,%ar0; .loc 1 33 0 ld.global.u64 %r46,[_impure_ptr]; add.u64 %r45,%r46,224; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r45; call (%value_in),__ieee754_lgammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r47,[%value_in]; } mov.f32 %r41,%r47; .loc 1 34 0 ld.global.u32 %r48,[__fdlib_version]; setp.eq.u32 %r49,%r48,-1; @ %r49 bra $L1; .loc 1 35 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r47; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.ne.u32 %r52,%r51,0; @ %r52 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r54,[%value_in]; } setp.eq.u32 %r55,%r54,0; @ %r55 bra $L1; .loc 1 42 0 cvta.const.u64 %r56,$LC0; st.u64 [%frame+8],%r56; .loc 1 43 0 st.u32 [%frame+40],%r51; .loc 1 44 0 cvt.f64.f32 %r27,%r42; st.f64 [%frame+24],%r27; st.f64 [%frame+16],%r27; .loc 1 45 0 ld.global.u32 %r58,[__fdlib_version]; setp.ne.u32 %r59,%r58,0; @ %r59 bra $L3; .loc 1 46 0 mov.f64 %r60,0d47efffffe0000000; st.f64 [%frame+32],%r60; bra $L4; $L3: .loc 1 48 0 mov.f64 %r61,0d7ff0000000000000; st.f64 [%frame+32],%r61; $L4: .loc 1 49 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r42; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r63,[%value_in]; } setp.neu.f32 %r64,%r63,%r42; @ %r64 bra $L5; ld.global.u32 %r40,[__fdlib_version]; setp.le.f32 %r65,%r42,0f00000000; @ ! %r65 bra $L6; .loc 1 51 0 mov.u32 %r66,2; st.u32 [%frame],%r66; .loc 1 52 0 setp.ne.u32 %r67,%r40,2; @ %r67 bra $L8; .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L9; $L8: .loc 1 54 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r71,[%value_in]; } setp.eq.u32 %r72,%r71,0; @ ! %r72 bra $L9; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r73,[%value_in]; } mov.u32 %r74,33; st.u32 [%r73],%r74; bra $L9; $L5: ld.global.u32 %r40,[__fdlib_version]; $L6: .loc 1 60 0 mov.u32 %r75,3; st.u32 [%frame],%r75; .loc 1 61 0 setp.ne.u32 %r76,%r40,2; @ %r76 bra $L11; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; bra $L9; $L11: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r80,[%value_in]; } setp.ne.u32 %r81,%r80,0; @ %r81 bra $L9; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r82,[%value_in]; } mov.u32 %r83,34; st.u32 [%r82],%r83; $L9: .loc 1 67 0 ld.u32 %r84,[%frame+40]; setp.eq.u32 %r85,%r84,0; @ %r85 bra $L13; .loc 1 68 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r86,[%value_in]; } ld.u32 %r38,[%frame+40]; st.u32 [%r86],%r38; $L13: .loc 1 69 0 ld.f64 %r87,[%frame+32]; cvt.rn.f32.f64 %r41,%r87; $L1: .loc 1 73 0 mov.f32 %value,%r41; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_log.o/ 0 0 0 644 5385 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: logf .visible .func (.param .f32 %value_out) logf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_log.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_logf .extern .func (.param .f32 %value_out) __ieee754_logf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {108,111,103,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: logf .visible .func (.param .f32 %value_out) logf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .pred %r53; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .f64 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u64 %r76; .reg .f64 %r77; .reg .u32 %r79; .reg .u32 %r80; mov.f32 %r38,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__ieee754_logf,(%out_arg1); ld.param.f32 %r40,[%value_in]; } mov.f32 %r37,%r40; .loc 1 36 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; setp.gt.f32 %r46,%r38,0f00000000; @ %r46 bra $L1; .loc 1 43 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 44 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 45 0 cvt.f64.f32 %r24,%r38; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 46 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r49,%r25,0; @ %r49 bra $L3; .loc 1 47 0 mov.f64 %r50,0dc7efffffe0000000; st.f64 [%frame+32],%r50; .loc 1 50 0 setp.eq.f32 %r51,%r38,0f00000000; @ %r51 bra $L4; bra $L21; $L3: .loc 1 49 0 mov.f64 %r52,0dfff0000000000000; st.f64 [%frame+32],%r52; .loc 1 50 0 setp.neu.f32 %r53,%r38,0f00000000; @ %r53 bra $L6; .loc 1 52 0 mov.u32 %r54,2; st.u32 [%frame],%r54; .loc 1 53 0 setp.ne.u32 %r55,%r25,2; @ %r55 bra $L7; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,34; st.u32 [%r56],%r57; bra $L8; $L7: .loc 1 55 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.ne.u32 %r60,%r59,0; @ %r60 bra $L8; .loc 1 56 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } mov.u32 %r62,34; st.u32 [%r61],%r62; bra $L8; $L6: .loc 1 60 0 mov.u32 %r63,1; st.u32 [%frame],%r63; .loc 1 61 0 setp.ne.u32 %r64,%r25,2; @ %r64 bra $L9; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L10; $L9: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.ne.u32 %r69,%r68,0; @ %r69 bra $L10; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; $L10: .loc 1 66 0 cvta.const.u64 %r72,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r72; call (%value_in),nan,(%out_arg1); ld.param.f64 %r73,[%value_in]; } st.f64 [%frame+32],%r73; $L8: .loc 1 68 0 ld.u32 %r74,[%frame+40]; setp.eq.u32 %r75,%r74,0; @ %r75 bra $L11; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r76,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r76],%r35; $L11: .loc 1 70 0 ld.f64 %r77,[%frame+32]; cvt.rn.f32.f64 %r37,%r77; bra $L1; $L4: .loc 1 52 0 mov.u32 %r79,2; st.u32 [%frame],%r79; bra $L7; $L21: .loc 1 60 0 mov.u32 %r80,1; st.u32 [%frame],%r80; bra $L9; $L1: .loc 1 72 0 mov.f32 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1587 0 0 0 644 5424 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: log10f .visible .func (.param .f32 %value_out) log10f (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_log10.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_log10f .extern .func (.param .f32 %value_out) __ieee754_log10f (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nan .extern .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {108,111,103,49,48,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: log10f .visible .func (.param .f32 %value_out) log10f (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r35; .reg .f32 %r37; .reg .f32 %r38; .reg .f32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .u32 %r44; .reg .pred %r45; .reg .pred %r46; .reg .u64 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .f64 %r50; .reg .pred %r51; .reg .f64 %r52; .reg .pred %r53; .reg .u32 %r54; .reg .pred %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .f64 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .u64 %r76; .reg .f64 %r77; .reg .u32 %r79; .reg .u32 %r80; mov.f32 %r38,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__ieee754_log10f,(%out_arg1); ld.param.f32 %r40,[%value_in]; } mov.f32 %r37,%r40; .loc 1 36 0 ld.global.u32 %r41,[__fdlib_version]; setp.eq.u32 %r42,%r41,-1; @ %r42 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r38; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r44,[%value_in]; } setp.eq.u32 %r45,%r44,0; @ %r45 bra $L1; .loc 1 37 0 setp.le.f32 %r46,%r38,0f00000000; @ ! %r46 bra $L1; .loc 1 44 0 cvta.const.u64 %r47,$LC0; st.u64 [%frame+8],%r47; .loc 1 45 0 mov.u32 %r48,0; st.u32 [%frame+40],%r48; .loc 1 46 0 cvt.f64.f32 %r24,%r38; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 47 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r49,%r25,0; @ %r49 bra $L4; .loc 1 48 0 mov.f64 %r50,0dc7efffffe0000000; st.f64 [%frame+32],%r50; .loc 1 51 0 setp.eq.f32 %r51,%r38,0f00000000; @ %r51 bra $L5; bra $L23; $L4: .loc 1 50 0 mov.f64 %r52,0dfff0000000000000; st.f64 [%frame+32],%r52; .loc 1 51 0 setp.neu.f32 %r53,%r38,0f00000000; @ %r53 bra $L7; .loc 1 53 0 mov.u32 %r54,2; st.u32 [%frame],%r54; .loc 1 54 0 setp.ne.u32 %r55,%r25,2; @ %r55 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r56,[%value_in]; } mov.u32 %r57,34; st.u32 [%r56],%r57; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r59,[%value_in]; } setp.ne.u32 %r60,%r59,0; @ %r60 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } mov.u32 %r62,34; st.u32 [%r61],%r62; bra $L9; $L7: .loc 1 61 0 mov.u32 %r63,1; st.u32 [%frame],%r63; .loc 1 62 0 setp.ne.u32 %r64,%r25,2; @ %r64 bra $L10; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L11; $L10: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.ne.u32 %r69,%r68,0; @ %r69 bra $L11; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; $L11: .loc 1 67 0 cvta.const.u64 %r72,$LC1; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r72; call (%value_in),nan,(%out_arg1); ld.param.f64 %r73,[%value_in]; } st.f64 [%frame+32],%r73; $L9: .loc 1 69 0 ld.u32 %r74,[%frame+40]; setp.eq.u32 %r75,%r74,0; @ %r75 bra $L12; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r76,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r76],%r35; $L12: .loc 1 71 0 ld.f64 %r77,[%frame+32]; cvt.rn.f32.f64 %r37,%r77; bra $L1; $L5: .loc 1 53 0 mov.u32 %r79,2; st.u32 [%frame],%r79; bra $L8; $L23: .loc 1 61 0 mov.u32 %r80,1; st.u32 [%frame],%r80; bra $L10; $L1: .loc 1 75 0 mov.f32 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_pow.o/ 0 0 0 644 16498 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: powf .visible .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_pow.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_powf .extern .func (.param .f32 %value_out) __ieee754_powf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: rint .extern .func (.param .f64 %value_out) rint (.param .f64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[5] = {112,111,119,102,0 }; // BEGIN GLOBAL FUNCTION DEF: powf .visible .func (.param .f32 %value_out) powf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .u32 %r42; .reg .u32 %r46; .reg .u32 %r52; .reg .u32 %r60; .reg .u32 %r67; .reg .f64 %r72; .reg .f64 %r74; .reg .u32 %r82; .reg .u32 %r94; .reg .u32 %r96; .reg .f32 %r97; .reg .f32 %r102; .reg .f32 %r103; .reg .f32 %r104; .reg .f32 %r107; .reg .u32 %r108; .reg .pred %r109; .reg .u32 %r111; .reg .pred %r112; .reg .u32 %r114; .reg .pred %r115; .reg .pred %r116; .reg .u32 %r117; .reg .u64 %r118; .reg .f64 %r120; .reg .f64 %r121; .reg .f64 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r127; .reg .u32 %r128; .reg .u16 %r129; .reg .u16 %r130; .reg .u16 %r131; .reg .u32 %r132; .reg .u16 %r133; .reg .pred %r134; .reg .u32 %r136; .reg .pred %r137; .reg .u64 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .pred %r141; .reg .f64 %r142; .reg .u64 %r143; .reg .f64 %r144; .reg .pred %r145; .reg .pred %r146; .reg .u32 %r147; .reg .u64 %r148; .reg .u32 %r149; .reg .f64 %r150; .reg .f64 %r151; .reg .f64 %r152; .reg .u32 %r153; .reg .pred %r154; .reg .u32 %r156; .reg .pred %r157; .reg .u64 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .pred %r161; .reg .f64 %r162; .reg .u64 %r163; .reg .f64 %r164; .reg .u32 %r166; .reg .pred %r167; .reg .pred %r168; .reg .u32 %r169; .reg .u64 %r170; .reg .u32 %r171; .reg .f64 %r172; .reg .f64 %r173; .reg .pred %r174; .reg .f64 %r175; .reg .f64 %r176; .reg .pred %r177; .reg .u64 %r178; .reg .u32 %r179; .reg .u32 %r181; .reg .pred %r182; .reg .u64 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .pred %r186; .reg .u64 %r187; .reg .f64 %r188; .reg .u32 %r190; .reg .pred %r191; .reg .u32 %r193; .reg .pred %r194; .reg .u32 %r196; .reg .pred %r197; .reg .u32 %r199; .reg .pred %r200; .reg .u32 %r201; .reg .u64 %r202; .reg .f64 %r204; .reg .f64 %r205; .reg .pred %r206; .reg .f64 %r207; .reg .f64 %r208; .reg .f64 %r209; .reg .pred %r210; .reg .u64 %r211; .reg .u32 %r212; .reg .u32 %r214; .reg .pred %r215; .reg .u64 %r216; .reg .u32 %r217; .reg .u32 %r218; .reg .pred %r219; .reg .u64 %r220; .reg .f64 %r221; .reg .u32 %r222; .reg .u64 %r223; .reg .f64 %r225; .reg .f64 %r226; .reg .pred %r228; .reg .f64 %r229; .reg .pred %r230; .reg .f64 %r232; .reg .pred %r233; .reg .f64 %r234; .reg .f64 %r235; .reg .pred %r236; .reg .f64 %r238; .reg .pred %r239; .reg .f64 %r240; .reg .pred %r242; .reg .u64 %r243; .reg .u32 %r244; .reg .u32 %r246; .reg .pred %r247; .reg .u64 %r248; .reg .u32 %r249; .reg .u32 %r250; .reg .pred %r251; .reg .u64 %r252; .reg .f64 %r253; .reg .pred %r254; .reg .u32 %r256; .reg .pred %r257; .reg .u32 %r259; .reg .pred %r260; .reg .u32 %r261; .reg .u64 %r262; .reg .u32 %r263; .reg .f64 %r264; .reg .f64 %r265; .reg .f64 %r266; .reg .u32 %r267; .reg .pred %r268; .reg .u64 %r269; .reg .u32 %r270; .reg .u32 %r272; .reg .pred %r273; .reg .u64 %r274; .reg .u32 %r275; .reg .u32 %r276; .reg .pred %r277; .reg .u64 %r278; .reg .f64 %r279; .reg .u32 %r281; mov.f32 %r103,%ar0; mov.f32 %r104,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r104; call (%value_in),__ieee754_powf,(%out_arg1,%out_arg2); ld.param.f32 %r107,[%value_in]; } mov.f32 %r102,%r107; .loc 1 36 0 ld.global.u32 %r108,[__fdlib_version]; setp.eq.u32 %r109,%r108,-1; @ %r109 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r111,[%value_in]; } setp.eq.u32 %r112,%r111,0; @ %r112 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r114,[%value_in]; } setp.ne.u32 %r115,%r114,0; @ %r115 bra $L3; .loc 1 38 0 setp.neu.f32 %r116,%r104,0f00000000; @ %r116 bra $L1; .loc 1 41 0 mov.u32 %r117,1; st.u32 [%frame],%r117; .loc 1 42 0 cvta.const.u64 %r118,$LC0; st.u64 [%frame+8],%r118; .loc 1 43 0 st.u32 [%frame+40],%r114; .loc 1 44 0 cvt.f64.f32 %r120,%r103; st.f64 [%frame+16],%r120; .loc 1 45 0 cvt.f64.f32 %r121,%r104; st.f64 [%frame+24],%r121; .loc 1 46 0 mov.f64 %r122,0d3ff0000000000000; st.f64 [%frame+32],%r122; .loc 1 47 0 ld.global.u32 %r96,[__fdlib_version]; set.u32.eq.u32 %r124,%r96,-1; neg.s32 %r125,%r124; set.u32.eq.u32 %r127,%r96,2; neg.s32 %r128,%r127; cvt.u16.u32 %r130,%r125; cvt.u16.u32 %r131,%r128; or.b16 %r129,%r130,%r131; cvt.u32.u16 %r132,%r129; cvt.u16.u8 %r133,%r132; setp.ne.u16 %r134,%r133,0; @ %r134 bra $L35; .loc 1 49 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r136,[%value_in]; } setp.ne.u32 %r137,%r136,0; @ %r137 bra $L5; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r138,[%value_in]; } mov.u32 %r139,33; st.u32 [%r138],%r139; $L5: .loc 1 52 0 ld.u32 %r140,[%frame+40]; setp.ne.u32 %r141,%r140,0; @ %r141 bra $L6; ld.f64 %r142,[%frame+32]; cvt.rn.f32.f64 %r102,%r142; bra $L1; $L6: .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r143,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r143],%r34; ld.f64 %r144,[%frame+32]; cvt.rn.f32.f64 %r102,%r144; bra $L1; $L35: mov.f32 %r102,0f3f800000; .loc 1 54 0 bra $L1; $L3: .loc 1 58 0 setp.neu.f32 %r145,%r103,0f00000000; @ %r145 bra $L7; .loc 1 59 0 setp.neu.f32 %r146,%r104,0f00000000; @ %r146 bra $L8; .loc 1 62 0 mov.u32 %r147,1; st.u32 [%frame],%r147; .loc 1 63 0 cvta.const.u64 %r148,$LC0; st.u64 [%frame+8],%r148; .loc 1 64 0 mov.u32 %r149,0; st.u32 [%frame+40],%r149; .loc 1 65 0 cvt.f64.f32 %r150,%r103; st.f64 [%frame+16],%r150; .loc 1 66 0 cvt.f64.f32 %r151,%r104; st.f64 [%frame+24],%r151; .loc 1 67 0 mov.f64 %r152,0d0000000000000000; st.f64 [%frame+32],%r152; .loc 1 68 0 ld.global.u32 %r153,[__fdlib_version]; setp.ne.u32 %r154,%r153,0; @ %r154 bra $L36; .loc 1 69 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r156,[%value_in]; } setp.ne.u32 %r157,%r156,0; @ %r157 bra $L10; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r158,[%value_in]; } mov.u32 %r159,33; st.u32 [%r158],%r159; $L10: .loc 1 72 0 ld.u32 %r160,[%frame+40]; setp.ne.u32 %r161,%r160,0; @ %r161 bra $L11; ld.f64 %r162,[%frame+32]; cvt.rn.f32.f64 %r102,%r162; bra $L1; $L11: .loc 1 73 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r163,[%value_in]; } ld.u32 %r42,[%frame+40]; st.u32 [%r163],%r42; ld.f64 %r164,[%frame+32]; cvt.rn.f32.f64 %r102,%r164; bra $L1; $L36: mov.f32 %r102,0f3f800000; .loc 1 74 0 bra $L1; $L8: .loc 1 76 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r166,[%value_in]; } setp.eq.u32 %r167,%r166,0; @ %r167 bra $L1; setp.lt.f32 %r168,%r104,0f00000000; @ ! %r168 bra $L1; .loc 1 78 0 mov.u32 %r169,1; st.u32 [%frame],%r169; .loc 1 79 0 cvta.const.u64 %r170,$LC0; st.u64 [%frame+8],%r170; .loc 1 80 0 mov.u32 %r171,0; st.u32 [%frame+40],%r171; .loc 1 81 0 cvt.f64.f32 %r172,%r103; st.f64 [%frame+16],%r172; .loc 1 82 0 cvt.f64.f32 %r173,%r104; st.f64 [%frame+24],%r173; .loc 1 83 0 ld.global.u32 %r46,[__fdlib_version]; setp.ne.u32 %r174,%r46,0; @ %r174 bra $L13; .loc 1 84 0 mov.f64 %r175,0d0000000000000000; st.f64 [%frame+32],%r175; bra $L14; $L13: .loc 1 86 0 mov.f64 %r176,0dfff0000000000000; st.f64 [%frame+32],%r176; .loc 1 87 0 setp.ne.u32 %r177,%r46,2; @ %r177 bra $L14; .loc 1 88 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r178,[%value_in]; } mov.u32 %r179,33; st.u32 [%r178],%r179; bra $L15; $L14: .loc 1 89 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r181,[%value_in]; } setp.ne.u32 %r182,%r181,0; @ %r182 bra $L15; .loc 1 90 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r183,[%value_in]; } mov.u32 %r184,33; st.u32 [%r183],%r184; $L15: .loc 1 92 0 ld.u32 %r185,[%frame+40]; setp.eq.u32 %r186,%r185,0; @ %r186 bra $L16; .loc 1 93 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r187,[%value_in]; } ld.u32 %r52,[%frame+40]; st.u32 [%r187],%r52; $L16: .loc 1 94 0 ld.f64 %r188,[%frame+32]; cvt.rn.f32.f64 %r102,%r188; bra $L1; $L7: .loc 1 98 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r107; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r190,[%value_in]; } setp.ne.u32 %r191,%r190,0; @ %r191 bra $L17; .loc 1 99 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r193,[%value_in]; } setp.eq.u32 %r194,%r193,0; @ %r194 bra $L17; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r196,[%value_in]; } setp.eq.u32 %r197,%r196,0; @ %r197 bra $L17; .loc 1 100 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r107; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r199,[%value_in]; } setp.ne.u32 %r200,%r199,0; @ %r200 bra $L18; .loc 1 102 0 mov.u32 %r201,1; st.u32 [%frame],%r201; .loc 1 103 0 cvta.const.u64 %r202,$LC0; st.u64 [%frame+8],%r202; .loc 1 104 0 st.u32 [%frame+40],%r199; .loc 1 105 0 cvt.f64.f32 %r204,%r103; st.f64 [%frame+16],%r204; .loc 1 106 0 cvt.f64.f32 %r205,%r104; st.f64 [%frame+24],%r205; .loc 1 107 0 ld.global.u32 %r60,[__fdlib_version]; setp.ne.u32 %r206,%r60,0; @ %r206 bra $L19; .loc 1 108 0 mov.f64 %r207,0d0000000000000000; st.f64 [%frame+32],%r207; bra $L20; $L19: .loc 1 110 0 mov.f64 %r209,0d0000000000000000; div.rn.f64 %r208,%r209,0d0000000000000000; st.f64 [%frame+32],%r208; .loc 1 111 0 setp.ne.u32 %r210,%r60,2; @ %r210 bra $L20; .loc 1 112 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r211,[%value_in]; } mov.u32 %r212,33; st.u32 [%r211],%r212; bra $L21; $L20: .loc 1 113 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r214,[%value_in]; } setp.ne.u32 %r215,%r214,0; @ %r215 bra $L21; .loc 1 114 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r216,[%value_in]; } mov.u32 %r217,33; st.u32 [%r216],%r217; $L21: .loc 1 116 0 ld.u32 %r218,[%frame+40]; setp.eq.u32 %r219,%r218,0; @ %r219 bra $L22; .loc 1 117 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r220,[%value_in]; } ld.u32 %r67,[%frame+40]; st.u32 [%r220],%r67; $L22: .loc 1 118 0 ld.f64 %r221,[%frame+32]; cvt.rn.f32.f64 %r102,%r221; bra $L1; $L18: .loc 1 121 0 mov.u32 %r222,3; st.u32 [%frame],%r222; .loc 1 122 0 cvta.const.u64 %r223,$LC0; st.u64 [%frame+8],%r223; .loc 1 123 0 st.u32 [%frame+40],%r190; .loc 1 124 0 cvt.f64.f32 %r225,%r103; st.f64 [%frame+16],%r225; .loc 1 125 0 cvt.f64.f32 %r226,%r104; st.f64 [%frame+24],%r226; mul.f32 %r97,%r104,0f3f000000; .loc 1 126 0 ld.global.u32 %r281,[__fdlib_version]; setp.ne.u32 %r228,%r281,0; @ %r228 bra $L23; .loc 1 127 0 mov.f64 %r229,0d47efffffe0000000; st.f64 [%frame+32],%r229; .loc 1 129 0 setp.lt.f32 %r230,%r103,0f00000000; @ ! %r230 bra $L24; cvt.f64.f32 %r72,%r97; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r72; call (%value_in),rint,(%out_arg1); ld.param.f64 %r232,[%value_in]; } setp.neu.f64 %r233,%r72,%r232; @ %r233 bra $L26; ld.global.u32 %r281,[__fdlib_version]; bra $L27; $L26: mov.f64 %r234,0dc7efffffe0000000; st.f64 [%frame+32],%r234; ld.global.u32 %r281,[__fdlib_version]; bra $L27; $L23: .loc 1 131 0 mov.f64 %r235,0d7ff0000000000000; st.f64 [%frame+32],%r235; .loc 1 133 0 setp.lt.f32 %r236,%r103,0f00000000; @ ! %r236 bra $L27; cvt.f64.f32 %r74,%r97; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r74; call (%value_in),rint,(%out_arg1); ld.param.f64 %r238,[%value_in]; } setp.eq.f64 %r239,%r74,%r238; @ ! %r239 bra $L74; ld.global.u32 %r281,[__fdlib_version]; bra $L27; $L74: mov.f64 %r240,0dfff0000000000000; st.f64 [%frame+32],%r240; ld.global.u32 %r281,[__fdlib_version]; $L27: .loc 1 135 0 setp.ne.u32 %r242,%r281,2; @ %r242 bra $L24; .loc 1 136 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r243,[%value_in]; } mov.u32 %r244,34; st.u32 [%r243],%r244; bra $L30; $L24: .loc 1 137 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r246,[%value_in]; } setp.ne.u32 %r247,%r246,0; @ %r247 bra $L30; .loc 1 138 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r248,[%value_in]; } mov.u32 %r249,34; st.u32 [%r248],%r249; $L30: .loc 1 140 0 ld.u32 %r250,[%frame+40]; setp.eq.u32 %r251,%r250,0; @ %r251 bra $L31; .loc 1 141 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r252,[%value_in]; } ld.u32 %r82,[%frame+40]; st.u32 [%r252],%r82; $L31: .loc 1 142 0 ld.f64 %r253,[%frame+32]; cvt.rn.f32.f64 %r102,%r253; bra $L1; $L17: .loc 1 146 0 setp.neu.f32 %r254,%r107,0f00000000; @ %r254 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r103; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r256,[%value_in]; } setp.eq.u32 %r257,%r256,0; @ %r257 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r104; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r259,[%value_in]; } setp.eq.u32 %r260,%r259,0; @ %r260 bra $L1; .loc 1 148 0 mov.u32 %r261,4; st.u32 [%frame],%r261; .loc 1 149 0 cvta.const.u64 %r262,$LC0; st.u64 [%frame+8],%r262; .loc 1 150 0 mov.u32 %r263,0; st.u32 [%frame+40],%r263; .loc 1 151 0 cvt.f64.f32 %r264,%r103; st.f64 [%frame+16],%r264; .loc 1 152 0 cvt.f64.f32 %r265,%r104; st.f64 [%frame+24],%r265; .loc 1 153 0 mov.f64 %r266,0d0000000000000000; st.f64 [%frame+32],%r266; .loc 1 154 0 ld.global.u32 %r267,[__fdlib_version]; setp.ne.u32 %r268,%r267,2; @ %r268 bra $L32; .loc 1 155 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r269,[%value_in]; } mov.u32 %r270,34; st.u32 [%r269],%r270; bra $L33; $L32: .loc 1 156 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r272,[%value_in]; } setp.ne.u32 %r273,%r272,0; @ %r273 bra $L33; .loc 1 157 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r274,[%value_in]; } mov.u32 %r275,34; st.u32 [%r274],%r275; $L33: .loc 1 159 0 ld.u32 %r276,[%frame+40]; setp.eq.u32 %r277,%r276,0; @ %r277 bra $L34; .loc 1 160 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r278,[%value_in]; } ld.u32 %r94,[%frame+40]; st.u32 [%r278],%r94; $L34: .loc 1 161 0 ld.f64 %r279,[%frame+32]; cvt.rn.f32.f64 %r102,%r279; $L1: .loc 1 165 0 mov.f32 %value,%r102; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1605 0 0 0 644 4460 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: remainderf .visible .func (.param .f32 %value_out) remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_remainder.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_remainderf .extern .func (.param .f32 %value_out) __ieee754_remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[11] = {114,101,109,97,105,110,100,101,114,102,0 }; // BEGIN GLOBAL FUNCTION DEF: remainderf .visible .func (.param .f32 %value_out) remainderf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r33; .reg .f32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .f32 %r43; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r47; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r52; .reg .u32 %r53; .reg .u16 %r54; .reg .u16 %r55; .reg .u16 %r56; .reg .u32 %r57; .reg .u16 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u64 %r61; .reg .u32 %r62; .reg .f64 %r63; .reg .f64 %r64; .reg .f64 %r65; .reg .f64 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .f64 %r79; mov.f32 %r39,%ar0; mov.f32 %r40,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r40; call (%value_in),__ieee754_remainderf,(%out_arg1,%out_arg2); ld.param.f32 %r43,[%value_in]; } mov.f32 %r38,%r43; .loc 1 36 0 ld.global.u32 %r44,[__fdlib_version]; setp.eq.u32 %r45,%r44,-1; @ %r45 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r47,[%value_in]; } .loc 1 37 0 set.u32.eq.f32 %r49,%r40,0f00000000; neg.s32 %r50,%r49; .loc 1 36 0 set.u32.ne.u32 %r52,%r47,0; neg.s32 %r53,%r52; .loc 1 37 0 cvt.u16.u32 %r55,%r50; cvt.u16.u32 %r56,%r53; and.b16 %r54,%r55,%r56; cvt.u32.u16 %r57,%r54; cvt.u16.u8 %r58,%r57; setp.eq.u16 %r59,%r58,0; @ %r59 bra $L1; .loc 1 39 0 mov.u32 %r60,1; st.u32 [%frame],%r60; .loc 1 40 0 cvta.const.u64 %r61,$LC0; st.u64 [%frame+8],%r61; .loc 1 41 0 mov.u32 %r62,0; st.u32 [%frame+40],%r62; .loc 1 42 0 cvt.f64.f32 %r63,%r39; st.f64 [%frame+16],%r63; .loc 1 43 0 cvt.f64.f32 %r64,%r40; st.f64 [%frame+24],%r64; .loc 1 44 0 mov.f64 %r66,0d0000000000000000; div.rn.f64 %r65,%r66,0d0000000000000000; st.f64 [%frame+32],%r65; .loc 1 45 0 ld.global.u32 %r67,[__fdlib_version]; setp.ne.u32 %r68,%r67,2; @ %r68 bra $L3; .loc 1 46 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r69,[%value_in]; } mov.u32 %r70,33; st.u32 [%r69],%r70; bra $L4; $L3: .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r72,[%value_in]; } setp.ne.u32 %r73,%r72,0; @ %r73 bra $L4; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } mov.u32 %r75,33; st.u32 [%r74],%r75; $L4: .loc 1 50 0 ld.u32 %r76,[%frame+40]; setp.eq.u32 %r77,%r76,0; @ %r77 bra $L5; .loc 1 51 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r78,[%value_in]; } ld.u32 %r33,[%frame+40]; st.u32 [%r78],%r33; $L5: .loc 1 52 0 ld.f64 %r79,[%frame+32]; cvt.rn.f32.f64 %r38,%r79; $L1: .loc 1 56 0 mov.f32 %value,%r38; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1627 0 0 0 644 7387 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: scalbf .visible .func (.param .f32 %value_out) scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wf_scalb.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_scalbf .extern .func (.param .f32 %value_out) __ieee754_scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {115,99,97,108,98,102,0 }; // BEGIN GLOBAL FUNCTION DEF: scalbf .visible .func (.param .f32 %value_out) scalbf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .f64 %r39; .reg .u32 %r48; .reg .f64 %r52; .reg .f32 %r53; .reg .f32 %r54; .reg .f32 %r55; .reg .f32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r65; .reg .pred %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u32 %r70; .reg .u64 %r71; .reg .f64 %r73; .reg .f64 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .pred %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .pred %r86; .reg .u64 %r87; .reg .f64 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r93; .reg .u32 %r94; .reg .u16 %r95; .reg .u16 %r96; .reg .u16 %r97; .reg .u32 %r98; .reg .u16 %r99; .reg .pred %r100; .reg .u32 %r101; .reg .u64 %r102; .reg .u32 %r103; .reg .f64 %r104; .reg .f64 %r105; .reg .f64 %r107; .reg .u32 %r108; .reg .pred %r109; .reg .u64 %r110; .reg .u32 %r111; .reg .u32 %r113; .reg .pred %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .pred %r118; .reg .u64 %r119; .reg .f64 %r120; .reg .u32 %r122; .reg .pred %r123; .reg .u64 %r124; .reg .u32 %r125; mov.f32 %r54,%ar0; mov.f32 %r55,%ar1; .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r54; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r55; call (%value_in),__ieee754_scalbf,(%out_arg1,%out_arg2); ld.param.f32 %r58,[%value_in]; } mov.f32 %r53,%r58; .loc 1 52 0 ld.global.u32 %r59,[__fdlib_version]; setp.eq.u32 %r60,%r59,-1; @ %r60 bra $L1; .loc 1 53 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r62,[%value_in]; } setp.ne.u32 %r63,%r62,0; @ %r63 bra $L3; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r58; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r65,[%value_in]; } setp.eq.u32 %r66,%r65,0; @ %r66 bra $L3; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r54; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.eq.u32 %r69,%r68,0; @ %r69 bra $L3; .loc 1 55 0 mov.u32 %r70,3; st.u32 [%frame],%r70; .loc 1 56 0 cvta.const.u64 %r71,$LC0; st.u64 [%frame+8],%r71; .loc 1 57 0 st.u32 [%frame+40],%r62; .loc 1 58 0 cvt.f64.f32 %r73,%r54; st.f64 [%frame+16],%r73; .loc 1 59 0 cvt.f64.f32 %r74,%r55; st.f64 [%frame+24],%r74; .loc 1 60 0 setp.gt.f32 %r75,%r54,0f00000000; selp.f64 %r52,0d7ff0000000000000,0dfff0000000000000,%r75; st.f64 [%frame+32],%r52; .loc 1 61 0 ld.global.u32 %r76,[__fdlib_version]; setp.ne.u32 %r77,%r76,2; @ %r77 bra $L5; .loc 1 62 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r78,[%value_in]; } mov.u32 %r79,34; st.u32 [%r78],%r79; bra $L6; $L5: .loc 1 63 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r81,[%value_in]; } setp.ne.u32 %r82,%r81,0; @ %r82 bra $L6; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } mov.u32 %r84,34; st.u32 [%r83],%r84; $L6: .loc 1 66 0 ld.u32 %r85,[%frame+40]; setp.eq.u32 %r86,%r85,0; @ %r86 bra $L7; .loc 1 67 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r87,[%value_in]; } ld.u32 %r34,[%frame+40]; st.u32 [%r87],%r34; $L7: .loc 1 68 0 ld.f64 %r88,[%frame+32]; cvt.rn.f32.f64 %r53,%r88; bra $L1; $L3: .loc 1 70 0 set.u32.eq.f32 %r90,%r58,0f00000000; neg.s32 %r91,%r90; set.u32.neu.f32 %r93,%r54,%r58; neg.s32 %r94,%r93; cvt.u16.u32 %r96,%r91; cvt.u16.u32 %r97,%r94; and.b16 %r95,%r96,%r97; cvt.u32.u16 %r98,%r95; cvt.u16.u8 %r99,%r98; setp.eq.u16 %r100,%r99,0; @ %r100 bra $L8; .loc 1 72 0 mov.u32 %r101,4; st.u32 [%frame],%r101; .loc 1 73 0 cvta.const.u64 %r102,$LC0; st.u64 [%frame+8],%r102; .loc 1 74 0 mov.u32 %r103,0; st.u32 [%frame+40],%r103; .loc 1 75 0 cvt.f64.f32 %r39,%r54; st.f64 [%frame+16],%r39; .loc 1 76 0 cvt.f64.f32 %r104,%r55; st.f64 [%frame+24],%r104; .loc 1 77 0 mov.f64 %r105,0d0000000000000000; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r105; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r39; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r107,[%value_in]; } st.f64 [%frame+32],%r107; .loc 1 78 0 ld.global.u32 %r108,[__fdlib_version]; setp.ne.u32 %r109,%r108,2; @ %r109 bra $L9; .loc 1 79 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r110,[%value_in]; } mov.u32 %r111,34; st.u32 [%r110],%r111; bra $L10; $L9: .loc 1 80 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r113,[%value_in]; } setp.ne.u32 %r114,%r113,0; @ %r114 bra $L10; .loc 1 81 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r115,[%value_in]; } mov.u32 %r116,34; st.u32 [%r115],%r116; $L10: .loc 1 83 0 ld.u32 %r117,[%frame+40]; setp.eq.u32 %r118,%r117,0; @ %r118 bra $L11; .loc 1 84 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r119,[%value_in]; } ld.u32 %r48,[%frame+40]; st.u32 [%r119],%r48; $L11: .loc 1 85 0 ld.f64 %r120,[%frame+32]; cvt.rn.f32.f64 %r53,%r120; bra $L1; $L8: .loc 1 88 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r55; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r122,[%value_in]; } setp.ne.u32 %r123,%r122,0; @ %r123 bra $L1; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r124,[%value_in]; } mov.u32 %r125,34; st.u32 [%r124],%r125; $L1: .loc 1 92 0 mov.f32 %value,%r53; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1645 0 0 0 644 1244 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sincosf .visible .func sincosf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libm/math/wf_sincos.c" // BEGIN GLOBAL FUNCTION DECL: sinf .extern .func (.param .f32 %value_out) sinf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: cosf .extern .func (.param .f32 %value_out) cosf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: sincosf .visible .func sincosf (.param .f32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f32 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .f32 %r28; .reg .f32 %r30; mov.f32 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 15 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),sinf,(%out_arg1); ld.param.f32 %r28,[%value_in]; } st.f32 [%r25],%r28; .loc 1 16 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r24; call (%value_in),cosf,(%out_arg1); ld.param.f32 %r30,[%value_in]; } st.f32 [%r26],%r30; .loc 1 17 0 ret; } lib_a-wf_sinh.o/0 0 0 644 4195 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sinhf .visible .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_sinh.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sinhf .extern .func (.param .f32 %value_out) __ieee754_sinhf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {115,105,110,104,102,0 }; // BEGIN GLOBAL FUNCTION DEF: sinhf .visible .func (.param .f32 %value_out) sinhf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r26; .reg .u32 %r32; .reg .f64 %r34; .reg .f64 %r35; .reg .f32 %r36; .reg .f32 %r37; .reg .f32 %r39; .reg .u32 %r40; .reg .pred %r41; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r48; .reg .u64 %r49; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r64; .reg .f64 %r65; mov.f32 %r37,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),__ieee754_sinhf,(%out_arg1); ld.param.f32 %r39,[%value_in]; } mov.f32 %r36,%r39; .loc 1 36 0 ld.global.u32 %r40,[__fdlib_version]; setp.eq.u32 %r41,%r40,-1; @ %r41 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r39; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r43,[%value_in]; } setp.ne.u32 %r44,%r43,0; @ %r44 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r37; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.eq.u32 %r47,%r46,0; @ %r47 bra $L1; .loc 1 45 0 mov.u32 %r48,3; st.u32 [%frame],%r48; .loc 1 46 0 cvta.const.u64 %r49,$LC0; st.u64 [%frame+8],%r49; .loc 1 47 0 st.u32 [%frame+40],%r43; .loc 1 48 0 cvt.f64.f32 %r25,%r37; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 49 0 ld.global.u32 %r26,[__fdlib_version]; setp.ne.u32 %r51,%r26,0; @ %r51 bra $L3; .loc 1 50 0 setp.gt.f32 %r52,%r37,0f00000000; selp.f64 %r34,0d47efffffe0000000,0dc7efffffe0000000,%r52; st.f64 [%frame+32],%r34; bra $L5; $L3: .loc 1 52 0 setp.gt.f32 %r53,%r37,0f00000000; selp.f64 %r35,0d7ff0000000000000,0dfff0000000000000,%r53; st.f64 [%frame+32],%r35; .loc 1 53 0 setp.ne.u32 %r54,%r26,2; @ %r54 bra $L5; .loc 1 54 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r55,[%value_in]; } mov.u32 %r56,34; st.u32 [%r55],%r56; bra $L7; $L5: .loc 1 55 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r58,[%value_in]; } setp.ne.u32 %r59,%r58,0; @ %r59 bra $L7; .loc 1 56 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r60,[%value_in]; } mov.u32 %r61,34; st.u32 [%r60],%r61; $L7: .loc 1 58 0 ld.u32 %r62,[%frame+40]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L8; .loc 1 59 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r64],%r32; $L8: .loc 1 60 0 ld.f64 %r65,[%frame+32]; cvt.rn.f32.f64 %r36,%r65; $L1: .loc 1 64 0 mov.f32 %value,%r36; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } lib_a-wf_sqrt.o/0 0 0 644 3995 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: sqrtf .visible .func (.param .f32 %value_out) sqrtf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_sqrt.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_sqrtf .extern .func (.param .f32 %value_out) __ieee754_sqrtf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .extern .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {115,113,114,116,102,0 }; // BEGIN GLOBAL FUNCTION DEF: sqrtf .visible .func (.param .f32 %value_out) sqrtf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r32; .reg .f32 %r34; .reg .f32 %r35; .reg .f32 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .f64 %r48; .reg .f64 %r49; .reg .f64 %r50; .reg .pred %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r61; .reg .f64 %r62; mov.f32 %r35,%ar0; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__ieee754_sqrtf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r34,%r37; .loc 1 36 0 ld.global.u32 %r38,[__fdlib_version]; setp.eq.u32 %r39,%r38,-1; @ %r39 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r35; call (%value_in),__fpclassifyf,(%out_arg1); ld.param.u32 %r41,[%value_in]; } setp.eq.u32 %r42,%r41,0; @ %r42 bra $L1; .loc 1 37 0 setp.lt.f32 %r43,%r35,0f00000000; @ ! %r43 bra $L1; .loc 1 39 0 mov.u32 %r44,1; st.u32 [%frame],%r44; .loc 1 40 0 cvta.const.u64 %r45,$LC0; st.u64 [%frame+8],%r45; .loc 1 41 0 mov.u32 %r46,0; st.u32 [%frame+40],%r46; .loc 1 42 0 cvt.f64.f32 %r24,%r35; st.f64 [%frame+24],%r24; st.f64 [%frame+16],%r24; .loc 1 43 0 ld.global.u32 %r25,[__fdlib_version]; setp.ne.u32 %r47,%r25,0; @ %r47 bra $L4; .loc 1 44 0 mov.f64 %r48,0d0000000000000000; st.f64 [%frame+32],%r48; bra $L5; $L4: .loc 1 46 0 mov.f64 %r50,0d0000000000000000; div.rn.f64 %r49,%r50,0d0000000000000000; st.f64 [%frame+32],%r49; .loc 1 47 0 setp.ne.u32 %r51,%r25,2; @ %r51 bra $L5; .loc 1 48 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r52,[%value_in]; } mov.u32 %r53,33; st.u32 [%r52],%r53; bra $L6; $L5: .loc 1 49 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r55,[%value_in]; } setp.ne.u32 %r56,%r55,0; @ %r56 bra $L6; .loc 1 50 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r57,[%value_in]; } mov.u32 %r58,33; st.u32 [%r57],%r58; $L6: .loc 1 52 0 ld.u32 %r59,[%frame+40]; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L7; .loc 1 53 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r61,[%value_in]; } ld.u32 %r32,[%frame+40]; st.u32 [%r61],%r32; $L7: .loc 1 54 0 ld.f64 %r62,[%frame+32]; cvt.rn.f32.f64 %r34,%r62; $L1: .loc 1 58 0 mov.f32 %value,%r34; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1664 0 0 0 644 3807 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tgammaf .visible .func (.param .f32 %value_out) tgammaf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/math/wf_tgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .extern .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __kernel_standard .extern .func (.param .f64 %value_out) __kernel_standard (.param .f64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: tgammaf .visible .func (.param .f32 %value_out) tgammaf (.param .f32 %in_ar0) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r29; .reg .f32 %r30; .reg .f32 %r31; .reg .f32 %r34; .reg .u32 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r40; .reg .pred %r41; .reg .u32 %r43; .reg .pred %r44; .reg .f32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .u32 %r51; .reg .f64 %r52; .reg .u32 %r55; .reg .f64 %r56; mov.f32 %r31,%ar0; .loc 1 28 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__ieee754_gammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r34,[%value_in]; } mov.f32 %r30,%r34; .loc 1 29 0 ld.u32 %r35,[%frame]; setp.ge.s32 %r36,%r35,0; @ %r36 bra $L2; neg.f32 %r30,%r30; $L2: .loc 1 33 0 ld.global.u32 %r37,[__fdlib_version]; setp.eq.u32 %r38,%r37,-1; @ %r38 bra $L1; .loc 1 35 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r30; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r40,[%value_in]; } setp.ne.u32 %r41,%r40,0; @ %r41 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r43,[%value_in]; } setp.eq.u32 %r44,%r43,0; @ %r44 bra $L1; .loc 1 36 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r31; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r46,[%value_in]; } setp.neu.f32 %r47,%r46,%r31; @ %r47 bra $L4; cvt.f64.f32 %r29,%r31; setp.le.f32 %r48,%r31,0f00000000; @ ! %r48 bra $L5; .loc 1 38 0 mov.u32 %r51,141; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r51; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r52,[%value_in]; } cvt.rn.f32.f64 %r30,%r52; bra $L1; $L4: cvt.f64.f32 %r29,%r31; $L5: .loc 1 41 0 mov.u32 %r55,140; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r29; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r29; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r55; call (%value_in),__kernel_standard,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r56,[%value_in]; } cvt.rn.f32.f64 %r30,%r56; $L1: .loc 1 45 0 mov.f32 %value,%r30; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1683 0 0 0 644 5438 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gamma_r .visible .func (.param .f64 %value_out) gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wr_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gamma_r .extern .func (.param .f64 %value_out) __ieee754_gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: gamma_r .visible .func (.param .f64 %value_out) gamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .f64 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 35 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r39; call (%value_in),__ieee754_gamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r42,[%value_in]; } mov.f64 %r37,%r42; .loc 1 36 0 ld.global.u32 %r43,[__fdlib_version]; setp.eq.u32 %r44,%r43,-1; @ %r44 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),finite,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.ne.u32 %r47,%r46,0; @ %r47 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L1; .loc 1 44 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 45 0 st.u32 [%frame+40],%r46; .loc 1 46 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 47 0 ld.global.u32 %r53,[__fdlib_version]; setp.ne.u32 %r54,%r53,0; @ %r54 bra $L3; .loc 1 48 0 mov.f64 %r55,0d47efffffe0000000; st.f64 [%frame+32],%r55; bra $L4; $L3: .loc 1 50 0 mov.f64 %r56,0d7ff0000000000000; st.f64 [%frame+32],%r56; $L4: .loc 1 51 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),floor,(%out_arg1); ld.param.f64 %r58,[%value_in]; } setp.neu.f64 %r59,%r58,%r38; @ %r59 bra $L5; ld.global.u32 %r36,[__fdlib_version]; setp.le.f64 %r60,%r38,0d0000000000000000; @ ! %r60 bra $L6; .loc 1 53 0 mov.u32 %r61,2; st.u32 [%frame],%r61; .loc 1 54 0 setp.ne.u32 %r62,%r36,2; @ %r62 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.eq.u32 %r67,%r66,0; @ ! %r67 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L9; $L5: ld.global.u32 %r36,[__fdlib_version]; $L6: .loc 1 61 0 mov.u32 %r70,3; st.u32 [%frame],%r70; .loc 1 62 0 setp.ne.u32 %r71,%r36,2; @ %r71 bra $L11; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L9; $L11: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L9; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L9: .loc 1 68 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L13; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r81],%r35; $L13: .loc 1 70 0 ld.f64 %r37,[%frame+32]; $L1: .loc 1 74 0 mov.f64 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } /1701 0 0 0 644 5450 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgamma_r .visible .func (.param .f64 %value_out) lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wr_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgamma_r .extern .func (.param .f64 %value_out) __ieee754_lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floor .extern .func (.param .f64 %value_out) floor (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {108,103,97,109,109,97,0 }; // BEGIN GLOBAL FUNCTION DEF: lgamma_r .visible .func (.param .f64 %value_out) lgamma_r (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .u64 %r39; .reg .f64 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r46; .reg .pred %r47; .reg .u32 %r49; .reg .pred %r50; .reg .u64 %r51; .reg .u32 %r53; .reg .pred %r54; .reg .f64 %r55; .reg .f64 %r56; .reg .f64 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .pred %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u32 %r66; .reg .pred %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .pred %r80; .reg .u64 %r81; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 35 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r39; call (%value_in),__ieee754_lgamma_r,(%out_arg1,%out_arg2); ld.param.f64 %r42,[%value_in]; } mov.f64 %r37,%r42; .loc 1 36 0 ld.global.u32 %r43,[__fdlib_version]; setp.eq.u32 %r44,%r43,-1; @ %r44 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r42; call (%value_in),finite,(%out_arg1); ld.param.u32 %r46,[%value_in]; } setp.ne.u32 %r47,%r46,0; @ %r47 bra $L1; { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),finite,(%out_arg1); ld.param.u32 %r49,[%value_in]; } setp.eq.u32 %r50,%r49,0; @ %r50 bra $L1; .loc 1 44 0 cvta.const.u64 %r51,$LC0; st.u64 [%frame+8],%r51; .loc 1 45 0 st.u32 [%frame+40],%r46; .loc 1 46 0 st.f64 [%frame+24],%r38; st.f64 [%frame+16],%r38; .loc 1 47 0 ld.global.u32 %r53,[__fdlib_version]; setp.ne.u32 %r54,%r53,0; @ %r54 bra $L3; .loc 1 48 0 mov.f64 %r55,0d47efffffe0000000; st.f64 [%frame+32],%r55; bra $L4; $L3: .loc 1 50 0 mov.f64 %r56,0d7ff0000000000000; st.f64 [%frame+32],%r56; $L4: .loc 1 51 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r38; call (%value_in),floor,(%out_arg1); ld.param.f64 %r58,[%value_in]; } setp.neu.f64 %r59,%r58,%r38; @ %r59 bra $L5; ld.global.u32 %r36,[__fdlib_version]; setp.le.f64 %r60,%r38,0d0000000000000000; @ ! %r60 bra $L6; .loc 1 53 0 mov.u32 %r61,2; st.u32 [%frame],%r61; .loc 1 54 0 setp.ne.u32 %r62,%r36,2; @ %r62 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r63,[%value_in]; } mov.u32 %r64,33; st.u32 [%r63],%r64; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r66,[%value_in]; } setp.eq.u32 %r67,%r66,0; @ ! %r67 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r68,[%value_in]; } mov.u32 %r69,33; st.u32 [%r68],%r69; bra $L9; $L5: ld.global.u32 %r36,[__fdlib_version]; $L6: .loc 1 62 0 mov.u32 %r70,3; st.u32 [%frame],%r70; .loc 1 63 0 setp.ne.u32 %r71,%r36,2; @ %r71 bra $L11; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r72,[%value_in]; } mov.u32 %r73,34; st.u32 [%r72],%r73; bra $L9; $L11: .loc 1 65 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r75,[%value_in]; } setp.ne.u32 %r76,%r75,0; @ %r76 bra $L9; .loc 1 66 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r77,[%value_in]; } mov.u32 %r78,34; st.u32 [%r77],%r78; $L9: .loc 1 69 0 ld.u32 %r79,[%frame+40]; setp.eq.u32 %r80,%r79,0; @ %r80 bra $L13; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r81,[%value_in]; } ld.u32 %r35,[%frame+40]; st.u32 [%r81],%r35; $L13: .loc 1 71 0 ld.f64 %r37,[%frame+32]; $L1: .loc 1 75 0 mov.f64 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } /1720 0 0 0 644 5530 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: gammaf_r .visible .func (.param .f32 %value_out) gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wrf_gamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_gammaf_r .extern .func (.param .f32 %value_out) __ieee754_gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: gammaf_r .visible .func (.param .f32 %value_out) gammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r36; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .u64 %r41; .reg .f32 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f32 %r60; .reg .pred %r61; .reg .pred %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .f64 %r84; mov.f32 %r40,%ar0; mov.u64 %r41,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; call (%value_in),__ieee754_gammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } mov.f32 %r39,%r44; .loc 1 36 0 ld.global.u32 %r45,[__fdlib_version]; setp.eq.u32 %r46,%r45,-1; @ %r46 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.ne.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.eq.u32 %r52,%r51,0; @ %r52 bra $L1; .loc 1 44 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 45 0 st.u32 [%frame+40],%r48; .loc 1 46 0 cvt.f64.f32 %r25,%r40; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 47 0 ld.global.u32 %r55,[__fdlib_version]; setp.ne.u32 %r56,%r55,0; @ %r56 bra $L3; .loc 1 48 0 mov.f64 %r57,0d47efffffe0000000; st.f64 [%frame+32],%r57; bra $L4; $L3: .loc 1 50 0 mov.f64 %r58,0d7ff0000000000000; st.f64 [%frame+32],%r58; $L4: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r60,[%value_in]; } setp.neu.f32 %r61,%r60,%r40; @ %r61 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f32 %r62,%r40,0f00000000; @ ! %r62 bra $L6; .loc 1 53 0 mov.u32 %r63,2; st.u32 [%frame],%r63; .loc 1 54 0 setp.ne.u32 %r64,%r38,2; @ %r64 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.eq.u32 %r69,%r68,0; @ ! %r69 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 61 0 mov.u32 %r72,3; st.u32 [%frame],%r72; .loc 1 62 0 setp.ne.u32 %r73,%r38,2; @ %r73 bra $L11; .loc 1 63 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } mov.u32 %r75,34; st.u32 [%r74],%r75; bra $L9; $L11: .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r77,[%value_in]; } setp.ne.u32 %r78,%r77,0; @ %r78 bra $L9; .loc 1 65 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } mov.u32 %r80,34; st.u32 [%r79],%r80; $L9: .loc 1 68 0 ld.u32 %r81,[%frame+40]; setp.eq.u32 %r82,%r81,0; @ %r82 bra $L13; .loc 1 69 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } ld.u32 %r36,[%frame+40]; st.u32 [%r83],%r36; $L13: .loc 1 70 0 ld.f64 %r84,[%frame+32]; cvt.rn.f32.f64 %r39,%r84; $L1: .loc 1 74 0 mov.f32 %value,%r39; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } /1739 0 0 0 644 5542 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: lgammaf_r .visible .func (.param .f32 %value_out) lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/wrf_lgamma.c" // BEGIN GLOBAL VAR DECL: __fdlib_version .extern .global .align 4 .u32 __fdlib_version[1]; // BEGIN GLOBAL FUNCTION DECL: __ieee754_lgammaf_r .extern .func (.param .f32 %value_out) __ieee754_lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: floorf .extern .func (.param .f32 %value_out) floorf (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: matherr .extern .func (.param .u32 %value_out) matherr (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {108,103,97,109,109,97,102,0 }; // BEGIN GLOBAL FUNCTION DEF: lgammaf_r .visible .func (.param .f32 %value_out) lgammaf_r (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,48; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r25; .reg .u32 %r36; .reg .u32 %r38; .reg .f32 %r39; .reg .f32 %r40; .reg .u64 %r41; .reg .f32 %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r48; .reg .pred %r49; .reg .u32 %r51; .reg .pred %r52; .reg .u64 %r53; .reg .u32 %r55; .reg .pred %r56; .reg .f64 %r57; .reg .f64 %r58; .reg .f32 %r60; .reg .pred %r61; .reg .pred %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; .reg .u32 %r68; .reg .pred %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .pred %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .f64 %r84; mov.f32 %r40,%ar0; mov.u64 %r41,%ar1; .loc 1 35 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r41; call (%value_in),__ieee754_lgammaf_r,(%out_arg1,%out_arg2); ld.param.f32 %r44,[%value_in]; } mov.f32 %r39,%r44; .loc 1 36 0 ld.global.u32 %r45,[__fdlib_version]; setp.eq.u32 %r46,%r45,-1; @ %r46 bra $L1; .loc 1 37 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r44; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r48,[%value_in]; } setp.ne.u32 %r49,%r48,0; @ %r49 bra $L1; { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r51,[%value_in]; } setp.eq.u32 %r52,%r51,0; @ %r52 bra $L1; .loc 1 44 0 cvta.const.u64 %r53,$LC0; st.u64 [%frame+8],%r53; .loc 1 45 0 st.u32 [%frame+40],%r48; .loc 1 46 0 cvt.f64.f32 %r25,%r40; st.f64 [%frame+24],%r25; st.f64 [%frame+16],%r25; .loc 1 47 0 ld.global.u32 %r55,[__fdlib_version]; setp.ne.u32 %r56,%r55,0; @ %r56 bra $L3; .loc 1 48 0 mov.f64 %r57,0d47efffffe0000000; st.f64 [%frame+32],%r57; bra $L4; $L3: .loc 1 50 0 mov.f64 %r58,0d7ff0000000000000; st.f64 [%frame+32],%r58; $L4: .loc 1 51 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r40; call (%value_in),floorf,(%out_arg1); ld.param.f32 %r60,[%value_in]; } setp.neu.f32 %r61,%r60,%r40; @ %r61 bra $L5; ld.global.u32 %r38,[__fdlib_version]; setp.le.f32 %r62,%r40,0f00000000; @ ! %r62 bra $L6; .loc 1 53 0 mov.u32 %r63,2; st.u32 [%frame],%r63; .loc 1 54 0 setp.ne.u32 %r64,%r38,2; @ %r64 bra $L8; .loc 1 55 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,33; st.u32 [%r65],%r66; bra $L9; $L8: .loc 1 56 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r68,[%value_in]; } setp.eq.u32 %r69,%r68,0; @ ! %r69 bra $L9; .loc 1 57 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r70,[%value_in]; } mov.u32 %r71,33; st.u32 [%r70],%r71; bra $L9; $L5: ld.global.u32 %r38,[__fdlib_version]; $L6: .loc 1 62 0 mov.u32 %r72,3; st.u32 [%frame],%r72; .loc 1 63 0 setp.ne.u32 %r73,%r38,2; @ %r73 bra $L11; .loc 1 64 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r74,[%value_in]; } mov.u32 %r75,34; st.u32 [%r74],%r75; bra $L9; $L11: .loc 1 65 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),matherr,(%out_arg1); ld.param.u32 %r77,[%value_in]; } setp.ne.u32 %r78,%r77,0; @ %r78 bra $L9; .loc 1 66 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r79,[%value_in]; } mov.u32 %r80,34; st.u32 [%r79],%r80; $L9: .loc 1 69 0 ld.u32 %r81,[%frame+40]; setp.eq.u32 %r82,%r81,0; @ %r82 bra $L13; .loc 1 70 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r83,[%value_in]; } ld.u32 %r36,[%frame+40]; st.u32 [%r83],%r36; $L13: .loc 1 71 0 ld.f64 %r84,[%frame+32]; cvt.rn.f32.f64 %r39,%r84; $L1: .loc 1 75 0 mov.f32 %value,%r39; st.shared.u64 [%sspslot],%sspprev; st.param.f32 [%value_out],%value; ret; } 0707010000006d000081a40000000000000000000000026181424300000000000000000000000000000000000000000000001c00000000./usr/nvptx-none/lib/libc.a0707010000006d000081a400000000000000000000000261814243001109d0000000000000000000000000000000000000001c00000000./usr/nvptx-none/lib/libg.a! // 958 ` lib_a-dtoastub.o/ lib_a-fix_grouping.o/ lib_a-gdtoa-gethex.o/ lib_a-gdtoa-hexnan.o/ lib_a-isxdigit.o/ lib_a-lmessages.o/ lib_a-lmonetary.o/ lib_a-lnumeric.o/ lib_a-nl_langinfo.o/ lib_a-rawmemchr.o/ lib_a-reallocr.o/ lib_a-s_copysign.o/ lib_a-s_finite.o/ lib_a-s_fpclassify.o/ lib_a-s_infconst.o/ lib_a-s_isinfd.o/ lib_a-s_isnand.o/ lib_a-s_scalbn.o/ lib_a-sf_copysign.o/ lib_a-sf_finite.o/ lib_a-sf_fpclassify.o/ lib_a-sf_frexp.o/ lib_a-sf_isinf.o/ lib_a-sf_isinff.o/ lib_a-sf_isnan.o/ lib_a-sf_isnanf.o/ lib_a-sf_ldexp.o/ lib_a-sf_scalbn.o/ lib_a-siprintf.o/ lib_a-snprintf.o/ lib_a-strcasecmp.o/ lib_a-strcasestr.o/ lib_a-strchrnul.o/ lib_a-strdup_r.o/ lib_a-strerror.o/ lib_a-strerror_r.o/ lib_a-strncasecmp.o/ lib_a-strndup_r.o/ lib_a-strsignal.o/ lib_a-strtok_r.o/ lib_a-strtoll_r.o/ lib_a-strtoull.o/ lib_a-strtoull_r.o/ lib_a-svfiprintf.o/ lib_a-svfprintf.o/ lib_a-timelocal.o/ lib_a-u_strerr.o/ lib_a-vfprintf.o/ lib_a-vsnprintf.o/ lib_a-vsprintf.o/ lib_a-a64l.o/ 0 0 0 644 2579 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: a64l .visible .func (.param .u64 %value_out) a64l (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/a64l.c" // BEGIN GLOBAL FUNCTION DEF: a64l .visible .func (.param .u64 %value_out) a64l (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r54; .reg .u64 %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u64 %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .pred %r67; .reg .u16 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .u16 %r73; .reg .pred %r74; .reg .pred %r76; .reg .pred %r78; .reg .pred %r80; .reg .pred %r82; .reg .u16 %r83; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .u64 %r92; .reg .pred %r93; .reg .u64 %r95; .reg .u16 %r96; .reg .u64 %r97; mov.u64 %r66,%ar0; .loc 1 75 0 setp.eq.u64 %r67,%r66,0; @ %r67 bra $L14; mov.u64 %r57,%r66; mov.u32 %r64,6; $L4: .loc 1 84 0 ld.s8 %r69,[%r57]; cvt.u16.u32 %r68,%r69; setp.eq.u16 %r70,%r68,0; @ %r70 bra $L3; .loc 1 85 0 add.u64 %r57,%r57,1; $L3: add.u32 %r64,%r64,-1; .loc 1 82 0 setp.ne.u32 %r71,%r64,0; @ %r71 bra $L4; .loc 1 88 0 setp.le.u64 %r72,%r57,%r66; @ %r72 bra $L15; .loc 1 73 0 mov.u64 %r58,0; .loc 1 104 0 mov.u64 %r95,%r58; mov.u16 %r96,25; mov.u64 %r97,1; $L12: .loc 1 90 0 add.u64 %r57,%r57,-1; ld.s8 %r59,[%r57]; .loc 1 104 0 cvt.u16.u32 %r73,%r59; setp.gt.s16 %r74,%r73,90; @ %r74 bra $L7; setp.ge.s16 %r76,%r73,65; @ %r76 bra $L8; setp.eq.u16 %r78,%r73,47; @ %r78 bra $L9; setp.lt.s16 %r80,%r73,47; @ %r80 bra $L16; setp.gt.s16 %r82,%r73,57; @ ! %r82 bra $L22; bra $L16; $L7: add.u16 %r83,%r73,-97; setp.gt.u16 %r87,%r83,%r96; @ ! %r87 bra $L23; bra $L16; $L9: mov.u64 %r63,%r97; bra $L6; $L22: .loc 1 119 0 add.u32 %r88,%r59,-46; cvt.s64.s32 %r63,%r88; .loc 1 120 0 bra $L6; $L8: .loc 1 147 0 add.u32 %r89,%r59,-53; cvt.s64.s32 %r63,%r89; .loc 1 148 0 bra $L6; $L23: .loc 1 175 0 add.u32 %r90,%r59,-59; cvt.s64.s32 %r63,%r90; .loc 1 176 0 bra $L6; $L16: .loc 1 104 0 mov.u64 %r63,%r95; $L6: .loc 1 183 0 shl.b64 %r54,%r58,6; add.u64 %r58,%r54,%r63; .loc 1 88 0 setp.ne.u64 %r91,%r66,%r57; @ %r91 bra $L12; .loc 1 188 0 and.b64 %r92,%r58,2147483648; setp.ne.u64 %r93,%r92,0; @ %r93 bra $L13; mov.u64 %r65,%r58; bra $L1; $L13: .loc 1 189 0 add.u64 %r65,%r58,-4294967296; bra $L1; $L15: .loc 1 88 0 mov.u64 %r65,0; .loc 1 192 0 bra $L1; $L14: .loc 1 76 0 mov.u64 %r65,%r66; $L1: .loc 1 193 0 mov.u64 %value,%r65; st.param.u64 [%value_out],%value; ret; } lib_a-abort.o/ 0 0 0 644 375 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: abort .visible .func abort; .file 1 "../../../../../../newlib/libc/machine/nvptx/abort.c" // BEGIN GLOBAL FUNCTION DEF: abort .visible .func abort { $L2: .loc 1 24 0 // #APP // 24 "../../../../../../newlib/libc/machine/nvptx/abort.c" 1 exit; // #NO_APP bra $L2; } lib_a-abs.o/ 0 0 0 644 516 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: abs .visible .func (.param .u32 %value_out) abs (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/abs.c" // BEGIN GLOBAL FUNCTION DEF: abs .visible .func (.param .u32 %value_out) abs (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r23; mov.u32 %r23,%ar0; .loc 1 42 0 abs.s32 %value,%r23; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-assert.o/ 0 0 0 644 1182 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __assert_func .visible .func __assert_func (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdlib/assert.c" // BEGIN GLOBAL FUNCTION DECL: __assert .visible .func __assert (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: abort .extern .func abort; // BEGIN GLOBAL FUNCTION DEF: __assert_func .visible .func __assert_func (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .loc 1 65 0 { call abort; trap; // (noreturn) } } // BEGIN GLOBAL FUNCTION DEF: __assert .visible .func __assert (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .loc 1 65 0 { call abort; trap; // (noreturn) } } lib_a-atof.o/ 0 0 0 644 910 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atof .visible .func (.param .f64 %value_out) atof (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/atof.c" // BEGIN GLOBAL FUNCTION DECL: strtod .extern .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atof .visible .func (.param .f64 %value_out) atof (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .f64 %r26; mov.u64 %r23,%ar0; .loc 1 71 0 mov.u64 %r25,0; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),strtod,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 72 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } lib_a-atoff.o/ 0 0 0 644 913 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atoff .visible .func (.param .f32 %value_out) atoff (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/atoff.c" // BEGIN GLOBAL FUNCTION DECL: strtof .extern .func (.param .f32 %value_out) strtof (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atoff .visible .func (.param .f32 %value_out) atoff (.param .u64 %in_ar0) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .f32 %r26; mov.u64 %r23,%ar0; .loc 1 8 0 mov.u64 %r25,0; { .param .f32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),strtof,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 9 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } lib_a-atoi.o/ 0 0 0 644 2163 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atoi .visible .func (.param .u32 %value_out) atoi (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/atoi.c" // BEGIN GLOBAL FUNCTION DECL: _atoi_r .visible .func (.param .u32 %value_out) _atoi_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtol .extern .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _strtol_r .extern .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: atoi .visible .func (.param .u32 %value_out) atoi (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r26; .reg .u32 %r27; .reg .u64 %r28; mov.u64 %r24,%ar0; .loc 1 70 0 mov.u32 %r27,10; mov.u64 %r26,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r27; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r28,[%value_in]; } .loc 1 71 0 cvt.u32.u64 %value,%r28; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _atoi_r .visible .func (.param .u32 %value_out) _atoi_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r28; .reg .u32 %r29; .reg .u64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 79 0 mov.u32 %r29,10; mov.u64 %r28,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r29; call (%value_in),_strtol_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 80 0 cvt.u32.u64 %value,%r30; st.param.u32 [%value_out],%value; ret; } lib_a-atol.o/ 0 0 0 644 2155 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atol .visible .func (.param .u64 %value_out) atol (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/atol.c" // BEGIN GLOBAL FUNCTION DECL: _atol_r .visible .func (.param .u64 %value_out) _atol_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtol .extern .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _strtol_r .extern .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: atol .visible .func (.param .u64 %value_out) atol (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r27; mov.u64 %r23,%ar0; .loc 1 12 0 mov.u32 %r26,10; mov.u64 %r25,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r26; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r27,[%value_in]; } .loc 1 13 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _atol_r .visible .func (.param .u64 %value_out) _atol_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r27; .reg .u32 %r28; .reg .u64 %r29; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 19 0 mov.u32 %r28,10; mov.u64 %r27,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r28; call (%value_in),_strtol_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r29,[%value_in]; } .loc 1 20 0 mov.u64 %value,%r29; st.param.u64 [%value_out],%value; ret; } lib_a-atoll.o/ 0 0 0 644 2170 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atoll .visible .func (.param .u64 %value_out) atoll (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/atoll.c" // BEGIN GLOBAL FUNCTION DECL: _atoll_r .visible .func (.param .u64 %value_out) _atoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtoll .extern .func (.param .u64 %value_out) strtoll (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _strtoll_r .extern .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: atoll .visible .func (.param .u64 %value_out) atoll (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r27; mov.u64 %r23,%ar0; .loc 1 84 0 mov.u32 %r26,10; mov.u64 %r25,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r26; call (%value_in),strtoll,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r27,[%value_in]; } .loc 1 85 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _atoll_r .visible .func (.param .u64 %value_out) _atoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r27; .reg .u32 %r28; .reg .u64 %r29; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 93 0 mov.u32 %r28,10; mov.u64 %r27,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r28; call (%value_in),_strtoll_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r29,[%value_in]; } .loc 1 94 0 mov.u64 %value,%r29; st.param.u64 [%value_out],%value; ret; } lib_a-bcmp.o/ 0 0 0 644 1207 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: bcmp .visible .func (.param .u32 %value_out) bcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/bcmp.c" // BEGIN GLOBAL FUNCTION DECL: memcmp .extern .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: bcmp .visible .func (.param .u32 %value_out) bcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r29; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 48 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r29,[%value_in]; } .loc 1 49 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } lib_a-bcopy.o/ 0 0 0 644 1092 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: bcopy .visible .func bcopy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/bcopy.c" // BEGIN GLOBAL FUNCTION DECL: memmove .extern .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: bcopy .visible .func bcopy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r28; mov.u64 %r22,%ar0; mov.u64 %r23,%ar1; mov.u64 %r24,%ar2; .loc 1 38 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r22; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r24; call (%value_in),memmove,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r28,[%value_in]; } .loc 1 39 0 ret; } lib_a-btowc.o/ 0 0 0 644 2687 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: btowc .visible .func (.param .u32 %value_out) btowc (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/btowc.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __mbtowc .extern .global .align 8 .u64 __mbtowc[1]; // BEGIN GLOBAL FUNCTION DECL: memset .extern .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __locale_charset .extern .func (.param .u64 %value_out) __locale_charset; // BEGIN GLOBAL FUNCTION DEF: btowc .visible .func (.param .u32 %value_out) btowc (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r23; .reg .u32 %r29; .reg .u32 %r30; .reg .pred %r31; .reg .u32 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; mov.u32 %r30,%ar0; .loc 1 16 0 setp.ne.u32 %r31,%r30,-1; @ %r31 bra $L2; $L4: .loc 1 17 0 mov.u32 %r29,-1; bra $L1; $L2: .loc 1 19 0 st.u8 [%frame+12],%r30; .loc 1 22 0 mov.u64 %r34,8; mov.u32 %r33,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r34; call (%value_in),memset,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r35,[%value_in]; } .loc 1 26 0 ld.global.u64 %r23,[__mbtowc]; .loc 1 27 0 { .param .u64 %value_in; call (%value_in),__locale_charset; ld.param.u64 %r36,[%value_in]; } .loc 1 26 0 add.u64 %r43,%frame,12; add.u64 %r44,%frame,8; ld.global.u64 %r45,[_impure_ptr]; mov.u64 %r40,1; { .param .u32 %value_in; $LCT0: .callprototype ( .param .u32 %value_out) _ ( .param .u64 %in_ar0,.param .u64 %in_ar1,.param .u64 %in_ar2,.param .u64 %in_ar3,.param .u64 %in_ar4,.param .u64 %in_ar5); .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r45; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r44; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r43; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r40; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r36; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%frame; call (%value_in),%r23,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6),$LCT0; ld.param.u32 %r46,[%value_in]; } .loc 1 29 0 setp.gt.u32 %r47,%r46,1; @ %r47 bra $L4; .loc 1 32 0 ld.u32 %r29,[%frame+8]; $L1: .loc 1 33 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } lib_a-bzero.o/ 0 0 0 644 825 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: bzero .visible .func bzero (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/bzero.c" // BEGIN GLOBAL FUNCTION DEF: bzero .visible .func bzero (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r52; .reg .u64 %r53; .reg .pred %r54; .reg .u32 %r55; .reg .pred %r56; mov.u64 %r52,%ar0; mov.u64 %r53,%ar1; .loc 1 41 0 setp.eq.u64 %r54,%r53,0; @ %r54 bra $L1; mov.u64 %r49,%r52; add.u64 %r50,%r49,%r53; .loc 1 42 0 mov.u32 %r55,0; $L3: st.u8 [%r49],%r55; add.u64 %r49,%r49,1; .loc 1 41 0 setp.ne.u64 %r56,%r49,%r50; @ %r56 bra $L3; $L1: .loc 1 43 0 ret; } lib_a-calloc.o/ 0 0 0 644 1617 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: calloc .visible .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/machine/nvptx/calloc.c" // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: memset .extern .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: calloc .visible .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r27; .reg .u64 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .u64 %r33; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 22 0 mul.lo.u64 %r27,%r24,%r25; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r28,[%value_in]; } mov.u64 %r23,%r28; .loc 1 23 0 setp.eq.u64 %r29,%r23,0; @ %r29 bra $L1; .loc 1 25 0 mov.u32 %r31,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r31; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),memset,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r33,[%value_in]; } mov.u64 %r23,%r33; $L1: .loc 1 26 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-callocr.o/0 0 0 644 1120 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _calloc_r .visible .func (.param .u64 %value_out) _calloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/machine/nvptx/callocr.c" // BEGIN GLOBAL FUNCTION DECL: calloc .extern .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _calloc_r .visible .func (.param .u64 %value_out) _calloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r28; mov.u64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 21 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),calloc,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } .loc 1 22 0 mov.u64 %value,%r28; st.param.u64 [%value_out],%value; ret; } lib_a-ctype_.o/ 0 0 0 644 1783 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN VAR DEF: _ctype_b .const .align 1 .u8 _ctype_b[384] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,32,32,32,32,32,32,32,32,32,40,40,40,40,40,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,136,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,4,4,4,4,4,4,4,4,4,4,16,16,16,16,16,16,16,65,65,65,65,65,65,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,16,16,16,16,16,16,66,66,66,66,66,66,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,16,16,16,16,32,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: _ctype_ .visible .const .align 1 .u8 _ctype_[257] = {0,32,32,32,32,32,32,32,32,32,40,40,40,40,40,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,136,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,4,4,4,4,4,4,4,4,4,4,16,16,16,16,16,16,16,65,65,65,65,65,65,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,16,16,16,16,16,16,66,66,66,66,66,66,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,16,16,16,16,32,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // BEGIN GLOBAL VAR DEF: __ctype_ptr__ .visible .global .align 8 .u64 __ctype_ptr__[1] = {generic(_ctype_b) + 127 }; lib_a-div.o/ 0 0 0 644 1147 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: div .visible .func div (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libc/stdlib/div.c" // BEGIN GLOBAL FUNCTION DEF: div .visible .func div (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r22; .reg .u32 %r23; .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 95 0 div.s32 %r22,%r25,%r26; .loc 1 96 0 rem.s32 %r23,%r25,%r26; .loc 1 123 0 setp.lt.s32 %r27,%r25,0; @ %r27 bra $L2; setp.ge.s32 %r28,%r23,0; @ %r28 bra $L3; .loc 1 124 0 add.u32 %r22,%r22,1; .loc 1 125 0 sub.u32 %r23,%r23,%r26; bra $L3; $L2: .loc 1 127 0 setp.le.s32 %r29,%r23,0; @ %r29 bra $L3; .loc 1 128 0 add.u32 %r22,%r22,-1; .loc 1 129 0 add.u32 %r23,%r23,%r26; $L3: .loc 1 131 0 st.u32 [%r24],%r22; st.u32 [%r24+4],%r23; .loc 1 132 0 ret; } lib_a-drand48.o/0 0 0 644 1654 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _drand48_r .visible .func (.param .f64 %value_out) _drand48_r (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/drand48.c" // BEGIN GLOBAL FUNCTION DECL: drand48 .visible .func (.param .f64 %value_out) drand48; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _erand48_r .extern .func (.param .f64 %value_out) _erand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _drand48_r .visible .func (.param .f64 %value_out) _drand48_r (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r27; .reg .f64 %r28; mov.u64 %r24,%ar0; .loc 1 21 0 add.u64 %r27,%r24,240; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; call (%value_in),_erand48_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } .loc 1 22 0 mov.f64 %value,%r28; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: drand48 .visible .func (.param .f64 %value_out) drand48 { .reg .f64 %value; .reg .u64 %r22; .reg .u64 %r27; .reg .f64 %r28; .loc 1 28 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 21 0 add.u64 %r27,%r22,240; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r22; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; call (%value_in),_erand48_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } .loc 1 29 0 mov.f64 %value,%r28; st.param.f64 [%value_out],%value; ret; } lib_a-dtoa.o/ 0 0 0 644 58898 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: quorem .func (.param .u32 %value_out) quorem (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/dtoa.c" // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .visible .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL VAR DECL: __mprec_bigtens .extern .const .align 8 .u64 __mprec_bigtens[5]; // BEGIN GLOBAL VAR DECL: __mprec_tens .extern .const .align 8 .u64 __mprec_tens[25]; // BEGIN GLOBAL FUNCTION DECL: __mcmp .extern .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __d2b .extern .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __i2b .extern .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __pow5mult .extern .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __multiply .extern .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __hi0bits .extern .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __lshift .extern .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __multadd .extern .func (.param .u64 %value_out) __multadd (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mdiff .extern .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[9] = {73,110,102,105,110,105,116,121,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {78,97,78,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[2] = {48,0 }; // BEGIN FUNCTION DEF: quorem .func (.param .u32 %value_out) quorem (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r57; .reg .u32 %r66; .reg .u32 %r85; .reg .u32 %r102; .reg .u32 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .u32 %r117; .reg .u64 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u32 %r125; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r136; .reg .u64 %r137; .reg .u32 %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .pred %r142; .reg .u64 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .u32 %r146; .reg .pred %r147; .reg .u32 %r148; .reg .u32 %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .u32 %r162; .reg .pred %r163; .reg .u32 %r164; .reg .pred %r165; .reg .pred %r166; .reg .u32 %r167; .reg .pred %r168; .reg .pred %r169; .reg .u32 %r170; .reg .pred %r171; .reg .u32 %r174; .reg .pred %r175; .reg .u32 %r176; .reg .u32 %r177; .reg .u32 %r178; .reg .u32 %r179; .reg .u32 %r180; .reg .u32 %r181; .reg .u32 %r182; .reg .u32 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .pred %r186; .reg .u64 %r187; .reg .u64 %r188; .reg .u32 %r189; .reg .pred %r190; .reg .pred %r191; .reg .u32 %r192; .reg .pred %r193; .reg .pred %r194; .reg .u32 %r195; .reg .pred %r196; mov.u64 %r139,%ar0; mov.u64 %r140,%ar1; .loc 1 49 0 ld.u32 %r107,[%r140+20]; .loc 1 54 0 ld.u32 %r141,[%r139+20]; setp.lt.s32 %r142,%r141,%r107; @ %r142 bra $L11; .loc 1 56 0 add.u64 %r108,%r140,24; .loc 1 57 0 add.u32 %r125,%r107,-1; cvt.s64.s32 %r143,%r125; shl.b64 %r57,%r143,2; add.u64 %r109,%r108,%r57; .loc 1 58 0 add.u64 %r110,%r139,24; .loc 1 59 0 add.u64 %r111,%r110,%r57; .loc 1 60 0 ld.u32 %r145,[%r109]; add.u32 %r144,%r145,1; ld.u32 %r146,[%r111]; div.u32 %r105,%r146,%r144; .loc 1 65 0 setp.eq.u32 %r147,%r105,0; @ %r147 bra $L3; mov.u64 %r132,%r110; mov.u64 %r131,%r108; .loc 1 68 0 mov.u32 %r104,0; .loc 1 67 0 mov.u32 %r102,%r104; $L4: .loc 1 72 0 ld.u32 %r112,[%r131]; .loc 1 73 0 and.b32 %r148,%r112,65535; mad.lo.u32 %r113,%r148,%r105,%r104; .loc 1 74 0 shr.u32 %r150,%r112,16; shr.u32 %r152,%r113,16; mad.lo.u32 %r114,%r150,%r105,%r152; .loc 1 75 0 shr.u32 %r104,%r114,16; .loc 1 76 0 ld.u32 %r66,[%r132]; and.b32 %r153,%r66,65535; add.u32 %r154,%r153,%r102; and.b32 %r155,%r113,65535; sub.u32 %r115,%r154,%r155; .loc 1 79 0 shr.u32 %r156,%r66,16; and.b32 %r157,%r114,65535; sub.u32 %r158,%r156,%r157; .loc 1 77 0 shr.s32 %r159,%r115,16; .loc 1 79 0 add.u32 %r117,%r158,%r159; .loc 1 80 0 shr.s32 %r102,%r117,16; .loc 1 82 0 shl.b32 %r160,%r117,16; and.b32 %r161,%r115,65535; or.b32 %r162,%r160,%r161; st.u32 [%r132],%r162; add.u64 %r132,%r132,4; add.u64 %r131,%r131,4; .loc 1 92 0 setp.ge.u64 %r163,%r109,%r131; @ %r163 bra $L4; .loc 1 93 0 ld.u32 %r164,[%r111]; setp.ne.u32 %r165,%r164,0; @ %r165 bra $L3; .loc 1 96 0 add.u64 %r118,%r111,-4; setp.ge.u64 %r166,%r110,%r118; @ %r166 bra $L5; ld.u32 %r167,[%r111+-4]; setp.ne.u32 %r168,%r167,0; @ %r168 bra $L5; $L6: .loc 1 97 0 add.u32 %r125,%r125,-1; .loc 1 96 0 add.u64 %r118,%r118,-4; setp.ge.u64 %r169,%r110,%r118; @ %r169 bra $L5; ld.u32 %r170,[%r118]; setp.eq.u32 %r171,%r170,0; @ %r171 bra $L6; $L5: .loc 1 98 0 st.u32 [%r139+20],%r125; $L3: .loc 1 101 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r139; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r140; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r174,[%value_in]; } setp.lt.s32 %r175,%r174,0; @ %r175 bra $L7; .loc 1 103 0 add.u32 %r105,%r105,1; mov.u64 %r137,%r110; mov.u64 %r136,%r108; .loc 1 104 0 mov.u32 %r103,0; $L8: .loc 1 111 0 ld.u32 %r119,[%r136]; .loc 1 115 0 ld.u32 %r85,[%r137]; and.b32 %r176,%r85,65535; add.u32 %r177,%r176,%r103; .loc 1 112 0 and.b32 %r178,%r119,65535; .loc 1 115 0 sub.u32 %r120,%r177,%r178; .loc 1 118 0 shr.u32 %r179,%r85,16; .loc 1 113 0 shr.u32 %r180,%r119,16; .loc 1 118 0 sub.u32 %r181,%r179,%r180; .loc 1 116 0 shr.s32 %r182,%r120,16; .loc 1 118 0 add.u32 %r122,%r181,%r182; .loc 1 119 0 shr.s32 %r103,%r122,16; .loc 1 121 0 shl.b32 %r183,%r122,16; and.b32 %r184,%r120,65535; or.b32 %r185,%r183,%r184; st.u32 [%r137],%r185; add.u64 %r137,%r137,4; add.u64 %r136,%r136,4; .loc 1 131 0 setp.ge.u64 %r186,%r109,%r136; @ %r186 bra $L8; .loc 1 133 0 cvt.s64.s32 %r187,%r125; shl.b64 %r188,%r187,2; add.u64 %r123,%r110,%r188; .loc 1 134 0 ld.u32 %r189,[%r123]; setp.ne.u32 %r190,%r189,0; @ %r190 bra $L7; .loc 1 136 0 add.u64 %r124,%r123,-4; setp.ge.u64 %r191,%r110,%r124; @ %r191 bra $L9; ld.u32 %r192,[%r123+-4]; setp.ne.u32 %r193,%r192,0; @ %r193 bra $L9; $L10: .loc 1 137 0 add.u32 %r125,%r125,-1; .loc 1 136 0 add.u64 %r124,%r124,-4; setp.ge.u64 %r194,%r110,%r124; @ %r194 bra $L9; ld.u32 %r195,[%r124]; setp.eq.u32 %r196,%r195,0; @ %r196 bra $L10; $L9: .loc 1 138 0 st.u32 [%r139+20],%r125; $L7: .loc 1 141 0 mov.u32 %r138,%r105; bra $L1; $L11: .loc 1 55 0 mov.u32 %r138,0; $L1: .loc 1 142 0 mov.u32 %value,%r138; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _dtoa_r .visible .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u64 %ar6; ld.param.u64 %ar6,[%in_ar6]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r178; .reg .u32 %r179; .reg .u32 %r186; .reg .u32 %r191; .reg .f64 %r197; .reg .u64 %r204; .reg .u32 %r209; .reg .u32 %r211; .reg .u64 %r214; .reg .f64 %r215; .reg .f64 %r220; .reg .u64 %r229; .reg .f64 %r230; .reg .f64 %r232; .reg .f64 %r233; .reg .f64 %r236; .reg .f64 %r241; .reg .f64 %r242; .reg .f64 %r243; .reg .f64 %r245; .reg .f64 %r250; .reg .u32 %r252; .reg .f64 %r253; .reg .u32 %r254; .reg .u64 %r262; .reg .f64 %r263; .reg .f64 %r267; .reg .u32 %r287; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .u32 %r323; .reg .u32 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r327; .reg .u32 %r328; .reg .u32 %r330; .reg .u32 %r332; .reg .u32 %r333; .reg .u32 %r334; .reg .u32 %r335; .reg .u32 %r336; .reg .u32 %r337; .reg .u32 %r338; .reg .u32 %r339; .reg .u32 %r340; .reg .u64 %r342; .reg .u64 %r343; .reg .u64 %r344; .reg .f64 %r345; .reg .f64 %r346; .reg .u64 %r347; .reg .u64 %r349; .reg .u64 %r350; .reg .u32 %r351; .reg .u32 %r352; .reg .u32 %r353; .reg .u32 %r355; .reg .u64 %r356; .reg .u32 %r357; .reg .f64 %r358; .reg .u32 %r359; .reg .u32 %r363; .reg .u32 %r364; .reg .u32 %r366; .reg .u32 %r368; .reg .u64 %r369; .reg .u32 %r370; .reg .f64 %r371; .reg .u32 %r372; .reg .u32 %r373; .reg .u32 %r375; .reg .u32 %r376; .reg .u32 %r377; .reg .u64 %r379; .reg .u32 %r380; .reg .u32 %r381; .reg .u32 %r382; .reg .u32 %r391; .reg .u64 %r393; .reg .u64 %r395; .reg .u64 %r396; .reg .u64 %r398; .reg .u64 %r402; .reg .u64 %r403; .reg .u64 %r409; .reg .u64 %r412; .reg .u64 %r417; .reg .u64 %r421; .reg .u64 %r424; .reg .u64 %r425; .reg .u64 %r431; .reg .f64 %r436; .reg .f64 %r440; .reg .u64 %r446; .reg .u32 %r448; .reg .u64 %r449; .reg .u32 %r451; .reg .u64 %r452; .reg .u32 %r454; .reg .u32 %r455; .reg .u32 %r456; .reg .u32 %r457; .reg .u32 %r459; .reg .u32 %r460; .reg .u32 %r461; .reg .f64 %r465; .reg .u32 %r466; .reg .f64 %r468; .reg .f64 %r470; .reg .u32 %r475; .reg .u32 %r476; .reg .u64 %r481; .reg .u64 %r482; .reg .u64 %r483; .reg .u64 %r484; .reg .u64 %r485; .reg .f64 %r486; .reg .u32 %r487; .reg .u32 %r488; .reg .u64 %r489; .reg .u64 %r490; .reg .u64 %r491; .reg .pred %r492; .reg .u32 %r493; .reg .u32 %r494; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r499; .reg .pred %r500; .reg .u32 %r501; .reg .u64 %r502; .reg .u64 %r503; .reg .u64 %r504; .reg .u32 %r506; .reg .u32 %r507; .reg .pred %r508; .reg .u32 %r509; .reg .u64 %r510; .reg .u64 %r511; .reg .pred %r512; .reg .pred %r513; .reg .u32 %r514; .reg .pred %r515; .reg .u64 %r516; .reg .u64 %r521; .reg .u64 %r522; .reg .pred %r523; .reg .u64 %r525; .reg .u32 %r526; .reg .u32 %r527; .reg .u32 %r528; .reg .u64 %r529; .reg .u64 %r530; .reg .u64 %r531; .reg .u32 %r533; .reg .pred %r534; .reg .u32 %r535; .reg .u32 %r536; .reg .u32 %r537; .reg .u32 %r538; .reg .u32 %r539; .reg .u32 %r540; .reg .u32 %r541; .reg .u64 %r543; .reg .u32 %r544; .reg .u32 %r545; .reg .u64 %r546; .reg .u64 %r547; .reg .u64 %r548; .reg .f64 %r550; .reg .f64 %r551; .reg .f64 %r552; .reg .f64 %r553; .reg .f64 %r554; .reg .pred %r555; .reg .f64 %r556; .reg .pred %r557; .reg .pred %r558; .reg .u64 %r559; .reg .u64 %r560; .reg .u64 %r561; .reg .u64 %r562; .reg .f64 %r563; .reg .f64 %r564; .reg .pred %r565; .reg .pred %r566; .reg .u32 %r567; .reg .pred %r568; .reg .pred %r569; .reg .pred %r570; .reg .pred %r571; .reg .u32 %r572; .reg .u32 %r574; .reg .u32 %r575; .reg .u16 %r576; .reg .u16 %r577; .reg .u16 %r578; .reg .u32 %r579; .reg .pred %r580; .reg .u64 %r582; .reg .u64 %r583; .reg .pred %r584; .reg .u64 %r587; .reg .pred %r588; .reg .pred %r589; .reg .u64 %r590; .reg .u32 %r591; .reg .u64 %r592; .reg .u64 %r593; .reg .u64 %r594; .reg .u32 %r595; .reg .pred %r596; .reg .u64 %r597; .reg .f64 %r598; .reg .u32 %r599; .reg .pred %r600; .reg .f64 %r601; .reg .pred %r602; .reg .pred %r603; .reg .pred %r604; .reg .u64 %r605; .reg .u32 %r606; .reg .u64 %r607; .reg .u64 %r608; .reg .u64 %r609; .reg .f64 %r610; .reg .pred %r611; .reg .u32 %r612; .reg .pred %r613; .reg .f64 %r614; .reg .pred %r615; .reg .pred %r616; .reg .pred %r617; .reg .pred %r618; .reg .pred %r619; .reg .pred %r620; .reg .u32 %r621; .reg .f64 %r622; .reg .u64 %r624; .reg .u32 %r625; .reg .u32 %r626; .reg .u64 %r627; .reg .u64 %r628; .reg .u64 %r629; .reg .f64 %r631; .reg .u64 %r633; .reg .u32 %r634; .reg .u32 %r635; .reg .u64 %r636; .reg .u64 %r637; .reg .u64 %r638; .reg .pred %r640; .reg .f64 %r641; .reg .pred %r642; .reg .f64 %r643; .reg .pred %r644; .reg .u64 %r645; .reg .u32 %r646; .reg .u64 %r647; .reg .u64 %r648; .reg .u64 %r649; .reg .f64 %r650; .reg .u16 %r652; .reg .u16 %r653; .reg .u32 %r654; .reg .pred %r655; .reg .f64 %r656; .reg .f64 %r657; .reg .pred %r659; .reg .f64 %r660; .reg .f64 %r661; .reg .pred %r662; .reg .pred %r663; .reg .u64 %r664; .reg .u32 %r665; .reg .u64 %r666; .reg .f64 %r667; .reg .pred %r669; .reg .pred %r670; .reg .f64 %r671; .reg .u16 %r673; .reg .u16 %r674; .reg .u32 %r675; .reg .pred %r677; .reg .pred %r679; .reg .f64 %r680; .reg .pred %r681; .reg .f64 %r682; .reg .f64 %r683; .reg .pred %r684; .reg .u16 %r685; .reg .pred %r686; .reg .u32 %r687; .reg .u64 %r688; .reg .f64 %r689; .reg .u16 %r691; .reg .u16 %r692; .reg .u32 %r693; .reg .pred %r694; .reg .u64 %r695; .reg .u32 %r697; .reg .u32 %r698; .reg .u32 %r700; .reg .u32 %r701; .reg .u16 %r703; .reg .u16 %r704; .reg .u16 %r705; .reg .u32 %r706; .reg .u16 %r707; .reg .pred %r708; .reg .u64 %r709; .reg .u64 %r710; .reg .u64 %r711; .reg .u64 %r712; .reg .u32 %r714; .reg .u32 %r716; .reg .u32 %r717; .reg .u16 %r719; .reg .u16 %r720; .reg .u16 %r721; .reg .u32 %r722; .reg .u16 %r723; .reg .pred %r724; .reg .pred %r725; .reg .f64 %r726; .reg .f64 %r727; .reg .pred %r728; .reg .f64 %r729; .reg .f64 %r730; .reg .f64 %r731; .reg .u16 %r733; .reg .u16 %r734; .reg .u32 %r735; .reg .pred %r736; .reg .pred %r737; .reg .u32 %r738; .reg .u64 %r739; .reg .pred %r741; .reg .pred %r742; .reg .u32 %r743; .reg .pred %r744; .reg .pred %r745; .reg .u32 %r746; .reg .u16 %r747; .reg .pred %r748; .reg .u16 %r750; .reg .u16 %r751; .reg .u32 %r752; .reg .pred %r753; .reg .f64 %r754; .reg .f64 %r755; .reg .f64 %r756; .reg .u16 %r758; .reg .u16 %r759; .reg .u32 %r760; .reg .pred %r761; .reg .pred %r762; .reg .pred %r763; .reg .pred %r764; .reg .u32 %r765; .reg .u32 %r766; .reg .pred %r767; .reg .u32 %r768; .reg .pred %r769; .reg .u32 %r771; .reg .u64 %r772; .reg .u32 %r774; .reg .u32 %r775; .reg .u32 %r777; .reg .u32 %r778; .reg .u16 %r779; .reg .u16 %r780; .reg .u16 %r781; .reg .u32 %r782; .reg .u16 %r783; .reg .pred %r784; .reg .pred %r785; .reg .pred %r786; .reg .pred %r787; .reg .u64 %r791; .reg .u64 %r795; .reg .pred %r798; .reg .u64 %r802; .reg .u64 %r806; .reg .u32 %r808; .reg .u64 %r809; .reg .u64 %r814; .reg .pred %r815; .reg .u64 %r816; .reg .u32 %r817; .reg .u32 %r818; .reg .pred %r819; .reg .u32 %r821; .reg .u32 %r822; .reg .u32 %r823; .reg .u64 %r824; .reg .u64 %r825; .reg .u64 %r826; .reg .u64 %r827; .reg .u32 %r828; .reg .u32 %r829; .reg .u32 %r830; .reg .pred %r831; .reg .u32 %r832; .reg .pred %r833; .reg .u32 %r834; .reg .pred %r835; .reg .u32 %r836; .reg .pred %r837; .reg .u64 %r841; .reg .pred %r842; .reg .u64 %r846; .reg .u32 %r847; .reg .u32 %r848; .reg .u32 %r849; .reg .pred %r850; .reg .u32 %r853; .reg .pred %r854; .reg .u32 %r857; .reg .u32 %r858; .reg .u64 %r859; .reg .u32 %r861; .reg .u32 %r862; .reg .u16 %r863; .reg .u16 %r864; .reg .u16 %r865; .reg .u32 %r866; .reg .pred %r867; .reg .u64 %r872; .reg .pred %r873; .reg .u32 %r875; .reg .u32 %r876; .reg .u16 %r877; .reg .u16 %r878; .reg .u16 %r879; .reg .u32 %r880; .reg .u16 %r881; .reg .pred %r882; .reg .pred %r883; .reg .u32 %r886; .reg .u64 %r888; .reg .u32 %r891; .reg .pred %r892; .reg .u32 %r893; .reg .pred %r894; .reg .pred %r895; .reg .u64 %r899; .reg .pred %r900; .reg .u64 %r903; .reg .u64 %r907; .reg .u64 %r908; .reg .u64 %r909; .reg .u64 %r910; .reg .u64 %r911; .reg .u64 %r912; .reg .u32 %r915; .reg .u64 %r916; .reg .u32 %r917; .reg .u64 %r918; .reg .u32 %r921; .reg .u32 %r924; .reg .u64 %r928; .reg .u32 %r929; .reg .pred %r930; .reg .u32 %r933; .reg .u32 %r936; .reg .pred %r937; .reg .pred %r941; .reg .pred %r942; .reg .pred %r943; .reg .u32 %r944; .reg .pred %r945; .reg .pred %r949; .reg .u32 %r952; .reg .u64 %r953; .reg .u32 %r956; .reg .pred %r957; .reg .pred %r958; .reg .u32 %r959; .reg .pred %r960; .reg .pred %r961; .reg .pred %r962; .reg .pred %r963; .reg .u32 %r964; .reg .u16 %r966; .reg .u16 %r967; .reg .u32 %r968; .reg .pred %r969; .reg .u32 %r972; .reg .u32 %r973; .reg .u64 %r974; .reg .pred %r975; .reg .u64 %r980; .reg .u64 %r985; .reg .u64 %r990; .reg .u32 %r993; .reg .pred %r994; .reg .u32 %r997; .reg .u32 %r998; .reg .u64 %r999; .reg .u32 %r1002; .reg .u64 %r1003; .reg .u32 %r1006; .reg .pred %r1007; .reg .pred %r1008; .reg .u32 %r1009; .reg .pred %r1010; .reg .pred %r1011; .reg .u32 %r1012; .reg .u16 %r1013; .reg .pred %r1014; .reg .u16 %r1016; .reg .u32 %r1018; .reg .u16 %r1019; .reg .pred %r1020; .reg .pred %r1023; .reg .u32 %r1025; .reg .u32 %r1026; .reg .u32 %r1028; .reg .u32 %r1029; .reg .u16 %r1030; .reg .u16 %r1031; .reg .u16 %r1032; .reg .u32 %r1033; .reg .u16 %r1034; .reg .pred %r1035; .reg .u32 %r1042; .reg .u32 %r1043; .reg .pred %r1044; .reg .pred %r1046; .reg .pred %r1047; .reg .f64 %r1048; .reg .u64 %r1050; .reg .u32 %r1051; .reg .u32 %r1052; .reg .u64 %r1053; .reg .u64 %r1054; .reg .u64 %r1055; .reg .pred %r1057; .reg .pred %r1060; .reg .u32 %r1061; .reg .u64 %r1064; .reg .u32 %r1066; .reg .u32 %r1067; .reg .u32 %r1069; .reg .u32 %r1070; .reg .u16 %r1072; .reg .u16 %r1073; .reg .u16 %r1074; .reg .u32 %r1075; .reg .u16 %r1076; .reg .pred %r1077; .reg .pred %r1078; .reg .pred %r1079; .reg .pred %r1080; .reg .pred %r1081; .reg .pred %r1082; .reg .u32 %r1083; .reg .pred %r1084; .reg .u64 %r1085; .reg .pred %r1086; .reg .u64 %r1087; .reg .pred %r1088; .reg .u64 %r1089; .reg .u64 %r1090; .reg .pred %r1091; .reg .u32 %r1094; .reg .u32 %r1095; .reg .pred %r1096; .reg .f64 %r1097; mov.u64 %r485,%ar0; mov.f64 %r486,%ar1; mov.u32 %r487,%ar2; mov.u32 %r488,%ar3; mov.u64 %r489,%ar4; mov.u64 %r490,%ar5; mov.u64 %r491,%ar6; .loc 1 236 0 mov.b64 %r481,%r486; .loc 1 239 0 ld.u64 %r178,[%r485+96]; setp.eq.u64 %r492,%r178,0; @ %r492 bra $L22; .loc 1 241 0 ld.u32 %r179,[%r485+104]; st.u32 [%r178+8],%r179; .loc 1 242 0 mov.u32 %r494,1; shl.b32 %r493,%r494,%r179; st.u32 [%r178+12],%r493; .loc 1 243 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r178; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 244 0 mov.u64 %r497,0; st.u64 [%r485+96],%r497; $L22: mov.b64 %r498,%r486; shr.u64 %r499,%r498,32; cvt.u32.u64 %r359,%r499; .loc 1 247 0 setp.ge.s32 %r500,%r359,0; @ %r500 bra $L23; .loc 1 250 0 mov.u32 %r501,1; st.u32 [%r490],%r501; .loc 1 251 0 and.b32 %r359,%r359,2147483647; cvt.u64.u32 %r502,%r359; shl.b64 %r503,%r502,32; and.b64 %r504,%r481,4294967295; or.b64 %r481,%r504,%r503; mov.b64 %r486,%r481; bra $L24; $L23: .loc 1 254 0 mov.u32 %r506,0; st.u32 [%r490],%r506; $L24: .loc 1 258 0 and.b32 %r507,%r359,2146435072; setp.ne.u32 %r508,%r507,2146435072; @ %r508 bra $L25; .loc 1 264 0 mov.u32 %r509,9999; st.u32 [%r489],%r509; .loc 1 267 0 mov.b64 %r511,%r486; and.b64 %r510,%r511,4503599627370495; setp.eq.u64 %r512,%r510,0; @ %r512 bra $L26; bra $L264; $L189: cvta.const.u64 %r484,$LC0; .loc 1 273 0 add.u64 %r350,%r484,8; bra $L144; $L190: .loc 1 267 0 cvta.const.u64 %r484,$LC1; .loc 1 273 0 add.u64 %r350,%r484,3; $L144: .loc 1 271 0 st.u64 [%r491],%r350; bra $L21; $L25: .loc 1 282 0 setp.neu.f64 %r513,%r486,0d0000000000000000; @ %r513 bra $L29; .loc 1 284 0 mov.u32 %r514,1; st.u32 [%r489],%r514; .loc 1 286 0 setp.eq.u64 %r515,%r491,0; @ %r515 bra $L153; .loc 1 287 0 cvta.const.u64 %r516,$LC2+1; st.u64 [%r491],%r516; .loc 1 288 0 cvta.const.u64 %r484,$LC2; bra $L21; $L29: .loc 1 291 0 add.u64 %r521,%frame,4; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r486; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r521; call (%value_in),__d2b,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r522,[%value_in]; } mov.u64 %r449,%r522; .loc 1 295 0 shr.u32 %r186,%r359,20; setp.eq.u32 %r523,%r186,0; @ %r523 bra $L30; .loc 1 298 0 mov.b64 %r482,%r486; .loc 1 299 0 shr.u64 %r525,%r482,32; cvt.u32.u64 %r527,%r525; and.b32 %r526,%r527,1048575; .loc 1 300 0 or.b32 %r528,%r526,1072693248; cvt.u64.u32 %r529,%r528; shl.b64 %r530,%r529,32; and.b64 %r531,%r482,4294967295; or.b64 %r482,%r531,%r530; .loc 1 328 0 add.u32 %r323,%r186,-1023; ld.u32 %r454,[%frame+4]; .loc 1 334 0 mov.u32 %r340,0; bra $L31; $L30: .loc 1 340 0 ld.u32 %r454,[%frame+4]; ld.u32 %r533,[%frame]; add.u32 %r191,%r454,%r533; add.u32 %r357,%r191,1074; cvt.u32.u64 %r475,%r481; .loc 1 345 0 setp.le.s32 %r534,%r357,32; @ %r534 bra $L32; .loc 1 344 0 mov.u32 %r536,64; sub.u32 %r535,%r536,%r357; shl.b32 %r537,%r359,%r535; add.u32 %r538,%r191,1042; shr.u32 %r539,%r475,%r538; .loc 1 345 0 or.b32 %r351,%r537,%r539; bra $L33; $L32: mov.u32 %r541,32; sub.u32 %r540,%r541,%r357; shl.b32 %r351,%r475,%r540; $L33: .loc 1 347 0 cvt.rn.f64.u32 %r197,%r351; mov.b64 %r482,%r197; .loc 1 348 0 shr.u64 %r543,%r482,32; cvt.u32.u64 %r545,%r543; add.u32 %r544,%r545,-32505856; cvt.u64.u32 %r546,%r544; shl.b64 %r547,%r546,32; and.b64 %r548,%r482,4294967295; or.b64 %r482,%r548,%r547; .loc 1 349 0 add.u32 %r323,%r191,-1; .loc 1 350 0 mov.u32 %r340,1; $L31: .loc 1 356 0 cvt.rn.f64.s32 %r550,%r323; mov.b64 %r552,%r482; mov.f64 %r553,0d3ff8000000000000; sub.f64 %r551,%r552,%r553; fma.rn.f64 %r554,%r551,0d3fd287a7636f4361,0d3fc68a288b60c8b3; fma.rn.f64 %r358,%r550,0d3fd34413509f79fb,%r554; .loc 1 358 0 cvt.rzi.s32.f64 %r332,%r358; .loc 1 359 0 setp.lt.f64 %r555,%r358,0d0000000000000000; @ ! %r555 bra $L34; cvt.rn.f64.s32 %r556,%r332; setp.eq.f64 %r557,%r556,%r358; @ %r557 bra $L34; .loc 1 360 0 add.u32 %r332,%r332,-1; $L34: .loc 1 362 0 setp.gt.u32 %r558,%r332,22; @ %r558 bra $L154; .loc 1 364 0 cvta.const.u64 %r559,__mprec_tens; cvt.s64.s32 %r560,%r332; shl.b64 %r561,%r560,3; add.u64 %r562,%r559,%r561; ld.f64 %r563,[%r562]; mov.b64 %r564,%r481; setp.gt.f64 %r565,%r563,%r564; @ ! %r565 bra $L265; .loc 1 365 0 add.u32 %r332,%r332,-1; .loc 1 366 0 mov.u32 %r333,0; bra $L36; $L154: .loc 1 361 0 mov.u32 %r333,1; bra $L36; $L265: .loc 1 366 0 mov.u32 %r333,0; $L36: .loc 1 368 0 sub.u32 %r209,%r454,%r323; add.u32 %r337,%r209,-1; .loc 1 369 0 setp.ge.s32 %r566,%r337,0; @ %r566 bra $L156; .loc 1 376 0 mov.u32 %r567,1; sub.u32 %r320,%r567,%r209; .loc 1 377 0 mov.u32 %r337,0; bra $L38; $L156: .loc 1 371 0 mov.u32 %r320,0; $L38: .loc 1 379 0 setp.lt.s32 %r568,%r332,0; @ %r568 bra $L39; .loc 1 383 0 add.u32 %r337,%r337,%r332; mov.u32 %r338,%r332; .loc 1 381 0 mov.u32 %r321,0; bra $L40; $L39: .loc 1 387 0 sub.u32 %r320,%r320,%r332; .loc 1 388 0 neg.s32 %r321,%r332; .loc 1 389 0 mov.u32 %r338,0; $L40: .loc 1 391 0 setp.gt.u32 %r569,%r487,9; @ %r569 bra $L157; .loc 1 394 0 setp.le.s32 %r570,%r487,5; @ %r570 bra $L158; .loc 1 396 0 add.u32 %r487,%r487,-4; mov.u32 %r455,0; bra $L42; $L43: .loc 1 399 0 mov.u32 %r334,1; bra $L44; $L193: .loc 1 409 0 mov.u32 %r334,0; $L44: .loc 1 412 0 setp.le.s32 %r571,%r488,0; @ %r571 bra $L159; mov.u32 %r330,%r488; mov.u32 %r328,%r488; mov.u32 %r324,%r488; bra $L45; $L194: .loc 1 417 0 mov.u32 %r334,0; $L46: .loc 1 420 0 add.u32 %r330,%r332,%r488; add.u32 %r328,%r330,1; max.s32 %r324,%r328,1; $L45: .loc 1 427 0 mov.u32 %r572,0; st.u32 [%r485+104],%r572; cvt.s64.s32 %r446,%r324; set.u32.le.u32 %r574,%r328,14; neg.s32 %r575,%r574; cvt.u16.u32 %r577,%r575; cvt.u16.u32 %r578,%r455; and.b16 %r576,%r577,%r578; cvt.u32.u16 %r579,%r576; cvt.u32.u8 %r455,%r579; setp.le.s32 %r580,%r324,31; @ %r580 bra $L160; mov.u32 %r391,1; .loc 1 426 0 mov.u32 %r355,4; $L48: .loc 1 429 0 mov.u32 %r211,%r391; .loc 1 428 0 add.u32 %r355,%r355,%r355; add.u32 %r391,%r211,1; .loc 1 427 0 cvt.s64.s32 %r582,%r355; add.u64 %r583,%r582,28; setp.le.u64 %r584,%r583,%r446; @ %r584 bra $L48; st.u32 [%r485+104],%r211; bra $L47; $L160: mov.u32 %r211,%r572; $L47: .loc 1 430 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r211; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r587,[%value_in]; } mov.u64 %r214,%r587; st.u64 [%r485+96],%r587; .loc 1 433 0 setp.eq.u32 %r588,%r455,0; @ %r588 bra $L49; .loc 1 438 0 mov.b64 %r215,%r481; .loc 1 442 0 setp.le.s32 %r589,%r332,0; @ %r589 bra $L50; .loc 1 444 0 cvta.const.u64 %r590,__mprec_tens; and.b32 %r591,%r332,15; cvt.s64.s32 %r592,%r591; shl.b64 %r593,%r592,3; add.u64 %r594,%r590,%r593; ld.f64 %r345,[%r594]; .loc 1 445 0 shr.s32 %r366,%r332,4; .loc 1 446 0 and.b32 %r595,%r366,16; setp.eq.u32 %r596,%r595,0; @ %r596 bra $L161; .loc 1 449 0 and.b32 %r366,%r366,15; .loc 1 450 0 cvta.const.u64 %r597,__mprec_bigtens; ld.f64 %r598,[%r597+32]; div.rn.f64 %r220,%r215,%r598; .loc 1 451 0 mov.u32 %r327,3; bra $L51; $L55: cvta.const.u64 %r395,__mprec_bigtens; $L53: .loc 1 454 0 and.b32 %r599,%r366,1; setp.eq.u32 %r600,%r599,0; @ %r600 bra $L52; .loc 1 456 0 add.u32 %r327,%r327,1; .loc 1 457 0 ld.f64 %r601,[%r395]; mul.f64 %r345,%r345,%r601; $L52: .loc 1 453 0 shr.s32 %r366,%r366,1; add.u64 %r395,%r395,8; setp.ne.u32 %r602,%r366,0; @ %r602 bra $L53; bra $L54; $L161: mov.f64 %r220,%r215; .loc 1 441 0 mov.u32 %r327,2; $L51: .loc 1 453 0 setp.ne.u32 %r603,%r366,0; @ %r603 bra $L55; $L54: .loc 1 459 0 div.rn.f64 %r465,%r220,%r345; bra $L56; $L50: .loc 1 461 0 setp.eq.u32 %r604,%r332,0; @ %r604 bra $L162; neg.s32 %r363,%r332; .loc 1 463 0 cvta.const.u64 %r605,__mprec_tens; and.b32 %r606,%r363,15; cvt.s64.s32 %r607,%r606; shl.b64 %r608,%r607,3; add.u64 %r609,%r605,%r608; ld.f64 %r610,[%r609]; mul.f64 %r465,%r215,%r610; .loc 1 464 0 shr.s32 %r364,%r363,4; setp.eq.u32 %r611,%r364,0; @ %r611 bra $L163; cvta.const.u64 %r393,__mprec_bigtens; mov.f64 %r346,%r465; mov.u32 %r325,0; .loc 1 441 0 mov.u32 %r327,2; $L58: .loc 1 465 0 and.b32 %r612,%r364,1; setp.eq.u32 %r613,%r612,0; @ %r613 bra $L57; .loc 1 467 0 add.u32 %r327,%r327,1; .loc 1 468 0 ld.f64 %r614,[%r393]; mul.f64 %r346,%r346,%r614; mov.u32 %r325,%r455; $L57: .loc 1 464 0 shr.s32 %r364,%r364,1; add.u64 %r393,%r393,8; setp.ne.u32 %r615,%r364,0; @ %r615 bra $L58; setp.eq.u32 %r616,%r325,0; selp.f64 %r465,%r465,%r346,%r616; bra $L56; $L162: mov.f64 %r465,%r215; .loc 1 441 0 mov.u32 %r327,2; bra $L56; $L163: mov.u32 %r327,2; $L56: .loc 1 471 0 setp.eq.u32 %r617,%r333,0; @ %r617 bra $L60; setp.lt.f64 %r618,%r465,0d3ff0000000000000; @ ! %r618 bra $L60; setp.eq.u32 %r619,%r328,0; @ %r619 bra $L62; .loc 1 473 0 setp.le.s32 %r620,%r330,0; @ %r620 bra $L63; .loc 1 476 0 add.u32 %r448,%r332,-1; .loc 1 477 0 mul.f64 %r465,%r465,0d4024000000000000; .loc 1 478 0 add.u32 %r621,%r327,1; .loc 1 480 0 cvt.rn.f64.s32 %r622,%r621; fma.rn.f64 %r440,%r465,%r622,0d401c000000000000; mov.b64 %r483,%r440; .loc 1 481 0 shr.u64 %r624,%r483,32; cvt.u32.u64 %r626,%r624; add.u32 %r625,%r626,-54525952; cvt.u64.u32 %r627,%r625; shl.b64 %r628,%r627,32; and.b64 %r629,%r483,4294967295; or.b64 %r483,%r629,%r628; mov.u32 %r451,%r330; bra $L64; $L60: .loc 1 480 0 cvt.rn.f64.s32 %r631,%r327; fma.rn.f64 %r230,%r631,%r465,0d401c000000000000; mov.b64 %r483,%r230; .loc 1 481 0 shr.u64 %r633,%r483,32; cvt.u32.u64 %r635,%r633; add.u32 %r634,%r635,-54525952; cvt.u64.u32 %r636,%r634; shl.b64 %r637,%r636,32; and.b64 %r638,%r483,4294967295; or.b64 %r483,%r638,%r637; .loc 1 482 0 setp.ne.u32 %r640,%r328,0; @ %r640 bra $L164; $L145: .loc 1 485 0 mov.f64 %r641,0d4014000000000000; sub.f64 %r232,%r465,%r641; .loc 1 486 0 mov.b64 %r233,%r483; setp.gt.f64 %r642,%r232,%r233; @ %r642 bra $L165; .loc 1 488 0 neg.f64 %r643,%r233; setp.lt.f64 %r644,%r232,%r643; @ %r644 bra $L166; bra $L63; $L164: mov.u32 %r448,%r332; mov.u32 %r451,%r328; $L64: cvt.rzi.s32.f64 %r466,%r465; mov.b64 %r468,%r483; cvta.const.u64 %r645,__mprec_tens; add.u32 %r646,%r451,-1; cvt.s64.s32 %r647,%r646; shl.b64 %r648,%r647,3; add.u64 %r649,%r645,%r648; ld.f64 %r470,[%r649]; cvt.rn.f64.s32 %r650,%r466; sub.f64 %r245,%r465,%r650; add.u64 %r347,%r587,1; cvt.u16.u32 %r653,%r466; add.u16 %r652,%r653,48; cvt.u32.u16 %r654,%r652; cvt.s32.s8 %r456,%r654; .loc 1 493 0 setp.eq.u32 %r655,%r334,0; @ %r655 bra $L67; .loc 1 498 0 mov.f64 %r657,0d3fe0000000000000; div.rn.f64 %r656,%r657,%r470; sub.f64 %r241,%r656,%r468; .loc 1 503 0 st.u8 [%r587],%r654; .loc 1 504 0 setp.gt.f64 %r659,%r241,%r245; @ %r659 bra $L167; .loc 1 506 0 mov.f64 %r661,0d3ff0000000000000; sub.f64 %r660,%r661,%r245; setp.lt.f64 %r662,%r660,%r241; @ %r662 bra $L69; .loc 1 508 0 setp.eq.u32 %r663,%r451,1; @ %r663 bra $L63; mov.u64 %r356,%r347; add.u64 %r664,%r587,2; add.u32 %r665,%r451,-2; cvt.u64.u32 %r666,%r665; add.u64 %r403,%r664,%r666; .loc 1 506 0 mov.f64 %r1097,%r661; bra $L70; $L266: sub.f64 %r667,%r1097,%r245; setp.lt.f64 %r669,%r667,%r241; @ %r669 bra $L69; mov.u64 %r356,%r409; .loc 1 508 0 setp.eq.u64 %r670,%r403,%r356; @ %r670 bra $L63; $L70: .loc 1 510 0 mul.f64 %r241,%r241,0d4024000000000000; .loc 1 511 0 mul.f64 %r242,%r245,0d4024000000000000; .loc 1 501 0 cvt.rzi.s32.f64 %r370,%r242; .loc 1 502 0 cvt.rn.f64.s32 %r671,%r370; sub.f64 %r245,%r242,%r671; add.u64 %r409,%r356,1; mov.u64 %r347,%r409; .loc 1 503 0 cvt.u16.u32 %r674,%r370; add.u16 %r673,%r674,48; cvt.u32.u16 %r675,%r673; cvt.s32.s8 %r456,%r675; st.u8 [%r356],%r675; .loc 1 504 0 setp.lt.f64 %r677,%r245,%r241; @ ! %r677 bra $L266; .loc 1 855 0 bra $L168; $L67: .loc 1 518 0 mul.f64 %r243,%r468,%r470; .loc 1 523 0 st.u8 [%r587],%r654; .loc 1 524 0 setp.ne.u32 %r679,%r451,1; @ %r679 bra $L72; $L78: .loc 1 526 0 add.f64 %r680,%r243,0d3fe0000000000000; setp.lt.f64 %r681,%r680,%r245; @ ! %r681 bra $L267; ld.s8 %r456,[%r347+-1]; bra $L69; $L267: .loc 1 528 0 mov.f64 %r683,0d3fe0000000000000; sub.f64 %r682,%r683,%r243; setp.gt.f64 %r684,%r682,%r245; @ %r684 bra $L76; bra $L63; $L169: mov.u64 %r347,%r369; $L76: .loc 1 530 0 add.u64 %r369,%r347,-1; ld.s8 %r252,[%r369]; cvt.u16.u32 %r685,%r252; setp.eq.u16 %r686,%r685,48; @ %r686 bra $L169; mov.u64 %r484,%r587; .loc 1 531 0 mov.u64 %r214,%r347; bra $L68; $L72: mov.u64 %r402,%r347; add.u32 %r687,%r451,-2; cvt.u64.u32 %r398,%r687; add.u64 %r688,%r587,2; add.u64 %r396,%r688,%r398; $L77: .loc 1 519 0 mul.f64 %r253,%r245,0d4024000000000000; .loc 1 521 0 cvt.rzi.s32.f64 %r368,%r253; .loc 1 522 0 cvt.rn.f64.s32 %r689,%r368; sub.f64 %r245,%r253,%r689; .loc 1 523 0 cvt.u16.u32 %r692,%r368; add.u16 %r691,%r692,48; cvt.u32.u16 %r693,%r691; st.u8 [%r402],%r693; add.u64 %r402,%r402,1; .loc 1 524 0 setp.ne.u64 %r694,%r396,%r402; @ %r694 bra $L77; add.u64 %r695,%r398,1; add.u64 %r347,%r347,%r695; bra $L78; $L63: .loc 1 542 0 mov.b64 %r481,%r215; $L49: .loc 1 549 0 ld.u32 %r254,[%frame]; set.u32.le.s32 %r697,%r332,14; neg.s32 %r698,%r697; not.b32 %r700,%r254; shr.u32 %r701,%r700,31; cvt.u16.u32 %r704,%r698; cvt.u16.u32 %r705,%r701; and.b16 %r703,%r704,%r705; cvt.u32.u16 %r706,%r703; cvt.u16.u8 %r707,%r706; setp.eq.u16 %r708,%r707,0; @ %r708 bra $L79; bra $L147; $L192: .loc 1 400 0 mov.u32 %r328,-1; .loc 1 406 0 mov.u32 %r488,%r1061; $L147: .loc 1 552 0 cvta.const.u64 %r709,__mprec_tens; cvt.s64.s32 %r710,%r332; shl.b64 %r711,%r710,3; add.u64 %r712,%r709,%r711; ld.f64 %r371,[%r712]; .loc 1 553 0 shr.u32 %r714,%r488,31; set.u32.le.s32 %r716,%r328,0; neg.s32 %r717,%r716; cvt.u16.u32 %r720,%r714; cvt.u16.u32 %r721,%r717; and.b16 %r719,%r720,%r721; cvt.u32.u16 %r722,%r719; cvt.u16.u8 %r723,%r722; setp.eq.u16 %r724,%r723,0; @ %r724 bra $L80; .loc 1 556 0 setp.ne.u32 %r725,%r328,0; @ %r725 bra $L170; mul.f64 %r726,%r371,0d4014000000000000; mov.b64 %r727,%r481; setp.ge.f64 %r728,%r726,%r727; @ %r728 bra $L171; .loc 1 555 0 mov.u64 %r379,0; mov.u64 %r343,%r379; bra $L65; $L80: .loc 1 562 0 mov.b64 %r250,%r481; div.rn.f64 %r729,%r250,%r371; cvt.rzi.s32.f64 %r372,%r729; .loc 1 563 0 neg.f64 %r730,%r371; cvt.rn.f64.s32 %r731,%r372; fma.rn.f64 %r263,%r730,%r731,%r250; .loc 1 572 0 add.u64 %r347,%r214,1; cvt.u16.u32 %r734,%r372; add.u16 %r733,%r734,48; cvt.u32.u16 %r735,%r733; st.u8 [%r214],%r735; .loc 1 573 0 setp.eq.u32 %r736,%r328,1; @ %r736 bra $L81; .loc 1 590 0 mul.f64 %r236,%r263,0d4024000000000000; setp.eq.f64 %r737,%r236,0d0000000000000000; @ %r737 bra $L172; mov.u64 %r229,%r347; add.u32 %r738,%r328,-2; cvt.u64.u32 %r739,%r738; add.u64 %r425,%r229,%r739; bra $L82; $L81: .loc 1 575 0 add.f64 %r267,%r263,%r263; .loc 1 576 0 setp.gt.f64 %r741,%r267,%r371; @ ! %r741 bra $L268; ld.s8 %r456,[%r347+-1]; mov.u32 %r448,%r332; bra $L69; $L268: setp.neu.f64 %r742,%r267,%r371; @ %r742 bra $L173; and.b32 %r743,%r372,1; setp.eq.u32 %r744,%r743,0; @ %r744 bra $L174; ld.s8 %r456,[%r347+-1]; mov.u32 %r448,%r332; bra $L69; $L88: add.u64 %r452,%r452,-1; .loc 1 580 0 setp.eq.u64 %r745,%r1089,%r214; @ %r745 bra $L85; ld.s8 %r456,[%r452]; mov.u64 %r347,%r1089; add.u64 %r1089,%r1089,-1; bra $L86; $L85: .loc 1 582 0 add.u32 %r448,%r448,1; .loc 1 583 0 mov.u32 %r746,48; st.u8 [%r214],%r746; ld.s8 %r456,[%r347+-1]; .loc 1 584 0 mov.u64 %r262,%r214; bra $L87; $L69: add.u64 %r1089,%r347,-1; mov.u64 %r452,%r1089; $L86: .loc 1 579 0 mov.u64 %r262,%r1089; cvt.u16.u32 %r747,%r456; setp.eq.u16 %r748,%r747,57; @ %r748 bra $L88; $L87: .loc 1 586 0 cvt.u16.u32 %r751,%r456; add.u16 %r750,%r751,1; cvt.u32.u16 %r752,%r750; st.u8 [%r262],%r752; mov.u64 %r484,%r214; mov.u64 %r214,%r347; bra $L68; $L269: .loc 1 590 0 mul.f64 %r236,%r263,0d4024000000000000; mov.u64 %r229,%r431; setp.eq.f64 %r753,%r236,0d0000000000000000; @ %r753 bra $L175; $L82: .loc 1 562 0 div.rn.f64 %r754,%r236,%r371; cvt.rzi.s32.f64 %r372,%r754; .loc 1 563 0 cvt.rn.f64.s32 %r755,%r372; neg.f64 %r756,%r755; fma.rn.f64 %r263,%r756,%r371,%r236; add.u64 %r431,%r229,1; mov.u64 %r347,%r431; .loc 1 572 0 cvt.u16.u32 %r759,%r372; add.u16 %r758,%r759,48; cvt.u32.u16 %r760,%r758; st.u8 [%r229],%r760; .loc 1 573 0 setp.eq.u64 %r761,%r229,%r425; @ ! %r761 bra $L269; bra $L81; $L79: .loc 1 599 0 setp.eq.u32 %r762,%r334,0; @ %r762 bra $L176; $L148: .loc 1 601 0 setp.gt.s32 %r763,%r487,1; @ %r763 bra $L91; .loc 1 605 0 setp.eq.u32 %r764,%r340,0; @ %r764 bra $L92; add.u32 %r376,%r254,1075; add.u32 %r337,%r337,%r376; mov.u32 %r336,%r321; .loc 1 596 0 mov.u32 %r335,%r320; add.u32 %r320,%r320,%r376; bra $L93; $L92: .loc 1 605 0 mov.u32 %r765,54; ld.u32 %r766,[%frame+4]; sub.u32 %r375,%r765,%r766; add.u32 %r337,%r337,%r375; mov.u32 %r336,%r321; .loc 1 596 0 mov.u32 %r335,%r320; .loc 1 605 0 add.u32 %r320,%r320,%r375; bra $L93; $L91: .loc 1 615 0 add.u32 %r373,%r328,-1; .loc 1 616 0 setp.lt.s32 %r767,%r321,%r373; @ %r767 bra $L94; .loc 1 617 0 sub.u32 %r336,%r321,%r373; bra $L95; $L94: .loc 1 620 0 sub.u32 %r768,%r373,%r321; add.u32 %r338,%r338,%r768; mov.u32 %r321,%r373; .loc 1 622 0 mov.u32 %r336,0; $L95: .loc 1 624 0 setp.lt.s32 %r769,%r328,0; @ %r769 bra $L96; add.u32 %r337,%r337,%r328; .loc 1 596 0 mov.u32 %r335,%r320; .loc 1 624 0 add.u32 %r320,%r320,%r328; bra $L93; $L96: .loc 1 626 0 sub.u32 %r335,%r320,%r328; $L93: .loc 1 632 0 mov.u32 %r771,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r771; call (%value_in),__i2b,(%out_arg1,%out_arg2); ld.param.u64 %r772,[%value_in]; } mov.u64 %r343,%r772; bra $L90; $L176: mov.u32 %r336,%r321; .loc 1 596 0 mov.u32 %r335,%r320; .loc 1 598 0 mov.u64 %r343,0; $L90: .loc 1 634 0 set.u32.gt.s32 %r774,%r335,0; neg.s32 %r775,%r774; set.u32.gt.s32 %r777,%r337,0; neg.s32 %r778,%r777; cvt.u16.u32 %r780,%r775; cvt.u16.u32 %r781,%r778; and.b16 %r779,%r780,%r781; cvt.u32.u16 %r782,%r779; cvt.u16.u8 %r783,%r782; setp.eq.u16 %r784,%r783,0; @ %r784 bra $L97; .loc 1 636 0 min.s32 %r377,%r335,%r337; .loc 1 637 0 sub.u32 %r320,%r320,%r377; .loc 1 638 0 sub.u32 %r335,%r335,%r377; .loc 1 639 0 sub.u32 %r337,%r337,%r377; $L97: .loc 1 641 0 setp.eq.u32 %r785,%r321,0; @ %r785 bra $L98; .loc 1 643 0 setp.eq.u32 %r786,%r334,0; @ %r786 bra $L99; sub.u32 %r461,%r321,%r336; .loc 1 645 0 setp.eq.u32 %r787,%r336,0; @ %r787 bra $L100; .loc 1 647 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r336; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r791,[%value_in]; } mov.u64 %r343,%r791; .loc 1 648 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r522; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r795,[%value_in]; } .loc 1 649 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r522; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 652 0 setp.eq.u32 %r798,%r461,0; @ %r798 bra $L177; .loc 1 650 0 mov.u64 %r449,%r795; $L100: .loc 1 653 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r461; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r802,[%value_in]; } mov.u64 %r449,%r802; bra $L98; $L99: .loc 1 656 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r522; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r321; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r806,[%value_in]; } mov.u64 %r449,%r806; bra $L98; $L177: .loc 1 650 0 mov.u64 %r449,%r795; $L98: .loc 1 658 0 mov.u32 %r808,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r808; call (%value_in),__i2b,(%out_arg1,%out_arg2); ld.param.u64 %r809,[%value_in]; } mov.u64 %r379,%r809; .loc 1 659 0 setp.eq.u32 %r1091,%r338,0; @ %r1091 bra $L101; .loc 1 660 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r338; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r814,[%value_in]; } mov.u64 %r379,%r814; .loc 1 665 0 setp.le.s32 %r815,%r487,1; @ %r815 bra $L102; .loc 1 664 0 mov.u32 %r338,0; bra $L103; $L152: .loc 1 669 0 shr.u64 %r816,%r481,32; cvt.u32.u64 %r818,%r816; and.b32 %r817,%r818,2146435072; setp.eq.u32 %r819,%r817,0; @ %r819 bra $L178; .loc 1 674 0 add.u32 %r320,%r320,1; .loc 1 675 0 add.u32 %r337,%r337,1; .loc 1 676 0 mov.u32 %r339,1; bra $L104; $L178: .loc 1 664 0 mov.u32 %r339,%r817; $L104: .loc 1 689 0 @ %r1091 bra $L179; mov.u32 %r338,%r339; $L103: ld.u32 %r823,[%r379+20]; add.u32 %r822,%r823,-1; cvt.s64.s32 %r824,%r822; add.u64 %r825,%r824,6; shl.b64 %r826,%r825,2; add.u64 %r827,%r379,%r826; ld.u32 %r821,[%r827]; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r821; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r828,[%value_in]; } mov.u32 %r829,32; sub.u32 %r352,%r829,%r828; bra $L105; $L179: mov.u32 %r338,%r339; mov.u32 %r352,1; $L105: add.u32 %r830,%r352,%r337; and.b32 %r380,%r830,31; setp.eq.u32 %r831,%r380,0; @ %r831 bra $L180; .loc 1 690 0 mov.u32 %r832,32; sub.u32 %r381,%r832,%r380; .loc 1 695 0 setp.le.s32 %r833,%r381,4; @ %r833 bra $L107; .loc 1 697 0 mov.u32 %r834,28; sub.u32 %r382,%r834,%r380; .loc 1 698 0 add.u32 %r320,%r320,%r382; .loc 1 699 0 add.u32 %r335,%r335,%r382; .loc 1 700 0 add.u32 %r337,%r337,%r382; bra $L108; $L107: .loc 1 702 0 setp.eq.u32 %r835,%r381,4; @ %r835 bra $L108; mov.u32 %r836,60; sub.u32 %r460,%r836,%r380; bra $L106; $L180: mov.u32 %r460,28; $L106: .loc 1 705 0 add.u32 %r320,%r320,%r460; .loc 1 706 0 add.u32 %r335,%r335,%r460; .loc 1 707 0 add.u32 %r337,%r337,%r460; $L108: .loc 1 709 0 setp.le.s32 %r837,%r320,0; @ %r837 bra $L109; .loc 1 710 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r320; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r841,[%value_in]; } mov.u64 %r449,%r841; $L109: .loc 1 711 0 setp.le.s32 %r842,%r337,0; @ %r842 bra $L110; .loc 1 712 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r337; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r846,[%value_in]; } mov.u64 %r379,%r846; $L110: set.u32.gt.s32 %r848,%r487,2; neg.s32 %r849,%r848; cvt.u32.u32 %r847,%r849; cvt.u32.u8 %r476,%r847; .loc 1 713 0 setp.eq.u32 %r850,%r333,0; @ %r850 bra $L111; .loc 1 715 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r853,[%value_in]; } setp.ge.s32 %r854,%r853,0; @ %r854 bra $L111; .loc 1 717 0 add.u32 %r332,%r332,-1; .loc 1 718 0 mov.u32 %r858,0; mov.u32 %r857,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r857; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r858; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r859,[%value_in]; } mov.u64 %r449,%r859; set.u32.le.s32 %r861,%r330,0; neg.s32 %r862,%r861; cvt.u16.u32 %r864,%r862; cvt.u16.u32 %r865,%r476; and.b16 %r863,%r864,%r865; cvt.u32.u16 %r866,%r863; cvt.u32.u8 %r459,%r866; .loc 1 719 0 setp.eq.u32 %r867,%r334,0; @ %r867 bra $L112; .loc 1 720 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r857; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r858; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r872,[%value_in]; } mov.u64 %r343,%r872; .loc 1 724 0 setp.ne.u32 %r873,%r459,0; @ %r873 bra $L181; mov.u32 %r328,%r330; bra $L114; $L111: set.u32.le.s32 %r875,%r328,0; neg.s32 %r876,%r875; cvt.u16.u32 %r878,%r876; cvt.u16.u32 %r879,%r476; and.b16 %r877,%r878,%r879; cvt.u32.u16 %r880,%r877; cvt.u16.u8 %r881,%r880; setp.eq.u16 %r882,%r881,0; @ %r882 bra $L115; bra $L113; $L181: mov.u32 %r328,%r330; bra $L113; $L191: mov.u32 %r328,%r330; $L113: .loc 1 726 0 setp.ne.u32 %r883,%r328,0; @ %r883 bra $L66; mov.u32 %r886,5; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r886; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r328; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r888,[%value_in]; } mov.u64 %r379,%r888; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r891,[%value_in]; } setp.gt.s32 %r892,%r891,0; @ %r892 bra $L65; bra $L66; $L166: .loc 1 484 0 mov.u64 %r379,0; mov.u64 %r343,%r379; bra $L66; $L170: .loc 1 555 0 mov.u64 %r379,0; mov.u64 %r343,%r379; bra $L66; $L171: mov.u64 %r379,0; mov.u64 %r343,%r379; $L66: .loc 1 730 0 not.b32 %r448,%r488; .loc 1 731 0 mov.u64 %r484,%r214; bra $L116; $L165: .loc 1 484 0 mov.u64 %r379,0; mov.u64 %r343,%r379; $L65: .loc 1 734 0 mov.u32 %r893,49; st.u8 [%r214],%r893; .loc 1 735 0 add.u32 %r448,%r332,1; .loc 1 736 0 mov.u64 %r484,%r214; .loc 1 734 0 add.u64 %r214,%r214,1; .loc 1 736 0 bra $L116; $L115: .loc 1 738 0 setp.eq.u32 %r894,%r334,0; @ %r894 bra $L117; $L114: .loc 1 740 0 setp.le.s32 %r895,%r335,0; @ %r895 bra $L118; .loc 1 741 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r335; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r899,[%value_in]; } mov.u64 %r343,%r899; $L118: .loc 1 748 0 setp.eq.u32 %r900,%r338,0; @ %r900 bra $L182; .loc 1 750 0 ld.u32 %r287,[%r343+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r287; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r903,[%value_in]; } .loc 1 751 0 ld.s32 %r907,[%r343+20]; add.u64 %r908,%r907,2; shl.b64 %r909,%r908,2; add.u64 %r910,%r343,16; add.u64 %r911,%r903,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r911; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r910; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r909; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r912,[%value_in]; } .loc 1 752 0 mov.u32 %r915,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r903; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r915; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r916,[%value_in]; } mov.u64 %r344,%r916; bra $L119; $L182: mov.u64 %r344,%r343; $L119: mov.u64 %r417,%r214; add.u32 %r917,%r328,-1; cvt.u64.u32 %r918,%r917; add.u64 %r412,%r918,%r214; .loc 1 766 0 cvt.u32.u64 %r1094,%r481; and.b32 %r1095,%r1094,1; setp.ne.u32 %r1096,%r1095,0; $L135: .loc 1 757 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),quorem,(%out_arg1,%out_arg2); ld.param.u32 %r921,[%value_in]; } add.u32 %r322,%r921,48; .loc 1 761 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r924,[%value_in]; } .loc 1 762 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r344; call (%value_in),__mdiff,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r928,[%value_in]; } .loc 1 763 0 ld.u32 %r929,[%r928+16]; setp.ne.u32 %r930,%r929,0; @ %r930 bra $L183; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r928; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r933,[%value_in]; } mov.u32 %r353,%r933; bra $L120; $L183: mov.u32 %r353,1; $L120: .loc 1 764 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r928; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 766 0 or.b32 %r936,%r353,%r487; setp.ne.u32 %r937,%r936,0; @ %r937 bra $L121; @ %r1096 bra $L121; add.u64 %r349,%r417,1; .loc 1 768 0 setp.eq.u32 %r941,%r322,57; @ %r941 bra $L122; .loc 1 770 0 setp.le.s32 %r942,%r924,0; @ %r942 bra $L123; .loc 1 771 0 add.u32 %r322,%r921,49; $L123: .loc 1 772 0 st.u8 [%r417],%r322; .loc 1 773 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r448,%r332; bra $L124; $L121: .loc 1 776 0 setp.lt.s32 %r943,%r924,0; @ %r943 bra $L125; or.b32 %r944,%r924,%r487; setp.ne.u32 %r945,%r944,0; @ %r945 bra $L126; .loc 1 778 0 @ %r1096 bra $L126; $L125: add.u64 %r349,%r417,1; .loc 1 782 0 setp.le.s32 %r949,%r353,0; @ %r949 bra $L127; .loc 1 784 0 mov.u32 %r952,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r952; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r953,[%value_in]; } mov.u64 %r449,%r953; .loc 1 785 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r956,[%value_in]; } .loc 1 786 0 setp.gt.s32 %r957,%r956,0; @ %r957 bra $L128; setp.ne.u32 %r958,%r956,0; @ %r958 bra $L127; and.b32 %r959,%r322,1; setp.eq.u32 %r960,%r959,0; @ %r960 bra $L127; $L128: .loc 1 787 0 setp.eq.u32 %r961,%r322,57; @ %r961 bra $L122; add.u32 %r322,%r921,49; $L127: .loc 1 790 0 st.u8 [%r417],%r322; .loc 1 791 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r448,%r332; bra $L124; $L126: add.u64 %r349,%r417,1; .loc 1 793 0 setp.le.s32 %r962,%r353,0; @ %r962 bra $L129; .loc 1 795 0 setp.ne.u32 %r963,%r322,57; @ %r963 bra $L130; $L122: .loc 1 798 0 mov.u32 %r964,57; st.u8 [%r417],%r964; .loc 1 799 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r457,57; bra $L131; $L130: .loc 1 801 0 cvt.u16.u32 %r967,%r322; add.u16 %r966,%r967,1; cvt.u32.u16 %r968,%r966; st.u8 [%r417],%r968; .loc 1 802 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r448,%r332; bra $L124; $L129: .loc 1 804 0 st.u8 [%r417],%r322; .loc 1 805 0 setp.eq.u64 %r969,%r412,%r417; @ %r969 bra $L184; .loc 1 807 0 mov.u32 %r973,0; mov.u32 %r972,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r974,[%value_in]; } mov.u64 %r449,%r974; .loc 1 808 0 setp.ne.u64 %r975,%r343,%r344; @ %r975 bra $L133; .loc 1 809 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r980,[%value_in]; } mov.u64 %r343,%r980; mov.u64 %r344,%r343; bra $L134; $L133: .loc 1 812 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r985,[%value_in]; } mov.u64 %r343,%r985; .loc 1 813 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r344; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r990,[%value_in]; } mov.u64 %r344,%r990; $L134: mov.u64 %r417,%r349; .loc 1 757 0 bra $L135; $L117: mov.u64 %r204,%r214; .loc 1 724 0 mov.u32 %r326,1; $L136: .loc 1 820 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),quorem,(%out_arg1,%out_arg2); ld.param.u32 %r993,[%value_in]; } add.u32 %r322,%r993,48; add.u64 %r349,%r204,1; st.u8 [%r204],%r322; .loc 1 821 0 setp.ge.s32 %r994,%r326,%r328; @ %r994 bra $L185; .loc 1 823 0 mov.u32 %r998,0; mov.u32 %r997,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r997; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r998; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r999,[%value_in]; } mov.u64 %r449,%r999; .loc 1 818 0 add.u32 %r326,%r326,1; mov.u64 %r204,%r349; .loc 1 820 0 bra $L136; $L184: mov.u64 %r342,%r343; mov.u64 %r343,%r344; bra $L132; $L185: .loc 1 598 0 mov.u64 %r342,0; $L132: .loc 1 828 0 mov.u32 %r1002,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1002; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r1003,[%value_in]; } mov.u64 %r449,%r1003; .loc 1 829 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r1006,[%value_in]; } .loc 1 830 0 setp.gt.s32 %r1007,%r1006,0; @ %r1007 bra $L137; ld.s8 %r457,[%r349+-1]; setp.ne.u32 %r1008,%r1006,0; @ %r1008 bra $L138; and.b32 %r1009,%r322,1; setp.ne.u32 %r1010,%r1009,0; @ %r1010 bra $L131; $L138: add.u64 %r421,%r349,-1; bra $L139; $L142: add.u64 %r424,%r424,-1; .loc 1 834 0 setp.eq.u64 %r1011,%r1090,%r214; @ %r1011 bra $L140; ld.s8 %r457,[%r424]; mov.u64 %r349,%r1090; add.u64 %r1090,%r1090,-1; bra $L141; $L140: .loc 1 836 0 add.u32 %r448,%r332,1; .loc 1 837 0 mov.u32 %r1012,49; st.u8 [%r214],%r1012; .loc 1 838 0 bra $L124; $L137: ld.s8 %r457,[%r349+-1]; $L131: add.u64 %r1090,%r349,-1; mov.u64 %r424,%r1090; $L141: .loc 1 833 0 cvt.u16.u32 %r1013,%r457; setp.eq.u16 %r1014,%r1013,57; @ %r1014 bra $L142; .loc 1 840 0 add.u16 %r1016,%r1013,1; cvt.u32.u16 %r1018,%r1016; st.u8 [%r1090],%r1018; mov.u32 %r448,%r332; bra $L124; $L139: add.u64 %r349,%r421,1; add.u64 %r421,%r421,-1; .loc 1 844 0 cvt.u16.u32 %r1019,%r457; setp.ne.u16 %r1020,%r1019,48; @ %r1020 bra $L186; ld.s8 %r457,[%r421]; bra $L139; $L186: mov.u32 %r448,%r332; $L124: .loc 1 848 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 849 0 setp.eq.u64 %r1023,%r343,0; @ %r1023 bra $L187; .loc 1 851 0 set.u32.ne.u64 %r1025,%r342,0; neg.s32 %r1026,%r1025; set.u32.ne.u64 %r1028,%r342,%r343; neg.s32 %r1029,%r1028; cvt.u16.u32 %r1031,%r1026; cvt.u16.u32 %r1032,%r1029; and.b16 %r1030,%r1031,%r1032; cvt.u32.u16 %r1033,%r1030; cvt.u16.u8 %r1034,%r1033; setp.eq.u16 %r1035,%r1034,0; @ %r1035 bra $L188; .loc 1 852 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r342; call _Bfree,(%out_arg1,%out_arg2); } mov.u64 %r484,%r214; mov.u64 %r214,%r349; bra $L143; $L188: mov.u64 %r484,%r214; mov.u64 %r214,%r349; $L143: .loc 1 853 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; call _Bfree,(%out_arg1,%out_arg2); } bra $L68; $L167: .loc 1 504 0 mov.u64 %r484,%r587; .loc 1 503 0 mov.u64 %r214,%r347; bra $L68; $L168: .loc 1 855 0 mov.u64 %r484,%r587; .loc 1 503 0 mov.u64 %r214,%r409; bra $L68; $L172: .loc 1 590 0 mov.u64 %r484,%r214; .loc 1 572 0 mov.u64 %r214,%r347; .loc 1 590 0 mov.u32 %r448,%r332; bra $L68; $L173: mov.u64 %r484,%r214; mov.u64 %r214,%r347; mov.u32 %r448,%r332; bra $L68; $L174: mov.u64 %r484,%r214; mov.u64 %r214,%r347; mov.u32 %r448,%r332; bra $L68; $L175: mov.u64 %r484,%r214; .loc 1 572 0 mov.u64 %r214,%r229; mov.u32 %r448,%r332; bra $L68; $L187: .loc 1 855 0 mov.u64 %r484,%r214; mov.u64 %r214,%r349; $L68: .loc 1 856 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 857 0 mov.u32 %r1042,0; st.u8 [%r214],%r1042; .loc 1 858 0 add.u32 %r1043,%r448,1; st.u32 [%r489],%r1043; .loc 1 859 0 setp.eq.u64 %r1044,%r491,0; @ %r1044 bra $L21; .loc 1 860 0 st.u64 [%r491],%r214; bra $L21; $L153: .loc 1 288 0 cvta.const.u64 %r484,$LC2; bra $L21; $L26: .loc 1 270 0 setp.ne.u64 %r1046,%r491,0; @ %r1046 bra $L189; .loc 1 267 0 cvta.const.u64 %r484,$LC0; bra $L21; $L264: .loc 1 270 0 setp.ne.u64 %r1047,%r491,0; @ %r1047 bra $L190; .loc 1 267 0 cvta.const.u64 %r484,$LC1; bra $L21; $L62: .loc 1 480 0 cvt.rn.f64.s32 %r1048,%r327; fma.rn.f64 %r436,%r1048,%r465,0d401c000000000000; mov.b64 %r483,%r436; .loc 1 481 0 shr.u64 %r1050,%r483,32; cvt.u32.u64 %r1052,%r1050; add.u32 %r1051,%r1052,-54525952; cvt.u64.u32 %r1053,%r1051; shl.b64 %r1054,%r1053,32; and.b64 %r1055,%r483,4294967295; or.b64 %r483,%r1055,%r1054; bra $L145; $L112: .loc 1 724 0 setp.ne.u32 %r1057,%r459,0; @ %r1057 bra $L191; mov.u32 %r328,%r330; bra $L117; $L116: .loc 1 848 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 849 0 setp.ne.u64 %r1060,%r343,0; @ %r1060 bra $L143; bra $L68; $L146: .loc 1 427 0 mov.u32 %r1061,0; st.u32 [%r485+104],%r1061; .loc 1 430 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r1061; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r1064,[%value_in]; } mov.u64 %r214,%r1064; st.u64 [%r485+96],%r214; .loc 1 549 0 ld.u32 %r254,[%frame]; set.u32.le.s32 %r1066,%r332,14; neg.s32 %r1067,%r1066; not.b32 %r1069,%r254; shr.u32 %r1070,%r1069,31; cvt.u16.u32 %r1073,%r1067; cvt.u16.u32 %r1074,%r1070; and.b16 %r1072,%r1073,%r1074; cvt.u32.u16 %r1075,%r1072; cvt.u16.u8 %r1076,%r1075; setp.ne.u16 %r1077,%r1076,0; @ %r1077 bra $L192; .loc 1 400 0 mov.u32 %r330,-1; mov.u32 %r328,%r330; .loc 1 406 0 mov.u32 %r488,%r1061; .loc 1 399 0 mov.u32 %r334,1; bra $L148; $L158: mov.u32 %r455,1; $L42: .loc 1 401 0 setp.eq.u32 %r1078,%r487,3; @ %r1078 bra $L194; setp.gt.s32 %r1079,%r487,3; @ %r1079 bra $L149; setp.eq.u32 %r1080,%r487,2; @ %r1080 bra $L193; bra $L146; $L149: setp.eq.u32 %r1081,%r487,4; @ %r1081 bra $L43; setp.eq.u32 %r1082,%r487,5; @ ! %r1082 bra $L146; .loc 1 399 0 mov.u32 %r334,1; bra $L46; $L157: mov.u32 %r487,0; .loc 1 392 0 mov.u32 %r455,%r487; .loc 1 399 0 mov.u32 %r334,1; .loc 1 400 0 mov.u32 %r328,-1; .loc 1 406 0 mov.u32 %r488,%r487; bra $L41; $L159: .loc 1 413 0 mov.u32 %r488,1; mov.u32 %r328,%r488; $L41: .loc 1 427 0 mov.u32 %r1083,0; st.u32 [%r485+104],%r1083; mov.u32 %r330,%r328; mov.u32 %r211,%r1083; bra $L47; $L101: .loc 1 665 0 setp.le.s32 %r1084,%r487,1; @ %r1084 bra $L151; .loc 1 689 0 mov.u32 %r352,%r808; bra $L105; $L102: .loc 1 667 0 and.b64 %r1085,%r481,4503599627370495; setp.eq.u64 %r1086,%r1085,0; @ %r1086 bra $L152; .loc 1 664 0 mov.u32 %r338,0; bra $L103; $L151: .loc 1 667 0 and.b64 %r1087,%r481,4503599627370495; setp.eq.u64 %r1088,%r1087,0; @ %r1088 bra $L152; .loc 1 689 0 mov.u32 %r352,%r808; bra $L105; $L21: .loc 1 862 0 mov.u64 %value,%r484; st.param.u64 [%value_out],%value; ret; } /0 0 0 0 644 2062 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __dtoa .visible .func (.param .u64 %value_out) __dtoa (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5); .file 1 "../../../../../newlib/libc/stdlib/dtoastub.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DEF: __dtoa .visible .func (.param .u64 %value_out) __dtoa (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r37; .reg .u64 %r38; mov.f64 %r24,%ar0; mov.u32 %r25,%ar1; mov.u32 %r26,%ar2; mov.u64 %r27,%ar3; mov.u64 %r28,%ar4; mov.u64 %r29,%ar5; .loc 1 20 0 ld.global.u64 %r37,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r27; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r28; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r29; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r38,[%value_in]; } .loc 1 21 0 mov.u64 %value,%r38; st.param.u64 [%value_out],%value; ret; } lib_a-ecvtbuf.o/0 0 0 644 34710 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: print_e .func print_e (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5); .file 1 "../../../../../newlib/libc/stdlib/ecvtbuf.c" // BEGIN GLOBAL FUNCTION DECL: fcvtbuf .visible .func (.param .u64 %value_out) fcvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: ecvtbuf .visible .func (.param .u64 %value_out) ecvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: _gcvt .visible .func (.param .u64 %value_out) _gcvt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DECL: _dcvt .visible .func (.param .u64 %value_out) _dcvt (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u32 %in_ar6); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _realloc_r .extern .func (.param .u64 %value_out) _realloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _mprec_log10 .extern .func (.param .f64 %value_out) _mprec_log10 (.param .u32 %in_ar0); // BEGIN FUNCTION DEF: print_e .func print_e (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r145; .reg .u32 %r149; .reg .u64 %r163; .reg .u64 %r164; .reg .u64 %r165; .reg .u64 %r166; .reg .u64 %r168; .reg .u64 %r169; .reg .u32 %r170; .reg .u32 %r171; .reg .u32 %r186; .reg .u64 %r187; .reg .u64 %r188; .reg .f64 %r189; .reg .u32 %r190; .reg .u32 %r191; .reg .u32 %r192; .reg .u32 %r195; .reg .u64 %r200; .reg .u64 %r201; .reg .u32 %r202; .reg .u64 %r203; .reg .pred %r204; .reg .u64 %r207; .reg .u32 %r208; .reg .u32 %r209; .reg .pred %r210; .reg .u32 %r211; .reg .u16 %r213; .reg .u32 %r214; .reg .u32 %r215; .reg .u32 %r217; .reg .u32 %r218; .reg .u16 %r219; .reg .u16 %r220; .reg .u16 %r221; .reg .u32 %r222; .reg .u16 %r223; .reg .pred %r224; .reg .u32 %r225; .reg .u32 %r227; .reg .u32 %r228; .reg .u16 %r230; .reg .u32 %r231; .reg .u32 %r232; .reg .u16 %r233; .reg .u16 %r234; .reg .u16 %r235; .reg .u32 %r236; .reg .u16 %r237; .reg .pred %r238; .reg .u16 %r239; .reg .pred %r240; .reg .pred %r242; .reg .u16 %r243; .reg .pred %r244; .reg .pred %r246; .reg .pred %r247; .reg .u64 %r249; .reg .u64 %r250; .reg .u32 %r251; .reg .pred %r252; .reg .u64 %r254; .reg .u64 %r255; .reg .u32 %r256; .reg .pred %r257; .reg .u32 %r258; .reg .u32 %r259; .reg .u32 %r260; .reg .pred %r261; .reg .u16 %r263; .reg .u16 %r264; .reg .u32 %r265; .reg .u16 %r268; .reg .u16 %r269; .reg .u32 %r270; .reg .u32 %r272; .reg .u32 %r273; .reg .u32 %r274; .reg .u32 %r276; .reg .u16 %r278; .reg .u16 %r279; .reg .u32 %r280; .reg .u32 %r281; .reg .u32 %r282; mov.u64 %r187,%ar0; mov.u64 %r188,%ar1; mov.f64 %r189,%ar2; mov.u32 %r190,%ar3; mov.u32 %r191,%ar4; mov.u32 %r192,%ar5; .loc 1 161 0 add.u64 %r200,%frame,12; add.u64 %r201,%frame,8; add.u32 %r202,%r190,1; mov.u32 %r195,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r187; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r189; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r195; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r202; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r201; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r200; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r203,[%value_in]; } .loc 1 163 0 ld.u32 %r145,[%frame+8]; setp.ne.u32 %r204,%r145,9999; @ %r204 bra $L2; .loc 1 165 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r188; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r203; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r207,[%value_in]; } bra $L1; $L2: .loc 1 169 0 ld.u8 %r208,[%r203]; st.u8 [%r188],%r208; .loc 1 170 0 or.b32 %r209,%r190,%r192; setp.eq.u32 %r210,%r209,0; @ %r210 bra $L4; .loc 1 171 0 add.u64 %r163,%r188,2; mov.u32 %r211,46; st.u8 [%r188+1],%r211; .loc 1 173 0 ld.s8 %r149,[%r203+1]; cvt.u16.u32 %r213,%r149; set.u32.ne.u16 %r214,%r213,0; neg.s32 %r215,%r214; set.u32.gt.s32 %r217,%r190,0; neg.s32 %r218,%r217; cvt.u16.u32 %r220,%r215; cvt.u16.u32 %r221,%r218; and.b16 %r219,%r220,%r221; cvt.u32.u16 %r222,%r219; cvt.u16.u8 %r223,%r222; setp.eq.u16 %r224,%r223,0; @ %r224 bra $L5; .loc 1 169 0 add.u64 %r168,%r203,1; mov.u64 %r165,%r163; $L6: .loc 1 175 0 add.u64 %r168,%r168,1; add.u64 %r163,%r163,1; cvt.u32.u32 %r225,%r149; st.u8 [%r165],%r225; .loc 1 176 0 add.u32 %r190,%r190,-1; .loc 1 173 0 ld.s8 %r149,[%r168]; mov.u64 %r165,%r163; set.u32.gt.s32 %r227,%r190,0; neg.s32 %r228,%r227; cvt.u16.u32 %r230,%r149; set.u32.ne.u16 %r231,%r230,0; neg.s32 %r232,%r231; cvt.u16.u32 %r234,%r228; cvt.u16.u32 %r235,%r232; and.b16 %r233,%r234,%r235; cvt.u32.u16 %r236,%r233; cvt.u16.u8 %r237,%r236; setp.ne.u16 %r238,%r237,0; @ %r238 bra $L6; bra $L5; $L4: .loc 1 169 0 add.u64 %r163,%r188,1; .loc 1 182 0 cvt.u16.u32 %r239,%r191; setp.eq.u16 %r240,%r239,103; @ %r240 bra $L12; .loc 1 184 0 setp.eq.u16 %r242,%r239,71; .loc 1 185 0 selp.u32 %r191,69,%r191,%r242; bra $L7; $L5: .loc 1 182 0 cvt.u16.u32 %r243,%r191; setp.eq.u16 %r244,%r243,103; @ %r244 bra $L14; .loc 1 184 0 setp.eq.u16 %r246,%r243,71; @ %r246 bra $L15; .loc 1 188 0 setp.le.s32 %r247,%r190,0; @ %r247 bra $L7; mov.u64 %r169,%r163; add.u32 %r282,%r190,-1; cvt.u64.u32 %r249,%r282; add.u64 %r250,%r163,1; add.u64 %r166,%r249,%r250; .loc 1 190 0 mov.u32 %r251,48; $L8: st.u8 [%r169],%r251; add.u64 %r169,%r169,1; .loc 1 188 0 setp.ne.u64 %r252,%r166,%r169; @ %r252 bra $L8; cvt.s64.s32 %r254,%r282; add.u64 %r255,%r254,1; add.u64 %r163,%r163,%r255; bra $L7; $L12: .loc 1 183 0 mov.u32 %r191,101; bra $L7; $L14: mov.u32 %r191,101; bra $L7; $L15: .loc 1 185 0 mov.u32 %r191,69; $L7: .loc 1 197 0 cvt.u32.u32 %r256,%r191; st.u8 [%r163],%r256; .loc 1 198 0 add.u32 %r186,%r145,-1; add.u64 %r164,%r163,2; .loc 1 199 0 setp.ge.s32 %r257,%r186,0; @ %r257 bra $L9; .loc 1 201 0 mov.u32 %r258,45; st.u8 [%r163+1],%r258; .loc 1 202 0 mov.u32 %r259,1; sub.u32 %r186,%r259,%r145; bra $L10; $L9: .loc 1 206 0 mov.u32 %r260,43; st.u8 [%r163+1],%r260; $L10: .loc 1 208 0 setp.le.s32 %r261,%r186,99; @ %r261 bra $L11; .loc 1 210 0 div.s32 %r170,%r186,100; .loc 1 211 0 add.u64 %r164,%r163,3; cvt.u16.u32 %r264,%r170; add.u16 %r263,%r264,48; cvt.u32.u16 %r265,%r263; st.u8 [%r163+2],%r265; .loc 1 212 0 mad.lo.u32 %r186,%r170,-100,%r186; $L11: .loc 1 214 0 div.s32 %r171,%r186,10; .loc 1 215 0 cvt.u16.u32 %r269,%r171; add.u16 %r268,%r269,48; cvt.u32.u16 %r270,%r268; st.u8 [%r164],%r270; .loc 1 216 0 shl.b32 %r272,%r171,2; add.u32 %r273,%r272,%r171; add.u32 %r274,%r273,%r273; sub.u32 %r276,%r186,%r274; .loc 1 217 0 cvt.u16.u32 %r279,%r276; add.u16 %r278,%r279,48; cvt.u32.u16 %r280,%r278; st.u8 [%r164+1],%r280; .loc 1 219 0 mov.u32 %r281,0; st.u8 [%r164+2],%r281; $L1: .loc 1 220 0 ret; } // BEGIN GLOBAL FUNCTION DEF: fcvtbuf .visible .func (.param .u64 %value_out) fcvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r74; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r82; .reg .u64 %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r90; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r101; .reg .f64 %r102; .reg .u32 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .pred %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .u64 %r114; .reg .u64 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .u32 %r121; .reg .u64 %r126; .reg .u32 %r129; .reg .u64 %r134; .reg .u32 %r135; .reg .u64 %r136; .reg .pred %r137; .reg .u32 %r138; .reg .u64 %r139; .reg .pred %r140; .reg .pred %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .u64 %r144; .reg .u32 %r145; .reg .pred %r146; .reg .u64 %r147; .reg .u32 %r148; mov.f64 %r102,%ar0; mov.u32 %r103,%ar1; mov.u64 %r104,%ar2; mov.u64 %r105,%ar3; mov.u64 %r106,%ar4; .loc 1 236 0 ld.global.u64 %r82,[_impure_ptr]; .loc 1 242 0 setp.ne.u64 %r107,%r106,0; @ %r107 bra $L22; ld.u64 %r106,[%r82+136]; .loc 1 244 0 add.u32 %r108,%r103,35; ld.u32 %r109,[%r82+128]; setp.gt.s32 %r110,%r109,%r108; @ %r110 bra $L22; .loc 1 247 0 add.u32 %r74,%r103,36; .loc 1 246 0 cvt.s64.s32 %r114,%r74; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r82; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r106; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r114; call (%value_in),_realloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r115,[%value_in]; } mov.u64 %r106,%r115; setp.eq.u64 %r116,%r106,0; @ %r116 bra $L33; .loc 1 249 0 st.u32 [%r82+128],%r74; .loc 1 250 0 st.u64 [%r82+136],%r106; $L22: .loc 1 258 0 setp.lt.f64 %r117,%r102,0d3ff0000000000000; @ ! %r117 bra $L25; setp.gt.f64 %r118,%r102,0dbff0000000000000; @ ! %r118 bra $L25; .loc 1 260 0 mov.u32 %r121,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r82; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r102; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r121; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r103; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r104; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r105; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r126,[%value_in]; } mov.u64 %r80,%r126; bra $L28; $L25: .loc 1 264 0 mov.u32 %r129,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r82; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r102; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r129; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r103; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r104; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r105; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r134,[%value_in]; } mov.u64 %r80,%r134; $L28: .loc 1 269 0 ld.u32 %r135,[%r104]; neg.s32 %r86,%r135; .loc 1 270 0 ld.u64 %r136,[%frame]; setp.ge.u64 %r137,%r80,%r136; @ %r137 bra $L34; mov.u64 %r84,%r106; mov.u64 %r85,%r80; $L30: add.u64 %r90,%r84,1; .loc 1 272 0 ld.u8 %r138,[%r85]; st.u8 [%r84],%r138; .loc 1 273 0 add.u32 %r86,%r86,1; mov.u64 %r84,%r90; add.u64 %r85,%r85,1; .loc 1 270 0 ld.u64 %r139,[%frame]; setp.gt.u64 %r140,%r139,%r85; @ %r140 bra $L30; bra $L29; $L34: mov.u64 %r90,%r106; $L29: .loc 1 276 0 setp.le.s32 %r141,%r103,%r86; @ %r141 bra $L31; mov.u64 %r79,%r90; add.u32 %r142,%r103,-1; sub.u32 %r143,%r142,%r86; cvt.u64.u32 %r94,%r143; add.u64 %r144,%r90,1; add.u64 %r95,%r144,%r94; .loc 1 278 0 mov.u32 %r145,48; $L32: st.u8 [%r79],%r145; add.u64 %r79,%r79,1; .loc 1 276 0 setp.ne.u64 %r146,%r79,%r95; @ %r146 bra $L32; add.u64 %r147,%r94,1; add.u64 %r90,%r90,%r147; $L31: .loc 1 281 0 mov.u32 %r148,0; st.u8 [%r90],%r148; .loc 1 282 0 mov.u64 %r101,%r106; bra $L21; $L33: .loc 1 248 0 mov.u64 %r101,%r115; $L21: .loc 1 283 0 mov.u64 %value,%r101; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ecvtbuf .visible .func (.param .u64 %value_out) ecvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r64; .reg .u64 %r68; .reg .u64 %r70; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u64 %r78; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r90; .reg .f64 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .pred %r96; .reg .u32 %r97; .reg .pred %r98; .reg .u64 %r102; .reg .u64 %r103; .reg .pred %r104; .reg .u32 %r107; .reg .u64 %r112; .reg .u64 %r113; .reg .pred %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u64 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .u64 %r124; .reg .u32 %r125; mov.f64 %r91,%ar0; mov.u32 %r92,%ar1; mov.u64 %r93,%ar2; mov.u64 %r94,%ar3; mov.u64 %r95,%ar4; .loc 1 293 0 ld.global.u64 %r70,[_impure_ptr]; .loc 1 299 0 setp.ne.u64 %r96,%r95,0; @ %r96 bra $L40; ld.u64 %r95,[%r70+136]; .loc 1 301 0 ld.u32 %r97,[%r70+128]; setp.gt.s32 %r98,%r97,%r92; @ %r98 bra $L40; .loc 1 304 0 add.u32 %r64,%r92,1; .loc 1 303 0 cvt.s64.s32 %r102,%r64; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r95; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r102; call (%value_in),_realloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r103,[%value_in]; } mov.u64 %r95,%r103; setp.eq.u64 %r104,%r95,0; @ %r104 bra $L47; .loc 1 306 0 st.u32 [%r70+128],%r64; .loc 1 307 0 st.u64 [%r70+136],%r95; $L40: .loc 1 315 0 mov.u32 %r107,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r91; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r107; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r92; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r93; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r94; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r112,[%value_in]; } .loc 1 319 0 ld.u64 %r113,[%frame]; setp.ge.u64 %r114,%r112,%r113; @ %r114 bra $L48; mov.u64 %r73,%r95; mov.u64 %r74,%r112; .loc 1 297 0 mov.u32 %r75,0; $L44: add.u64 %r78,%r73,1; .loc 1 321 0 ld.u8 %r115,[%r74]; st.u8 [%r73],%r115; .loc 1 322 0 add.u32 %r75,%r75,1; mov.u64 %r73,%r78; add.u64 %r74,%r74,1; .loc 1 319 0 ld.u64 %r116,[%frame]; setp.gt.u64 %r117,%r116,%r74; @ %r117 bra $L44; bra $L43; $L48: mov.u64 %r78,%r95; .loc 1 297 0 mov.u32 %r75,0; $L43: .loc 1 325 0 setp.le.s32 %r118,%r92,%r75; @ %r118 bra $L45; mov.u64 %r68,%r78; add.u32 %r119,%r92,-1; sub.u32 %r120,%r119,%r75; cvt.u64.u32 %r83,%r120; add.u64 %r121,%r78,1; add.u64 %r84,%r121,%r83; .loc 1 327 0 mov.u32 %r122,48; $L46: st.u8 [%r68],%r122; add.u64 %r68,%r68,1; .loc 1 325 0 setp.ne.u64 %r123,%r68,%r84; @ %r123 bra $L46; add.u64 %r124,%r83,1; add.u64 %r78,%r78,%r124; $L45: .loc 1 330 0 mov.u32 %r125,0; st.u8 [%r78],%r125; .loc 1 331 0 mov.u64 %r90,%r95; bra $L39; $L47: .loc 1 305 0 mov.u64 %r90,%r103; $L39: .loc 1 332 0 mov.u64 %value,%r90; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _gcvt .visible .func (.param .u64 %value_out) _gcvt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r354; .reg .u32 %r357; .reg .u32 %r358; .reg .u32 %r361; .reg .u32 %r364; .reg .u32 %r365; .reg .u64 %r366; .reg .u64 %r369; .reg .u32 %r371; .reg .u64 %r372; .reg .u64 %r373; .reg .u64 %r374; .reg .u64 %r376; .reg .u64 %r377; .reg .u32 %r378; .reg .u32 %r383; .reg .u32 %r391; .reg .u64 %r395; .reg .u32 %r397; .reg .u64 %r405; .reg .u64 %r415; .reg .f64 %r416; .reg .u32 %r417; .reg .u64 %r418; .reg .u32 %r419; .reg .u32 %r420; .reg .pred %r421; .reg .pred %r422; .reg .u32 %r423; .reg .u32 %r424; .reg .pred %r425; .reg .u32 %r432; .reg .f64 %r434; .reg .pred %r435; .reg .pred %r436; .reg .u32 %r439; .reg .u64 %r444; .reg .u64 %r445; .reg .u64 %r446; .reg .u32 %r449; .reg .u64 %r454; .reg .u64 %r455; .reg .u64 %r456; .reg .pred %r457; .reg .pred %r458; .reg .pred %r459; .reg .u64 %r462; .reg .u32 %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u32 %r467; .reg .u32 %r468; .reg .u32 %r470; .reg .u32 %r471; .reg .u16 %r472; .reg .u16 %r473; .reg .u16 %r474; .reg .u32 %r475; .reg .u16 %r476; .reg .pred %r477; .reg .pred %r478; .reg .u32 %r479; .reg .u32 %r481; .reg .u32 %r482; .reg .u32 %r484; .reg .u32 %r485; .reg .u16 %r486; .reg .u16 %r487; .reg .u16 %r488; .reg .u32 %r489; .reg .u16 %r490; .reg .pred %r491; .reg .pred %r492; .reg .u16 %r493; .reg .u32 %r494; .reg .pred %r495; .reg .pred %r496; .reg .u32 %r497; .reg .u32 %r498; .reg .u32 %r499; .reg .u32 %r500; .reg .u32 %r501; .reg .u32 %r503; .reg .u16 %r505; .reg .u16 %r506; .reg .u16 %r507; .reg .u32 %r508; .reg .u16 %r509; .reg .pred %r510; .reg .u32 %r511; .reg .u32 %r512; .reg .u32 %r513; .reg .u32 %r514; .reg .u32 %r516; .reg .u16 %r518; .reg .u16 %r519; .reg .u16 %r520; .reg .u32 %r521; .reg .u16 %r522; .reg .pred %r523; .reg .u16 %r525; .reg .u32 %r526; .reg .u32 %r527; .reg .u16 %r528; .reg .u16 %r529; .reg .u16 %r530; .reg .u32 %r531; .reg .u16 %r532; .reg .pred %r533; .reg .u32 %r534; .reg .u16 %r536; .reg .u32 %r537; .reg .u32 %r538; .reg .u32 %r540; .reg .u32 %r541; .reg .u16 %r542; .reg .u16 %r543; .reg .u16 %r544; .reg .u32 %r545; .reg .u16 %r546; .reg .pred %r547; .reg .pred %r548; .reg .pred %r549; .reg .u64 %r551; .reg .u64 %r552; .reg .u32 %r553; .reg .pred %r554; .reg .u64 %r556; .reg .u64 %r557; .reg .u32 %r558; .reg .u32 %r560; mov.u64 %r415,%ar0; mov.f64 %r416,%ar1; mov.u32 %r417,%ar2; mov.u64 %r418,%ar3; mov.u32 %r419,%ar4; mov.u32 %r420,%ar5; .loc 1 347 0 setp.lt.f64 %r421,%r416,0d0000000000000000; @ ! %r421 bra $L52; .loc 1 349 0 neg.f64 %r416,%r416; $L52: .loc 1 352 0 setp.neu.f64 %r422,%r416,0d0000000000000000; @ %r422 bra $L54; .loc 1 354 0 mov.u32 %r423,48; st.u8 [%r418],%r423; .loc 1 355 0 mov.u32 %r424,0; st.u8 [%r418+1],%r424; bra $L55; $L54: .loc 1 363 0 setp.le.f64 %r425,%r416,0d3f1a36e2eb1c432d; @ ! %r425 bra $L97; $L58: .loc 1 372 0 add.u32 %r432,%r417,-1; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r415; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r418; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r416; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r432; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r419; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r420; call print_e,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } bra $L55; $L97: .loc 1 363 0 { .param .f64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r417; call (%value_in),_mprec_log10,(%out_arg1); ld.param.f64 %r434,[%value_in]; } setp.le.f64 %r435,%r434,%r416; @ %r435 bra $L58; .loc 1 381 0 setp.lt.f64 %r436,%r416,0d3ff0000000000000; @ ! %r436 bra $L98; .loc 1 384 0 add.u64 %r444,%frame,8; add.u64 %r445,%frame,12; mov.u32 %r439,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r415; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r416; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r439; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r417; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r445; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r444; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r446,[%value_in]; } mov.u64 %r376,%r446; bra $L61; $L98: .loc 1 388 0 add.u64 %r454,%frame,8; add.u64 %r455,%frame,12; mov.u32 %r449,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r415; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r416; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r449; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r417; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r455; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r454; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r456,[%value_in]; } mov.u64 %r376,%r456; $L61: .loc 1 391 0 ld.u32 %r354,[%frame+12]; setp.eq.u32 %r457,%r354,9999; @ %r457 bra $L62; .loc 1 396 0 ld.s8 %r358,[%r376]; setp.eq.u32 %r458,%r358,0; @ %r458 bra $L79; setp.gt.s32 %r459,%r354,0; @ %r459 bra $L64; mov.u64 %r366,%r418; mov.u32 %r378,%r417; bra $L68; $L62: .loc 1 393 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r418; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r376; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r462,[%value_in]; } bra $L55; $L64: mov.u64 %r377,%r418; .loc 1 396 0 mov.u32 %r357,%r354; $L69: .loc 1 398 0 add.u64 %r376,%r376,1; add.u64 %r366,%r377,1; cvt.u32.u32 %r463,%r358; st.u8 [%r377],%r463; .loc 1 399 0 add.u32 %r357,%r357,-1; st.u32 [%frame+12],%r357; sub.u32 %r464,%r357,%r354; add.u32 %r378,%r464,%r417; .loc 1 396 0 ld.s8 %r358,[%r376]; setp.ne.u32 %r465,%r358,0; @ %r465 bra $L66; bra $L63; $L79: mov.u32 %r357,%r354; mov.u64 %r366,%r418; mov.u32 %r378,%r417; $L63: .loc 1 403 0 set.u32.gt.s32 %r467,%r378,0; neg.s32 %r468,%r467; set.u32.gt.s32 %r470,%r357,0; neg.s32 %r471,%r470; cvt.u16.u32 %r473,%r468; cvt.u16.u32 %r474,%r471; and.b16 %r472,%r473,%r474; cvt.u32.u16 %r475,%r472; cvt.u16.u8 %r476,%r475; setp.ne.u16 %r477,%r476,0; @ %r477 bra $L67; bra $L68; $L66: mov.u64 %r377,%r366; .loc 1 396 0 setp.ne.u32 %r478,%r357,0; @ %r478 bra $L69; bra $L68; $L67: add.u32 %r391,%r357,-1; mov.u64 %r374,%r366; .loc 1 405 0 mov.u32 %r479,48; $L70: add.u64 %r366,%r366,1; st.u8 [%r374],%r479; .loc 1 406 0 mov.u32 %r361,%r391; .loc 1 407 0 add.u32 %r378,%r378,-1; add.u32 %r391,%r391,-1; mov.u64 %r374,%r366; .loc 1 403 0 set.u32.gt.s32 %r481,%r361,0; neg.s32 %r482,%r481; set.u32.gt.s32 %r484,%r378,0; neg.s32 %r485,%r484; cvt.u16.u32 %r487,%r482; cvt.u16.u32 %r488,%r485; and.b16 %r486,%r487,%r488; cvt.u32.u16 %r489,%r486; cvt.u16.u8 %r490,%r489; setp.ne.u16 %r491,%r490,0; @ %r491 bra $L70; st.u32 [%frame+12],%r361; $L68: .loc 1 410 0 setp.ne.u32 %r492,%r420,0; @ %r492 bra $L71; ld.s8 %r494,[%r376]; cvt.u16.u32 %r493,%r494; setp.eq.u16 %r495,%r493,0; @ %r495 bra $L72; $L71: add.u64 %r405,%r366,1; .loc 1 412 0 setp.ne.u64 %r496,%r418,%r366; @ %r496 bra $L73; .loc 1 413 0 mov.u32 %r497,48; st.u8 [%r418],%r497; mov.u64 %r366,%r405; add.u64 %r405,%r418,2; $L73: .loc 1 414 0 mov.u32 %r498,46; st.u8 [%r366],%r498; .loc 1 415 0 ld.u32 %r397,[%frame+12]; set.u32.gt.s32 %r500,%r378,0; neg.s32 %r501,%r500; cvt.u32.u32 %r499,%r501; cvt.u32.u8 %r383,%r499; shr.u32 %r503,%r397,31; cvt.u16.u32 %r506,%r503; cvt.u16.u32 %r507,%r383; and.b16 %r505,%r506,%r507; cvt.u32.u16 %r508,%r505; cvt.u16.u8 %r509,%r508; setp.eq.u16 %r510,%r509,0; @ %r510 bra $L80; add.u32 %r371,%r397,1; mov.u64 %r369,%r405; .loc 1 417 0 mov.u32 %r511,48; $L75: add.u64 %r366,%r369,1; st.u8 [%r369],%r511; .loc 1 418 0 mov.u32 %r364,%r371; .loc 1 419 0 add.u32 %r378,%r378,-1; .loc 1 415 0 set.u32.gt.s32 %r513,%r378,0; neg.s32 %r514,%r513; cvt.u32.u32 %r512,%r514; cvt.u32.u8 %r383,%r512; add.u32 %r371,%r371,1; mov.u64 %r369,%r366; shr.u32 %r516,%r364,31; cvt.u16.u32 %r519,%r516; cvt.u16.u32 %r520,%r383; and.b16 %r518,%r519,%r520; cvt.u32.u16 %r521,%r518; cvt.u16.u8 %r522,%r521; setp.ne.u16 %r523,%r522,0; @ %r523 bra $L75; st.u32 [%frame+12],%r364; bra $L74; $L80: .loc 1 414 0 mov.u64 %r366,%r405; $L74: .loc 1 423 0 ld.s8 %r365,[%r376]; cvt.u16.u32 %r525,%r365; set.u32.ne.u16 %r526,%r525,0; neg.s32 %r527,%r526; cvt.u16.u32 %r529,%r527; cvt.u16.u32 %r530,%r383; and.b16 %r528,%r529,%r530; cvt.u32.u16 %r531,%r528; cvt.u16.u8 %r532,%r531; setp.eq.u16 %r533,%r532,0; @ %r533 bra $L76; mov.u64 %r372,%r366; $L77: .loc 1 425 0 add.u64 %r376,%r376,1; add.u64 %r366,%r366,1; cvt.u32.u32 %r534,%r365; st.u8 [%r372],%r534; .loc 1 426 0 add.u32 %r378,%r378,-1; .loc 1 423 0 ld.s8 %r365,[%r376]; mov.u64 %r372,%r366; cvt.u16.u32 %r536,%r365; set.u32.ne.u16 %r537,%r536,0; neg.s32 %r538,%r537; set.u32.gt.s32 %r540,%r378,0; neg.s32 %r541,%r540; cvt.u16.u32 %r543,%r538; cvt.u16.u32 %r544,%r541; and.b16 %r542,%r543,%r544; cvt.u32.u16 %r545,%r542; cvt.u16.u8 %r546,%r545; setp.ne.u16 %r547,%r546,0; @ %r547 bra $L77; $L76: .loc 1 429 0 setp.eq.u32 %r548,%r420,0; @ %r548 bra $L72; .loc 1 431 0 setp.le.s32 %r549,%r378,0; @ %r549 bra $L72; mov.u64 %r395,%r366; add.u32 %r560,%r378,-1; cvt.u64.u32 %r551,%r560; add.u64 %r552,%r366,1; add.u64 %r373,%r551,%r552; .loc 1 433 0 mov.u32 %r553,48; $L78: st.u8 [%r395],%r553; add.u64 %r395,%r395,1; .loc 1 431 0 setp.ne.u64 %r554,%r373,%r395; @ %r554 bra $L78; cvt.s64.s32 %r556,%r560; add.u64 %r557,%r556,1; add.u64 %r366,%r366,%r557; $L72: .loc 1 438 0 mov.u32 %r558,0; st.u8 [%r366],%r558; $L55: .loc 1 442 0 mov.u64 %value,%r418; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _dcvt .visible .func (.param .u64 %value_out) _dcvt (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u32 %in_ar6) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u32 %ar6; ld.param.u32 %ar6,[%in_ar6]; .local .align 8 .b8 %frame_ar[16]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r257; .reg .u64 %r258; .reg .u32 %r266; .reg .u64 %r268; .reg .u64 %r269; .reg .u32 %r270; .reg .u32 %r271; .reg .u64 %r272; .reg .u64 %r275; .reg .u32 %r276; .reg .u32 %r280; .reg .u64 %r282; .reg .u64 %r285; .reg .u64 %r294; .reg .u64 %r295; .reg .u32 %r298; .reg .u64 %r302; .reg .u64 %r307; .reg .u64 %r308; .reg .u64 %r312; .reg .u64 %r313; .reg .f64 %r314; .reg .u32 %r315; .reg .u32 %r317; .reg .u32 %r318; .reg .u16 %r320; .reg .u16 %r321; .reg .u32 %r322; .reg .u16 %r323; .reg .pred %r324; .reg .u64 %r325; .reg .u64 %r326; .reg .pred %r327; .reg .u64 %r328; .reg .pred %r329; .reg .u64 %r330; .reg .pred %r331; .reg .pred %r332; .reg .u32 %r335; .reg .u64 %r340; .reg .u64 %r341; .reg .u64 %r342; .reg .pred %r343; .reg .pred %r344; .reg .pred %r345; .reg .u64 %r348; .reg .u32 %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .u64 %r353; .reg .u64 %r355; .reg .u32 %r356; .reg .pred %r357; .reg .u64 %r359; .reg .u64 %r360; .reg .u32 %r361; .reg .pred %r362; .reg .u16 %r363; .reg .u32 %r364; .reg .pred %r365; .reg .pred %r366; .reg .u32 %r367; .reg .u32 %r368; .reg .u32 %r370; .reg .u32 %r371; .reg .u32 %r373; .reg .u16 %r375; .reg .u16 %r376; .reg .u16 %r377; .reg .u32 %r378; .reg .u16 %r379; .reg .pred %r380; .reg .u32 %r381; .reg .u32 %r383; .reg .u32 %r385; .reg .u32 %r386; .reg .u16 %r388; .reg .u16 %r389; .reg .u16 %r390; .reg .u32 %r391; .reg .u16 %r392; .reg .pred %r393; .reg .pred %r394; .reg .pred %r395; .reg .u32 %r396; .reg .pred %r397; .reg .pred %r398; .reg .pred %r399; .reg .u64 %r401; .reg .u64 %r402; .reg .u32 %r403; .reg .pred %r404; .reg .u64 %r406; .reg .u64 %r407; .reg .u32 %r408; .reg .pred %r409; .reg .u64 %r416; .reg .u32 %r424; .reg .u32 %r425; mov.u64 %r312,%ar0; mov.u64 %r313,%ar1; mov.f64 %r314,%ar2; mov.u32 %r315,%ar3; mov.u32 %r317,%ar5; mov.u32 %r318,%ar6; cvt.u16.u32 %r321,%r317; add.u16 %r320,%r321,-69; cvt.u32.u16 %r322,%r320; cvt.u32.u8 %r257,%r322; cvt.u16.u32 %r323,%r257; setp.gt.u16 %r324,%r323,34; @ %r324 bra $L100; mov.u64 %r325,1; shl.b64 %r258,%r325,%r257; and.b64 %r326,%r258,4294967297; setp.ne.u64 %r327,%r326,0; @ %r327 bra $L101; and.b64 %r328,%r258,17179869188; setp.ne.u64 %r329,%r328,0; @ %r329 bra $L102; and.b64 %r330,%r258,8589934594; setp.eq.u64 %r331,%r330,0; @ %r331 bra $L100; .loc 1 458 0 setp.ne.u32 %r332,%r315,0; selp.u32 %r318,1,%r318,%r332; .loc 1 91 0 add.u64 %r340,%frame,8; add.u64 %r341,%frame,12; mov.u32 %r335,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r312; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r314; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r335; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r315; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r341; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r340; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r342,[%value_in]; } .loc 1 93 0 ld.u32 %r271,[%frame+12]; setp.eq.u32 %r343,%r271,9999; @ %r343 bra $L104; .loc 1 98 0 ld.s8 %r270,[%r342]; setp.eq.u32 %r344,%r270,0; @ %r344 bra $L125; setp.gt.s32 %r345,%r271,0; @ %r345 bra $L106; mov.u64 %r268,%r342; mov.u64 %r294,%r313; bra $L110; $L104: .loc 1 95 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r313; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r342; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r348,[%value_in]; } bra $L100; $L106: mov.u64 %r307,%r313; .loc 1 98 0 mov.u64 %r268,%r342; $L111: .loc 1 100 0 add.u64 %r268,%r268,1; add.u64 %r294,%r307,1; cvt.u32.u32 %r349,%r270; st.u8 [%r307],%r349; .loc 1 101 0 add.u32 %r271,%r271,-1; st.u32 [%frame+12],%r271; .loc 1 98 0 ld.s8 %r270,[%r268]; setp.ne.u32 %r350,%r270,0; @ %r350 bra $L108; bra $L105; $L125: mov.u64 %r268,%r342; mov.u64 %r294,%r313; $L105: .loc 1 104 0 setp.gt.s32 %r351,%r271,0; @ %r351 bra $L109; bra $L110; $L108: mov.u64 %r307,%r294; .loc 1 98 0 setp.ne.u32 %r352,%r271,0; @ %r352 bra $L111; bra $L110; $L109: mov.u64 %r302,%r294; add.u64 %r353,%r294,1; add.u32 %r424,%r271,-1; cvt.u64.u32 %r355,%r424; add.u64 %r308,%r353,%r355; .loc 1 106 0 mov.u32 %r356,48; $L112: st.u8 [%r302],%r356; add.u64 %r302,%r302,1; .loc 1 104 0 setp.ne.u64 %r357,%r302,%r308; @ %r357 bra $L112; cvt.s64.s32 %r359,%r424; add.u64 %r360,%r359,1; add.u64 %r294,%r294,%r360; mov.u32 %r361,0; st.u32 [%frame+12],%r361; $L110: .loc 1 110 0 setp.ne.u32 %r362,%r318,0; @ %r362 bra $L113; ld.s8 %r364,[%r268]; cvt.u16.u32 %r363,%r364; setp.eq.u16 %r365,%r363,0; @ %r365 bra $L114; $L113: add.u64 %r285,%r294,1; .loc 1 112 0 setp.ne.u64 %r366,%r342,%r268; @ %r366 bra $L115; .loc 1 113 0 mov.u32 %r367,48; st.u8 [%r294],%r367; add.u64 %r272,%r294,2; mov.u64 %r294,%r285; mov.u64 %r285,%r272; $L115: .loc 1 114 0 mov.u32 %r368,46; st.u8 [%r294],%r368; .loc 1 115 0 ld.u32 %r266,[%frame+12]; set.u32.gt.s32 %r370,%r315,0; neg.s32 %r371,%r370; shr.u32 %r373,%r266,31; cvt.u16.u32 %r376,%r371; cvt.u16.u32 %r377,%r373; and.b16 %r375,%r376,%r377; cvt.u32.u16 %r378,%r375; cvt.u16.u8 %r379,%r378; setp.eq.u16 %r380,%r379,0; @ %r380 bra $L116; add.u32 %r298,%r266,1; mov.u64 %r269,%r285; .loc 1 117 0 mov.u32 %r381,48; $L117: add.u64 %r285,%r285,1; st.u8 [%r269],%r381; .loc 1 118 0 mov.u32 %r276,%r298; .loc 1 119 0 add.u32 %r315,%r315,-1; add.u32 %r298,%r298,1; mov.u64 %r269,%r285; .loc 1 115 0 shr.u32 %r383,%r276,31; set.u32.gt.s32 %r385,%r315,0; neg.s32 %r386,%r385; cvt.u16.u32 %r389,%r383; cvt.u16.u32 %r390,%r386; and.b16 %r388,%r389,%r390; cvt.u32.u16 %r391,%r388; cvt.u16.u8 %r392,%r391; setp.ne.u16 %r393,%r392,0; @ %r393 bra $L117; st.u32 [%frame+12],%r276; $L116: .loc 1 123 0 ld.s8 %r280,[%r268]; setp.eq.u32 %r394,%r280,0; @ %r394 bra $L126; setp.le.s32 %r395,%r315,0; @ %r395 bra $L127; mov.u64 %r275,%r285; $L121: .loc 1 125 0 add.u64 %r268,%r268,1; add.u64 %r294,%r275,1; cvt.u32.u32 %r396,%r280; st.u8 [%r275],%r396; .loc 1 126 0 add.u32 %r315,%r315,-1; .loc 1 123 0 ld.s8 %r280,[%r268]; setp.ne.u32 %r397,%r280,0; @ %r397 bra $L119; bra $L118; $L126: mov.u64 %r294,%r285; $L118: .loc 1 129 0 setp.gt.s32 %r398,%r315,0; @ %r398 bra $L120; bra $L114; $L119: mov.u64 %r275,%r294; .loc 1 123 0 setp.ne.u32 %r399,%r315,0; @ %r399 bra $L121; bra $L114; $L120: mov.u64 %r282,%r294; add.u32 %r425,%r315,-1; cvt.u64.u32 %r401,%r425; add.u64 %r402,%r294,1; add.u64 %r295,%r401,%r402; .loc 1 131 0 mov.u32 %r403,48; $L122: st.u8 [%r282],%r403; add.u64 %r282,%r282,1; .loc 1 129 0 setp.ne.u64 %r404,%r282,%r295; @ %r404 bra $L122; cvt.s64.s32 %r406,%r425; add.u64 %r407,%r406,1; add.u64 %r294,%r294,%r407; bra $L114; $L127: .loc 1 123 0 mov.u64 %r294,%r285; $L114: .loc 1 135 0 mov.u32 %r408,0; st.u8 [%r294],%r408; bra $L100; $L102: .loc 1 462 0 setp.eq.u32 %r409,%r315,0; .loc 1 463 0 selp.u32 %r315,1,%r315,%r409; .loc 1 464 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r312; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r314; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r315; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r313; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r317; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r318; call (%value_in),_gcvt,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u64 %r416,[%value_in]; } .loc 1 465 0 bra $L100; $L101: .loc 1 468 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r312; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r313; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r314; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r315; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r317; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r318; call print_e,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } $L100: .loc 1 471 0 mov.u64 %value,%r313; st.param.u64 [%value_out],%value; ret; } lib_a-efgcvt.o/ 0 0 0 644 8332 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fcvt .visible .func (.param .u64 %value_out) fcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdlib/efgcvt.c" // BEGIN GLOBAL FUNCTION DECL: fcvtf .visible .func (.param .u64 %value_out) fcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: ecvt .visible .func (.param .u64 %value_out) ecvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: ecvtf .visible .func (.param .u64 %value_out) ecvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: gcvt .visible .func (.param .u64 %value_out) gcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: gcvtf .visible .func (.param .u64 %value_out) gcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: fcvtbuf .extern .func (.param .u64 %value_out) fcvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: ecvtbuf .extern .func (.param .u64 %value_out) ecvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: _gcvt .extern .func (.param .u64 %value_out) _gcvt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DEF: fcvt .visible .func (.param .u64 %value_out) fcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f64 %r23; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; mov.u64 %r25,%ar2; mov.u64 %r26,%ar3; .loc 1 147 0 mov.u64 %r31,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r31; call (%value_in),fcvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r32,[%value_in]; } .loc 1 148 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: fcvtf .visible .func (.param .u64 %value_out) fcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r32; .reg .f64 %r33; .reg .u64 %r34; mov.f32 %r24,%ar0; mov.u32 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 157 0 cvt.f64.f32 %r33,%r24; .loc 1 147 0 mov.u64 %r32,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r27; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r32; call (%value_in),fcvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r34,[%value_in]; } .loc 1 158 0 mov.u64 %value,%r34; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ecvt .visible .func (.param .u64 %value_out) ecvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f64 %r23; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; mov.u64 %r25,%ar2; mov.u64 %r26,%ar3; .loc 1 179 0 mov.u64 %r31,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r31; call (%value_in),ecvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r32,[%value_in]; } .loc 1 180 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ecvtf .visible .func (.param .u64 %value_out) ecvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r32; .reg .f64 %r33; .reg .u64 %r34; mov.f32 %r24,%ar0; mov.u32 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 189 0 cvt.f64.f32 %r33,%r24; .loc 1 179 0 mov.u64 %r32,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r27; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r32; call (%value_in),ecvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r34,[%value_in]; } .loc 1 190 0 mov.u64 %value,%r34; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: gcvt .visible .func (.param .u64 %value_out) gcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .f64 %r26; .reg .u32 %r27; .reg .u64 %r28; .reg .pred %r29; .reg .u32 %r30; .reg .u32 %r35; .reg .u32 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .pred %r39; mov.f64 %r26,%ar0; mov.u32 %r27,%ar1; mov.u64 %r28,%ar2; .loc 1 200 0 setp.lt.f64 %r29,%r26,0d0000000000000000; @ ! %r29 bra $L11; .loc 1 201 0 mov.u32 %r30,45; st.u8 [%r28],%r30; .loc 1 202 0 add.u64 %r24,%r28,1; .loc 1 203 0 add.u32 %r27,%r27,-1; bra $L6; $L11: mov.u64 %r24,%r28; $L6: .loc 1 205 0 ld.global.u64 %r37,[_impure_ptr]; mov.u32 %r36,0; mov.u32 %r35,103; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r24; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r35; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r36; call (%value_in),_gcvt,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u64 %r38,[%value_in]; } setp.ne.u64 %r39,%r38,0; selp.u64 %value,%r28,0,%r39; .loc 1 206 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: gcvtf .visible .func (.param .u64 %value_out) gcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .f64 %r30; .reg .u64 %r31; mov.f32 %r24,%ar0; mov.u32 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 167 0 cvt.f64.f32 %r30,%r24; .loc 1 168 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; call (%value_in),gcvt,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r31,[%value_in]; } .loc 1 169 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } lib_a-erand48.o/0 0 0 644 2958 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _erand48_r .visible .func (.param .f64 %value_out) _erand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/erand48.c" // BEGIN GLOBAL FUNCTION DECL: erand48 .visible .func (.param .f64 %value_out) erand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: ldexp .extern .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _erand48_r .visible .func (.param .f64 %value_out) _erand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r28; .reg .u64 %r33; .reg .u64 %r34; .reg .u32 %r38; .reg .f64 %r39; .reg .u32 %r40; .reg .f64 %r41; .reg .u32 %r43; .reg .f64 %r44; .reg .u32 %r45; .reg .f64 %r46; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .f64 %r51; mov.u64 %r33,%ar0; mov.u64 %r34,%ar1; .loc 1 21 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r40,[%r34]; cvt.rn.f64.u32 %r39,%r40; mov.u32 %r38,-48; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r38; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } .loc 1 23 0 ld.u16 %r45,[%r34+2]; cvt.rn.f64.u32 %r44,%r45; mov.u32 %r43,-32; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r43; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } .loc 1 22 0 add.f64 %r28,%r41,%r46; .loc 1 24 0 ld.u16 %r50,[%r34+4]; cvt.rn.f64.u32 %r49,%r50; mov.u32 %r48,-16; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r51,[%value_in]; } .loc 1 23 0 add.f64 %value,%r28,%r51; .loc 1 25 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: erand48 .visible .func (.param .f64 %value_out) erand48 (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r27; .reg .f64 %r28; mov.u64 %r24,%ar0; .loc 1 32 0 ld.global.u64 %r27,[_impure_ptr]; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),_erand48_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } .loc 1 33 0 mov.f64 %value,%r28; st.param.f64 [%value_out],%value; ret; } lib_a-errno.o/ 0 0 0 644 508 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __errno .visible .func (.param .u64 %value_out) __errno; .file 1 "../../../../../newlib/libc/errno/errno.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: __errno .visible .func (.param .u64 %value_out) __errno { .reg .u64 %value; .loc 1 13 0 ld.global.u64 %value,[_impure_ptr]; .loc 1 14 0 st.param.u64 [%value_out],%value; ret; } lib_a-exit.o/ 0 0 0 644 732 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exit .visible .func exit (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/machine/nvptx/exit.c" // BEGIN GLOBAL VAR DEF: __exitval_ptr .weak .global .align 8 .u64 __exitval_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: exit .visible .func exit (.param .u32 %in_ar0) { .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u32 %r23; .reg .pred %r24; mov.u32 %r23,%ar0; .loc 1 28 0 ld.global.u64 %r22,[__exitval_ptr]; setp.eq.u64 %r24,%r22,0; @ %r24 bra $L3; .loc 1 29 0 st.u32 [%r22],%r23; $L3: .loc 1 31 0 // #APP // 31 "../../../../../../newlib/libc/machine/nvptx/exit.c" 1 exit; // #NO_APP bra $L3; } lib_a-ffs.o/ 0 0 0 644 874 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ffs .visible .func (.param .u32 %value_out) ffs (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/misc/ffs.c" // BEGIN GLOBAL FUNCTION DEF: ffs .visible .func (.param .u32 %value_out) ffs (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r25; .reg .u32 %r26; .reg .u32 %r27; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r30; .reg .pred %r31; mov.u32 %r28,%ar0; .loc 1 37 0 setp.eq.u32 %r29,%r28,0; @ %r29 bra $L4; .loc 1 40 0 mov.u32 %r26,0; $L3: .loc 1 43 0 add.u32 %r27,%r26,1; shr.s32 %r30,%r28,%r26; and.b32 %r25,%r30,1; mov.u32 %r26,%r27; setp.eq.u32 %r31,%r25,0; @ %r31 bra $L3; bra $L1; $L4: .loc 1 38 0 mov.u32 %r27,%r28; $L1: .loc 1 46 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } /18 0 0 0 644 3798 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fix_locale_grouping_str .visible .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/locale/fix_grouping.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN VAR DEF: nogrouping .const .align 1 .u8 nogrouping[2] = {127,0 }; // BEGIN GLOBAL FUNCTION DEF: __fix_locale_grouping_str .visible .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r31; .reg .u32 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u64 %r45; .reg .u64 %r47; .reg .u64 %r48; .reg .pred %r49; .reg .pred %r50; .reg .u16 %r51; .reg .pred %r52; .reg .pred %r54; .reg .u16 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r59; .reg .u64 %r60; .reg .u64 %r62; .reg .u16 %r65; .reg .u16 %r66; .reg .u32 %r67; .reg .u16 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u16 %r71; .reg .u16 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u16 %r79; .reg .u16 %r80; .reg .u32 %r81; .reg .u16 %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u32 %r88; .reg .u32 %r89; .reg .u16 %r90; .reg .u16 %r91; .reg .u16 %r94; .reg .u16 %r97; .reg .u16 %r98; .reg .u16 %r101; .reg .u32 %r104; .reg .u32 %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .u32 %r109; .reg .u32 %r111; .reg .u16 %r112; .reg .u32 %r113; mov.u64 %r48,%ar0; .loc 1 45 0 setp.ne.u64 %r49,%r48,0; @ %r49 bra $L2; $L4: .loc 1 46 0 cvta.const.u64 %r47,nogrouping; bra $L1; $L2: .loc 1 45 0 ld.s8 %r38,[%r48]; setp.eq.u32 %r50,%r38,0; @ %r50 bra $L4; mov.u64 %r40,%r48; mov.u64 %r45,%r48; .loc 1 56 0 mov.u32 %r111,127; $L10: .loc 1 52 0 cvt.u16.u32 %r51,%r38; setp.eq.u16 %r52,%r51,59; @ %r52 bra $L11; .loc 1 55 0 setp.ne.u16 %r54,%r51,45; @ %r54 bra $L6; ld.s8 %r56,[%r45+1]; cvt.u16.u32 %r55,%r56; setp.ne.u16 %r57,%r55,49; @ %r57 bra $L6; .loc 1 56 0 st.u8 [%r40],%r111; .loc 1 57 0 add.u64 %r39,%r45,1; .loc 1 56 0 add.u64 %r40,%r40,1; .loc 1 58 0 bra $L5; $L6: .loc 1 61 0 ld.global.u64 %r23,[__ctype_ptr__]; cvt.u32.u32 %r59,%r38; cvt.u32.u8 %r24,%r59; cvt.u64.u8 %r60,%r59; add.u64 %r62,%r23,%r60; ld.u8 %r112,[%r62+1]; mov.u16 %r66,%r112; and.b16 %r65,%r66,4; cvt.u32.u16 %r67,%r65; cvt.s32.s8 %r69,%r67; cvt.u16.u32 %r68,%r69; setp.eq.u16 %r70,%r68,0; @ %r70 bra $L4; .loc 1 67 0 cvt.u16.u32 %r72,%r24; add.u16 %r71,%r72,-48; cvt.u32.u16 %r73,%r71; .loc 1 68 0 ld.u8 %r31,[%r45+1]; cvt.u32.u32 %r75,%r31; cvt.u64.u8 %r74,%r75; add.u64 %r76,%r23,%r74; ld.u8 %r112,[%r76+1]; mov.u16 %r80,%r112; and.b16 %r79,%r80,4; cvt.u32.u16 %r81,%r79; cvt.s32.s8 %r83,%r81; cvt.u16.u32 %r82,%r83; setp.ne.u16 %r84,%r82,0; @ %r84 bra $L7; .loc 1 67 0 cvt.s32.s8 %r41,%r73; mov.u64 %r39,%r45; bra $L8; $L7: .loc 1 69 0 add.u64 %r39,%r45,1; .loc 1 70 0 cvt.u32.u8 %r113,%r73; mov.u32 %r89,%r113; shl.b32 %r88,%r89,2; cvt.u16.u32 %r91,%r88; add.u16 %r90,%r91,%r71; add.u16 %r94,%r90,%r90; .loc 1 71 0 cvt.u16.u32 %r98,%r31; add.u16 %r97,%r98,-48; add.u16 %r101,%r94,%r97; cvt.u32.u16 %r104,%r101; cvt.s32.s8 %r41,%r104; $L8: .loc 1 74 0 cvt.u32.u32 %r105,%r41; st.u8 [%r40],%r105; .loc 1 76 0 setp.ne.u32 %r106,%r41,0; @ %r106 bra $L9; .loc 1 77 0 setp.ne.u64 %r107,%r48,%r40; @ %r107 bra $L12; bra $L4; $L9: .loc 1 78 0 add.u64 %r40,%r40,1; bra $L5; $L11: mov.u64 %r39,%r45; $L5: .loc 1 49 0 add.u64 %r45,%r39,1; ld.s8 %r38,[%r39+1]; setp.ne.u32 %r108,%r38,0; @ %r108 bra $L10; .loc 1 80 0 cvt.u32.u32 %r109,%r38; st.u8 [%r40],%r109; .loc 1 81 0 mov.u64 %r47,%r48; bra $L1; $L12: mov.u64 %r47,%r48; $L1: .loc 1 82 0 mov.u64 %value,%r47; st.param.u64 [%value_out],%value; ret; } lib_a-free.o/ 0 0 0 644 712 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .visible .func __nvptx_free (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/machine/nvptx/free.c" // BEGIN GLOBAL FUNCTION DECL: free .extern .func free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __nvptx_free .visible .func __nvptx_free (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .pred %r24; .reg .u64 %r26; mov.u64 %r23,%ar0; .loc 1 33 0 setp.eq.u64 %r24,%r23,0; @ %r24 bra $L1; .loc 1 34 0 add.u64 %r26,%r23,-8; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call free,(%out_arg1); } $L1: .loc 1 35 0 ret; } /40 0 0 0 644 28013 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: rshift .func rshift (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/gdtoa-gethex.c" // BEGIN GLOBAL FUNCTION DECL: __gethex .visible .func (.param .u32 %value_out) __gethex (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strncmp .extern .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __hi0bits .extern .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __any_on .extern .func (.param .u32 %value_out) __any_on (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __lshift .extern .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DEF: __hexdig .visible .const .align 1 .u8 __hexdig[256] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,16,17,18,19,20,21,22,23,24,25,0,0,0,0,0,0,0,26,27,28,29,30,31,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,26,27,28,29,30,31,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // BEGIN FUNCTION DEF: rshift .func rshift (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u64 %r59; .reg .u32 %r60; .reg .u64 %r61; .reg .u32 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r76; .reg .u64 %r77; .reg .u32 %r79; .reg .u64 %r85; .reg .u64 %r90; .reg .u64 %r99; .reg .u32 %r100; .reg .u64 %r103; .reg .u64 %r105; .reg .u32 %r106; .reg .pred %r107; .reg .u32 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .pred %r113; .reg .pred %r114; .reg .u32 %r116; .reg .u32 %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r137; .reg .pred %r138; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r143; .reg .u64 %r144; .reg .u64 %r146; .reg .pred %r147; .reg .u32 %r148; mov.u64 %r105,%ar0; mov.u32 %r106,%ar1; .loc 1 80 0 add.u64 %r85,%r105,24; .loc 1 81 0 shr.s32 %r70,%r106,5; .loc 1 82 0 ld.u32 %r49,[%r105+20]; setp.gt.s32 %r107,%r49,%r70; @ %r107 bra $L2; .loc 1 99 0 mov.u32 %r108,0; st.u32 [%r105+20],%r108; bra $L3; $L2: mov.u64 %r103,%r85; .loc 1 83 0 cvt.s64.s32 %r109,%r49; shl.b64 %r110,%r109,2; add.u64 %r71,%r85,%r110; .loc 1 84 0 cvt.s64.s32 %r111,%r70; shl.b64 %r112,%r111,2; add.u64 %r72,%r85,%r112; .loc 1 85 0 and.b32 %r73,%r106,31; setp.ne.u32 %r113,%r73,0; @ %r113 bra $L4; .loc 1 96 0 setp.gt.u64 %r114,%r71,%r72; @ %r114 bra $L5; .loc 1 99 0 st.u32 [%r105+20],%r73; bra $L3; $L4: .loc 1 86 0 mov.u32 %r116,32; sub.u32 %r76,%r116,%r73; .loc 1 87 0 add.u64 %r77,%r72,4; ld.u32 %r117,[%r72]; shr.u32 %r79,%r117,%r73; .loc 1 88 0 setp.le.u64 %r118,%r71,%r77; @ %r118 bra $L6; mov.u64 %r59,%r85; mov.u64 %r99,%r77; $L7: .loc 1 89 0 ld.u32 %r120,[%r99]; shl.b32 %r119,%r120,%r76; or.b32 %r121,%r119,%r79; st.u32 [%r59],%r121; .loc 1 90 0 ld.u32 %r122,[%r99]; shr.u32 %r79,%r122,%r73; add.u64 %r59,%r59,4; add.u64 %r99,%r99,4; .loc 1 88 0 setp.gt.u64 %r123,%r71,%r99; @ %r123 bra $L7; sub.u64 %r125,%r71,%r72; add.u64 %r126,%r125,-5; and.b64 %r128,%r126,-4; add.u64 %r129,%r128,4; add.u64 %r85,%r85,%r129; $L6: .loc 1 92 0 st.u32 [%r85],%r79; setp.ne.u32 %r130,%r79,0; @ %r130 bra $L8; sub.u64 %r131,%r85,%r103; shr.s64 %r133,%r131,2; cvt.u32.u64 %r100,%r133; bra $L9; $L8: .loc 1 93 0 add.u64 %r134,%r85,4; sub.u64 %r135,%r134,%r103; shr.s64 %r137,%r135,2; cvt.u32.u64 %r100,%r137; bra $L9; $L5: mov.u64 %r90,%r72; mov.u64 %r61,%r85; $L10: .loc 1 97 0 ld.u32 %r60,[%r90]; st.u32 [%r61],%r60; add.u64 %r90,%r90,4; add.u64 %r61,%r61,4; .loc 1 96 0 setp.gt.u64 %r138,%r71,%r90; @ %r138 bra $L10; not.b64 %r140,%r72; add.u64 %r141,%r140,%r71; and.b64 %r143,%r141,-4; add.u64 %r144,%r143,4; shr.s64 %r146,%r144,2; cvt.u32.u64 %r100,%r146; $L9: .loc 1 99 0 st.u32 [%r105+20],%r100; setp.ne.u32 %r147,%r100,0; @ %r147 bra $L1; $L3: .loc 1 100 0 mov.u32 %r148,0; st.u32 [%r105+24],%r148; $L1: .loc 1 101 0 ret; } // BEGIN GLOBAL FUNCTION DEF: __gethex .visible .func (.param .u32 %value_out) __gethex (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u32 %in_ar5) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r73; .reg .u32 %r75; .reg .u64 %r76; .reg .u32 %r89; .reg .u32 %r91; .reg .u64 %r102; .reg .u32 %r114; .reg .u32 %r116; .reg .u32 %r129; .reg .u64 %r166; .reg .u64 %r167; .reg .u32 %r168; .reg .u32 %r169; .reg .u32 %r170; .reg .u64 %r172; .reg .u64 %r174; .reg .u32 %r175; .reg .u64 %r176; .reg .u32 %r178; .reg .u32 %r180; .reg .u64 %r181; .reg .u32 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .u32 %r186; .reg .u32 %r188; .reg .u32 %r189; .reg .u32 %r190; .reg .u32 %r191; .reg .u32 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .u64 %r195; .reg .u32 %r196; .reg .u32 %r197; .reg .u64 %r198; .reg .u64 %r201; .reg .u64 %r202; .reg .u32 %r204; .reg .u32 %r206; .reg .u64 %r219; .reg .u64 %r223; .reg .u32 %r224; .reg .u32 %r225; .reg .u64 %r228; .reg .u64 %r231; .reg .u64 %r232; .reg .u32 %r233; .reg .u32 %r237; .reg .u32 %r238; .reg .u32 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u32 %r245; .reg .u64 %r247; .reg .u64 %r249; .reg .u64 %r250; .reg .u16 %r252; .reg .pred %r253; .reg .u16 %r254; .reg .pred %r255; .reg .u64 %r257; .reg .u64 %r258; .reg .u16 %r259; .reg .pred %r260; .reg .u32 %r264; .reg .pred %r265; .reg .u64 %r267; .reg .u64 %r268; .reg .pred %r269; .reg .u16 %r270; .reg .pred %r271; .reg .u16 %r272; .reg .pred %r273; .reg .u64 %r275; .reg .u64 %r276; .reg .u16 %r278; .reg .u32 %r279; .reg .u64 %r283; .reg .u64 %r284; .reg .u16 %r285; .reg .pred %r286; .reg .u64 %r289; .reg .u64 %r290; .reg .pred %r291; .reg .u32 %r295; .reg .pred %r296; .reg .pred %r297; .reg .u64 %r299; .reg .u64 %r300; .reg .u16 %r301; .reg .pred %r302; .reg .u64 %r304; .reg .u64 %r305; .reg .u16 %r306; .reg .pred %r307; .reg .pred %r308; .reg .u64 %r309; .reg .u32 %r310; .reg .u32 %r311; .reg .u16 %r312; .reg .pred %r313; .reg .pred %r315; .reg .u16 %r316; .reg .pred %r317; .reg .pred %r319; .reg .u64 %r321; .reg .u64 %r322; .reg .u16 %r323; .reg .u16 %r324; .reg .u16 %r325; .reg .u32 %r326; .reg .pred %r327; .reg .u64 %r330; .reg .u64 %r331; .reg .u16 %r332; .reg .u16 %r333; .reg .u16 %r334; .reg .u32 %r335; .reg .pred %r336; .reg .u32 %r338; .reg .u32 %r339; .reg .u32 %r340; .reg .u64 %r343; .reg .u64 %r344; .reg .u16 %r345; .reg .u16 %r346; .reg .u16 %r347; .reg .u32 %r348; .reg .pred %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .u64 %r353; .reg .u32 %r354; .reg .pred %r355; .reg .pred %r356; .reg .u64 %r359; .reg .pred %r360; .reg .u16 %r361; .reg .u16 %r362; .reg .pred %r363; .reg .pred %r364; .reg .u64 %r365; .reg .pred %r367; .reg .u32 %r371; .reg .pred %r372; .reg .u64 %r375; .reg .u64 %r376; .reg .u16 %r378; .reg .u16 %r379; .reg .u32 %r380; .reg .u32 %r381; .reg .u32 %r382; .reg .pred %r383; .reg .u64 %r384; .reg .u64 %r386; .reg .u32 %r388; .reg .pred %r389; .reg .u32 %r392; .reg .pred %r393; .reg .u32 %r394; .reg .u64 %r395; .reg .u64 %r396; .reg .u64 %r397; .reg .u32 %r398; .reg .u32 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .u32 %r402; .reg .pred %r403; .reg .pred %r404; .reg .u32 %r407; .reg .u32 %r408; .reg .pred %r409; .reg .pred %r412; .reg .u64 %r416; .reg .u32 %r417; .reg .pred %r418; .reg .u64 %r421; .reg .pred %r422; .reg .pred %r423; .reg .u32 %r424; .reg .pred %r425; .reg .pred %r426; .reg .pred %r427; .reg .pred %r428; .reg .pred %r429; .reg .u32 %r432; .reg .u32 %r433; .reg .pred %r434; .reg .pred %r435; .reg .pred %r436; .reg .u32 %r437; .reg .u64 %r441; .reg .pred %r442; .reg .pred %r443; .reg .u32 %r446; .reg .u32 %r447; .reg .u64 %r448; .reg .u64 %r449; .reg .u64 %r450; .reg .u32 %r451; .reg .u32 %r452; .reg .u32 %r453; .reg .u32 %r454; .reg .u32 %r455; .reg .pred %r456; .reg .pred %r459; .reg .u32 %r460; .reg .pred %r461; .reg .pred %r462; .reg .pred %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u32 %r466; .reg .u32 %r467; .reg .u32 %r468; .reg .pred %r469; .reg .u32 %r470; .reg .pred %r471; .reg .u64 %r472; .reg .pred %r473; .reg .u32 %r474; .reg .pred %r476; .reg .u32 %r477; .reg .pred %r478; .reg .u32 %r481; .reg .u32 %r482; .reg .u64 %r483; .reg .u64 %r487; .reg .u64 %r488; .reg .u64 %r489; .reg .u64 %r490; .reg .u64 %r491; .reg .u64 %r492; .reg .u32 %r495; .reg .u64 %r496; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r499; .reg .u32 %r500; .reg .pred %r501; .reg .u32 %r502; .reg .u32 %r503; .reg .pred %r504; .reg .u32 %r505; .reg .u64 %r506; .reg .u64 %r507; .reg .u64 %r508; .reg .u32 %r509; .reg .u32 %r510; .reg .u32 %r511; .reg .u32 %r512; .reg .u32 %r513; .reg .pred %r514; .reg .u32 %r515; .reg .pred %r516; .reg .u32 %r518; .reg .u32 %r519; .reg .pred %r520; .reg .pred %r521; .reg .u32 %r522; .reg .u64 %r523; .reg .u32 %r525; .reg .u32 %r526; .reg .u32 %r527; .reg .pred %r528; .reg .u16 %r530; .reg .pred %r531; .reg .pred %r533; .reg .u64 %r534; .reg .u32 %r535; .reg .u16 %r536; mov.u64 %r240,%ar0; mov.u64 %r241,%ar1; mov.u64 %r242,%ar2; mov.u64 %r243,%ar3; mov.u64 %r244,%ar4; mov.u32 %r245,%ar5; .loc 1 162 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r247,[%value_in]; } .loc 1 161 0 ld.u64 %r176,[%r247]; .loc 1 163 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r176; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r249,[%value_in]; } .loc 1 164 0 add.u64 %r250,%r176,%r249; ld.u8 %r178,[%r250+-1]; .loc 1 167 0 ld.u64 %r67,[%r241]; .loc 1 168 0 ld.u8 %r68,[%r67+2]; cvt.u16.u32 %r252,%r68; setp.ne.u16 %r253,%r252,48; @ %r253 bra $L15; add.u64 %r228,%r67,3; .loc 1 166 0 mov.u32 %r224,0; $L16: .loc 1 169 0 add.u32 %r224,%r224,1; .loc 1 168 0 mov.u64 %r223,%r228; add.u64 %r228,%r228,1; ld.u8 %r68,[%r228+-1]; cvt.u16.u32 %r254,%r68; setp.eq.u16 %r255,%r254,48; @ %r255 bra $L16; bra $L17; $L15: add.u64 %r223,%r67,2; .loc 1 166 0 mov.u32 %r224,0; $L17: .loc 1 175 0 cvta.const.u64 %r534,__hexdig; cvt.s64.s32 %r257,%r68; add.u64 %r258,%r534,%r257; ld.u8 %r259,[%r258]; setp.ne.u16 %r260,%r259,0; @ %r260 bra $L18; .loc 1 177 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r223; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r176; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r249; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r264,[%value_in]; } setp.ne.u32 %r265,%r264,0; @ %r265 bra $L19; .loc 1 180 0 add.u64 %r76,%r223,%r249; .loc 1 181 0 ld.u8 %r73,[%r76]; cvt.s64.s32 %r267,%r73; add.u64 %r268,%r534,%r267; ld.u8 %r237,[%r268]; setp.eq.u32 %r269,%r237,0; @ %r269 bra $L20; .loc 1 183 0 cvt.u16.u32 %r270,%r73; setp.ne.u16 %r271,%r270,48; @ %r271 bra $L88; mov.u64 %r223,%r76; $L22: .loc 1 184 0 add.u64 %r223,%r223,1; .loc 1 183 0 ld.u8 %r75,[%r223]; cvt.u16.u32 %r272,%r75; setp.eq.u16 %r273,%r272,48; @ %r273 bra $L22; cvt.s64.s32 %r275,%r75; add.u64 %r276,%r534,%r275; ld.u8 %r237,[%r276]; bra $L21; $L88: mov.u64 %r223,%r76; $L21: .loc 1 185 0 cvt.u16.u32 %r278,%r237; set.u32.eq.u16 %r279,%r278,0; neg.s32 %r225,%r279; .loc 1 187 0 mov.u32 %r224,1; bra $L23; $L89: .loc 1 190 0 mov.u64 %r181,%r223; $L24: .loc 1 191 0 add.u64 %r181,%r181,1; .loc 1 190 0 ld.u8 %r283,[%r181]; add.u64 %r284,%r534,%r283; ld.u8 %r285,[%r284]; setp.ne.u16 %r286,%r285,0; @ %r286 bra $L24; bra $L25; $L18: ld.u8 %r289,[%r223]; add.u64 %r290,%r534,%r289; ld.u8 %r237,[%r290]; .loc 1 173 0 mov.u32 %r225,0; .loc 1 172 0 mov.u64 %r76,0; $L23: .loc 1 190 0 setp.ne.u32 %r291,%r237,0; @ %r291 bra $L89; mov.u64 %r181,%r223; $L25: .loc 1 192 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r181; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r176; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r249; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r295,[%value_in]; } setp.ne.u32 %r296,%r295,0; @ %r296 bra $L26; .loc 1 194 0 setp.eq.u64 %r297,%r76,0; @ %r297 bra $L27; ld.u8 %r238,[%r181]; bra $L28; $L27: .loc 1 195 0 add.u64 %r76,%r181,%r249; .loc 1 196 0 ld.u8 %r238,[%r76]; cvt.s64.s32 %r299,%r238; add.u64 %r300,%r534,%r299; ld.u8 %r301,[%r300]; setp.eq.u16 %r302,%r301,0; @ %r302 bra $L90; mov.u64 %r181,%r76; $L30: .loc 1 197 0 add.u64 %r181,%r181,1; .loc 1 196 0 ld.u8 %r238,[%r181]; cvt.s64.s32 %r304,%r238; add.u64 %r305,%r534,%r304; ld.u8 %r306,[%r305]; setp.ne.u16 %r307,%r306,0; @ %r307 bra $L30; bra $L28; $L26: ld.u8 %r238,[%r181]; .loc 1 199 0 setp.eq.u64 %r308,%r76,0; @ %r308 bra $L91; $L28: .loc 1 200 0 sub.u64 %r309,%r181,%r76; cvt.u32.u64 %r311,%r309; shl.b32 %r310,%r311,2; neg.s32 %r175,%r310; bra $L31; $L91: .loc 1 174 0 cvt.u32.u64 %r175,%r76; $L31: .loc 1 203 0 cvt.u16.u32 %r312,%r238; setp.eq.u16 %r313,%r312,80; @ %r313 bra $L93; setp.eq.u16 %r315,%r312,112; @ ! %r315 bra $L168; $L93: mov.u64 %r76,%r181; bra $L33; $L106: mov.u32 %r175,0; mov.u32 %r225,1; $L33: .loc 1 207 0 ld.u8 %r233,[%r76+1]; cvt.u16.u32 %r316,%r233; setp.eq.u16 %r317,%r316,43; @ %r317 bra $L94; setp.eq.u16 %r319,%r316,45; @ ! %r319 bra $L169; .loc 1 209 0 mov.u32 %r168,1; bra $L35; $L169: .loc 1 207 0 add.u64 %r167,%r76,1; .loc 1 206 0 mov.u32 %r168,0; bra $L37; $L94: mov.u32 %r168,0; $L35: .loc 1 212 0 add.u64 %r167,%r76,2; ld.u8 %r233,[%r76+2]; $L37: .loc 1 214 0 cvt.s64.s32 %r321,%r233; add.u64 %r322,%r534,%r321; ld.u8 %r89,[%r322]; cvt.u16.u32 %r324,%r89; add.u16 %r323,%r324,-1; cvt.u32.u16 %r326,%r323; cvt.u16.u8 %r325,%r326; setp.gt.u16 %r327,%r325,24; @ %r327 bra $L95; .loc 1 218 0 add.u32 %r184,%r89,-16; .loc 1 219 0 add.u64 %r181,%r167,1; ld.u8 %r330,[%r167+1]; add.u64 %r331,%r534,%r330; ld.u8 %r183,[%r331]; cvt.u16.u32 %r333,%r183; add.u16 %r332,%r333,-1; cvt.u32.u16 %r335,%r332; cvt.u16.u8 %r334,%r335; setp.gt.u16 %r336,%r334,24; @ %r336 bra $L38; $L39: .loc 1 220 0 shl.b32 %r338,%r184,2; add.u32 %r339,%r338,%r184; add.u32 %r340,%r339,%r339; add.u32 %r91,%r340,%r183; add.u32 %r184,%r91,-16; .loc 1 219 0 add.u64 %r181,%r181,1; ld.u8 %r343,[%r181]; add.u64 %r344,%r534,%r343; ld.u8 %r183,[%r344]; cvt.u16.u32 %r346,%r183; add.u16 %r345,%r346,-1; cvt.u32.u16 %r348,%r345; cvt.u16.u8 %r347,%r348; setp.le.u16 %r349,%r347,24; @ %r349 bra $L39; $L38: .loc 1 221 0 setp.eq.u32 %r350,%r168,0; @ %r350 bra $L40; .loc 1 222 0 neg.s32 %r184,%r184; $L40: .loc 1 223 0 add.u32 %r175,%r175,%r184; bra $L32; $L168: .loc 1 203 0 mov.u64 %r76,%r181; bra $L32; $L95: mov.u64 %r181,%r76; $L32: .loc 1 225 0 st.u64 [%r241],%r181; .loc 1 226 0 setp.eq.u32 %r351,%r225,0; @ %r351 bra $L41; $L87: .loc 1 227 0 setp.eq.u32 %r352,%r224,0; selp.u32 %r239,6,0,%r352; bra $L14; $L41: .loc 1 228 0 sub.u64 %r353,%r76,%r223; cvt.u32.u64 %r354,%r353; add.u32 %r197,%r354,-1; .loc 1 229 0 setp.le.s32 %r355,%r197,7; @ %r355 bra $L97; mov.u32 %r196,%r225; $L44: .loc 1 230 0 add.u32 %r196,%r196,1; .loc 1 229 0 shr.s32 %r197,%r197,1; setp.gt.s32 %r356,%r197,7; @ %r356 bra $L44; bra $L43; $L97: mov.u32 %r196,%r225; $L43: .loc 1 231 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r196; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r359,[%value_in]; } mov.u64 %r166,%r359; .loc 1 232 0 add.u64 %r174,%r359,24; .loc 1 235 0 setp.ge.u64 %r360,%r223,%r76; @ %r360 bra $L45; .loc 1 232 0 mov.u64 %r219,%r174; .loc 1 233 0 mov.u32 %r69,%r225; .loc 1 234 0 mov.u32 %r180,0; .loc 1 236 0 cvt.u16.u32 %r362,%r178; $L52: add.u64 %r195,%r76,-1; add.u64 %r232,%r219,4; ld.u8 %r361,[%r76+-1]; setp.eq.u16 %r363,%r361,%r362; @ %r363 bra $L46; $L49: .loc 1 242 0 setp.eq.u32 %r364,%r69,32; @ ! %r364 bra $L170; bra $L47; $L46: .loc 1 236 0 sub.u64 %r365,%r195,%r249; add.u64 %r102,%r365,1; setp.lt.u64 %r367,%r102,%r223; @ %r367 bra $L49; .loc 1 237 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r176; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r249; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r371,[%value_in]; } setp.eq.u32 %r372,%r371,0; @ ! %r372 bra $L49; bra $L98; $L170: .loc 1 242 0 mov.u32 %r169,%r69; add.u32 %r69,%r69,4; bra $L51; $L47: .loc 1 243 0 st.u32 [%r219],%r180; add.u64 %r231,%r219,8; mov.u64 %r219,%r232; mov.u64 %r232,%r231; .loc 1 245 0 mov.u32 %r169,%r225; .loc 1 243 0 mov.u32 %r69,4; .loc 1 244 0 mov.u32 %r180,0; $L51: .loc 1 247 0 ld.u8 %r375,[%r76+-1]; add.u64 %r376,%r534,%r375; ld.u8 %r536,[%r376]; mov.u16 %r379,%r536; and.b16 %r378,%r379,15; cvt.u32.u16 %r381,%r378; cvt.u32.u8 %r380,%r381; shl.b32 %r382,%r380,%r169; or.b32 %r180,%r180,%r382; .loc 1 236 0 mov.u64 %r76,%r195; bra $L50; $L98: mov.u64 %r76,%r102; $L50: .loc 1 235 0 setp.gt.u64 %r383,%r76,%r223; @ %r383 bra $L52; bra $L53; $L45: add.u64 %r232,%r359,28; .loc 1 232 0 mov.u64 %r219,%r174; .loc 1 234 0 mov.u32 %r180,0; $L53: .loc 1 250 0 st.u32 [%r219],%r180; .loc 1 251 0 sub.u64 %r384,%r232,%r174; shr.s64 %r386,%r384,2; cvt.u32.u64 %r185,%r386; st.u32 [%r359+20],%r185; .loc 1 252 0 shl.b32 %r114,%r185,5; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r180; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r388,[%value_in]; } sub.u32 %r186,%r114,%r388; .loc 1 253 0 ld.u32 %r170,[%r242]; .loc 1 256 0 setp.le.s32 %r389,%r186,%r170; @ %r389 bra $L54; .loc 1 257 0 sub.u32 %r189,%r186,%r170; .loc 1 258 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r359; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r189; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r392,[%value_in]; } mov.u32 %r116,%r392; setp.eq.u32 %r393,%r116,0; @ %r393 bra $L55; .loc 1 260 0 add.u32 %r190,%r189,-1; .loc 1 261 0 shr.s32 %r394,%r190,5; cvt.s64.s32 %r395,%r394; shl.b64 %r396,%r395,2; add.u64 %r397,%r174,%r396; and.b32 %r398,%r190,31; mov.u32 %r400,1; shl.b32 %r399,%r400,%r398; ld.u32 %r402,[%r397]; and.b32 %r401,%r399,%r402; setp.eq.u32 %r403,%r401,0; @ %r403 bra $L99; .loc 1 263 0 setp.gt.s32 %r404,%r190,1; @ %r404 bra $L56; $L57: .loc 1 262 0 mov.u32 %r116,2; bra $L55; $L56: .loc 1 263 0 add.u32 %r407,%r189,-2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r359; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r407; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r408,[%value_in]; } setp.eq.u32 %r409,%r408,0; @ %r409 bra $L57; .loc 1 264 0 mov.u32 %r116,3; bra $L55; $L99: .loc 1 259 0 mov.u32 %r116,%r400; $L55: .loc 1 267 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r359; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r189; call rshift,(%out_arg1,%out_arg2); } .loc 1 268 0 add.u32 %r175,%r175,%r189; bra $L58; $L54: .loc 1 270 0 setp.ge.s32 %r412,%r186,%r170; @ %r412 bra $L100; .loc 1 271 0 sub.u32 %r188,%r170,%r186; .loc 1 272 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r359; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r188; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r416,[%value_in]; } mov.u64 %r166,%r416; .loc 1 273 0 sub.u32 %r175,%r175,%r188; .loc 1 274 0 add.u64 %r174,%r166,24; .loc 1 254 0 mov.u32 %r116,0; bra $L58; $L100: mov.u32 %r116,0; $L58: .loc 1 276 0 ld.u32 %r417,[%r242+8]; setp.ge.s32 %r418,%r417,%r175; @ %r418 bra $L59; $L60: .loc 1 278 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r166; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 279 0 mov.u64 %r421,0; st.u64 [%r244],%r421; .loc 1 280 0 mov.u32 %r239,163; bra $L14; $L59: .loc 1 283 0 ld.u32 %r129,[%r242+4]; setp.le.s32 %r422,%r129,%r175; @ %r422 bra $L101; .loc 1 285 0 sub.u32 %r191,%r129,%r175; .loc 1 286 0 setp.gt.s32 %r423,%r170,%r191; @ %r423 bra $L62; .loc 1 287 0 ld.u32 %r424,[%r242+12]; setp.eq.u32 %r425,%r424,2; @ %r425 bra $L64; setp.eq.u32 %r426,%r424,3; @ %r426 bra $L65; setp.eq.u32 %r427,%r424,1; @ ! %r427 bra $L63; .loc 1 289 0 setp.eq.u32 %r428,%r170,%r191; @ ! %r428 bra $L63; setp.le.s32 %r429,%r170,1; @ %r429 bra $L68; add.u32 %r432,%r170,-1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r432; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r433,[%value_in]; } setp.eq.u32 %r434,%r433,0; @ %r434 bra $L63; ld.u32 %r129,[%r242+4]; bra $L68; $L64: .loc 1 293 0 setp.eq.u32 %r435,%r245,0; @ %r435 bra $L68; bra $L63; $L65: .loc 1 297 0 setp.eq.u32 %r436,%r245,0; @ %r436 bra $L63; $L68: .loc 1 299 0 st.u32 [%r243],%r129; .loc 1 300 0 mov.u32 %r437,1; st.u32 [%r166+20],%r437; st.u32 [%r174],%r437; .loc 1 301 0 st.u64 [%r244],%r166; .loc 1 302 0 mov.u32 %r239,98; bra $L14; $L63: .loc 1 306 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r166; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 307 0 mov.u64 %r441,0; st.u64 [%r244],%r441; .loc 1 308 0 mov.u32 %r239,80; bra $L14; $L62: .loc 1 310 0 add.u32 %r192,%r191,-1; .loc 1 311 0 setp.ne.u32 %r442,%r116,0; @ %r442 bra $L102; .loc 1 313 0 setp.eq.u32 %r443,%r192,0; @ %r443 bra $L70; .loc 1 314 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r192; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r446,[%value_in]; } mov.u32 %r116,%r446; bra $L70; $L102: .loc 1 312 0 mov.u32 %r116,1; $L70: .loc 1 315 0 shr.s32 %r447,%r192,5; cvt.s64.s32 %r448,%r447; shl.b64 %r449,%r448,2; add.u64 %r450,%r174,%r449; and.b32 %r451,%r192,31; mov.u32 %r453,1; shl.b32 %r452,%r453,%r451; ld.u32 %r455,[%r450]; and.b32 %r454,%r452,%r455; setp.eq.u32 %r456,%r454,0; @ %r456 bra $L71; .loc 1 316 0 or.b32 %r116,%r116,2; $L71: .loc 1 317 0 sub.u32 %r170,%r170,%r191; .loc 1 318 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r191; call rshift,(%out_arg1,%out_arg2); } .loc 1 319 0 ld.u32 %r175,[%r242+4]; .loc 1 284 0 mov.u32 %r239,2; bra $L61; $L101: .loc 1 282 0 mov.u32 %r239,1; $L61: .loc 1 321 0 setp.eq.u32 %r459,%r116,0; @ %r459 bra $L72; .loc 1 323 0 ld.u32 %r460,[%r242+12]; setp.eq.u32 %r461,%r460,2; @ %r461 bra $L74; setp.eq.u32 %r462,%r460,3; @ %r462 bra $L75; setp.eq.u32 %r463,%r460,1; @ ! %r463 bra $L73; .loc 1 327 0 and.b32 %r464,%r116,2; setp.eq.u32 %r465,%r464,0; @ %r465 bra $L73; .loc 1 328 0 ld.u32 %r467,[%r174]; or.b32 %r466,%r116,%r467; and.b32 %r468,%r466,1; setp.ne.u32 %r469,%r468,0; @ %r469 bra $L77; bra $L73; $L74: .loc 1 332 0 mov.u32 %r470,1; sub.u32 %r245,%r470,%r245; $L75: .loc 1 337 0 setp.eq.u32 %r471,%r245,0; @ %r471 bra $L73; $L77: .loc 1 338 0 ld.u32 %r193,[%r166+20]; .loc 1 114 0 add.u64 %r198,%r166,24; .loc 1 115 0 cvt.s64.s32 %r472,%r193; shl.b64 %r201,%r472,2; add.u64 %r202,%r198,%r201; mov.u64 %r172,%r198; .loc 1 122 0 mov.u32 %r535,0; $L80: .loc 1 118 0 ld.u32 %r204,[%r172]; setp.eq.u32 %r473,%r204,-1; @ %r473 bra $L78; .loc 1 119 0 add.u32 %r474,%r204,1; st.u32 [%r172],%r474; bra $L79; $L78: .loc 1 122 0 st.u32 [%r172],%r535; add.u64 %r172,%r172,4; .loc 1 123 0 setp.gt.u64 %r476,%r202,%r172; @ %r476 bra $L80; .loc 1 135 0 ld.u32 %r206,[%r166+20]; ld.u32 %r477,[%r166+12]; setp.lt.s32 %r478,%r206,%r477; @ %r478 bra $L81; .loc 1 136 0 ld.u32 %r482,[%r166+8]; add.u32 %r481,%r482,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r481; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r483,[%value_in]; } .loc 1 137 0 ld.s32 %r487,[%r166+20]; add.u64 %r488,%r487,2; shl.b64 %r489,%r488,2; add.u64 %r490,%r166,16; add.u64 %r491,%r483,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r491; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r490; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r489; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r492,[%value_in]; } .loc 1 138 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r166; call _Bfree,(%out_arg1,%out_arg2); } ld.u32 %r206,[%r483+20]; add.u64 %r198,%r483,24; mov.u64 %r166,%r483; $L81: .loc 1 141 0 add.u32 %r495,%r206,1; st.u32 [%r166+20],%r495; cvt.s64.s32 %r496,%r206; add.u64 %r497,%r496,6; shl.b64 %r498,%r497,2; add.u64 %r499,%r166,%r498; mov.u32 %r500,1; st.u32 [%r499],%r500; $L79: .loc 1 341 0 setp.ne.u32 %r501,%r239,2; @ %r501 bra $L82; .loc 1 342 0 ld.u32 %r503,[%r242]; add.u32 %r502,%r503,-1; setp.ne.u32 %r504,%r502,%r170; @ %r504 bra $L103; .loc 1 343 0 shr.s32 %r505,%r170,5; cvt.s64.s32 %r506,%r505; shl.b64 %r507,%r506,2; add.u64 %r508,%r198,%r507; and.b32 %r509,%r170,31; mov.u32 %r511,1; shl.b32 %r510,%r511,%r509; ld.u32 %r513,[%r508]; and.b32 %r512,%r510,%r513; setp.ne.u32 %r514,%r512,0; selp.u32 %r239,33,34,%r514; bra $L72; $L82: .loc 1 346 0 ld.u32 %r515,[%r166+20]; setp.le.s32 %r516,%r515,%r193; @ %r516 bra $L84; $L85: .loc 1 349 0 mov.u32 %r518,1; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r518; call rshift,(%out_arg1,%out_arg2); } .loc 1 350 0 add.u32 %r175,%r175,1; ld.u32 %r519,[%r242+8]; setp.lt.s32 %r520,%r519,%r175; @ %r520 bra $L60; mov.u32 %r239,33; bra $L72; $L84: .loc 1 347 0 and.b32 %r194,%r170,31; setp.eq.u32 %r521,%r194,0; @ %r521 bra $L105; .loc 1 348 0 add.u64 %r523,%r198,%r201; ld.u32 %r522,[%r523+-4]; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r522; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r525,[%value_in]; } mov.u32 %r527,32; sub.u32 %r526,%r527,%r194; setp.lt.s32 %r528,%r525,%r526; @ %r528 bra $L85; mov.u32 %r239,33; bra $L72; $L103: mov.u32 %r239,34; bra $L72; $L105: mov.u32 %r239,33; bra $L72; $L73: .loc 1 356 0 or.b32 %r239,%r239,16; $L72: .loc 1 358 0 st.u64 [%r244],%r166; .loc 1 359 0 st.u32 [%r243],%r175; .loc 1 360 0 bra $L14; $L171: .loc 1 225 0 st.u64 [%r241],%r76; bra $L87; $L19: ld.u8 %r73,[%r223]; .loc 1 177 0 mov.u64 %r76,%r223; $L20: .loc 1 203 0 cvt.u16.u32 %r530,%r73; setp.eq.u16 %r531,%r530,80; @ %r531 bra $L106; setp.eq.u16 %r533,%r530,112; @ ! %r533 bra $L171; bra $L106; $L90: .loc 1 196 0 mov.u64 %r181,%r76; bra $L28; $L14: .loc 1 361 0 mov.u32 %value,%r239; st.param.u32 [%value_out],%value; ret; } /62 0 0 0 644 7397 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __hexnan .visible .func (.param .u32 %value_out) __hexnan (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/stdlib/gdtoa-hexnan.c" // BEGIN GLOBAL VAR DECL: __hexdig .extern .const .align 1 .u8 __hexdig[256]; // BEGIN GLOBAL FUNCTION DEF: __hexnan .visible .func (.param .u32 %value_out) __hexnan (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r85; .reg .u64 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u64 %r99; .reg .u64 %r100; .reg .u32 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u32 %r106; .reg .u64 %r108; .reg .u32 %r109; .reg .u64 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .u32 %r118; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u32 %r127; .reg .u32 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u32 %r140; .reg .u32 %r141; .reg .u64 %r142; .reg .u64 %r143; .reg .u64 %r144; .reg .u32 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u32 %r149; .reg .u64 %r151; .reg .u64 %r152; .reg .pred %r153; .reg .pred %r154; .reg .pred %r155; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r160; .reg .u32 %r161; .reg .u16 %r162; .reg .u16 %r163; .reg .u16 %r164; .reg .u32 %r165; .reg .u16 %r166; .reg .pred %r167; .reg .u32 %r169; .reg .u32 %r170; .reg .u32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .pred %r175; .reg .u64 %r176; .reg .pred %r177; .reg .u32 %r178; .reg .pred %r179; .reg .u16 %r181; .reg .u16 %r182; .reg .u32 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .pred %r186; .reg .pred %r187; .reg .u32 %r189; .reg .u32 %r190; .reg .u32 %r192; .reg .u32 %r193; .reg .u16 %r194; .reg .u16 %r195; .reg .u16 %r196; .reg .u32 %r197; .reg .u16 %r198; .reg .pred %r199; .reg .u32 %r200; .reg .u32 %r201; .reg .u32 %r202; .reg .u32 %r203; .reg .pred %r204; .reg .pred %r205; .reg .pred %r206; .reg .u32 %r207; .reg .pred %r208; .reg .u32 %r210; .reg .u32 %r211; .reg .u32 %r212; .reg .u32 %r213; .reg .pred %r214; .reg .pred %r215; .reg .pred %r216; .reg .u32 %r217; .reg .u32 %r218; .reg .pred %r219; .reg .pred %r221; .reg .u64 %r222; .reg .u32 %r223; .reg .u32 %r225; mov.u64 %r142,%ar0; mov.u64 %r143,%ar1; mov.u64 %r144,%ar2; .loc 1 74 0 ld.u32 %r106,[%r143]; .loc 1 75 0 shr.s32 %r145,%r106,5; cvt.s64.s32 %r146,%r145; shl.b64 %r147,%r146,2; add.u64 %r99,%r144,%r147; .loc 1 76 0 and.b32 %r79,%r106,31; setp.eq.u32 %r221,%r79,0; @ %r221 bra $L2; .loc 1 77 0 add.u64 %r99,%r99,4; $L2: .loc 1 78 0 add.u64 %r112,%r99,-4; mov.u32 %r149,0; st.u32 [%r99+-4],%r149; .loc 1 81 0 ld.u64 %r103,[%r142]; .loc 1 78 0 mov.u64 %r102,%r112; mov.u64 %r100,%r112; .loc 1 80 0 mov.u32 %r105,%r149; mov.u32 %r104,%r149; mov.u32 %r101,%r149; .loc 1 83 0 cvta.const.u64 %r222,__hexdig; .loc 1 110 0 mov.u32 %r223,%r149; .loc 1 55 0 mov.u32 %r225,8; .loc 1 82 0 bra $L3; $L14: .loc 1 83 0 cvt.u64.u32 %r151,%r109; add.u64 %r152,%r222,%r151; ld.u8 %r80,[%r152]; setp.ne.u32 %r153,%r80,0; @ %r153 bra $L4; .loc 1 84 0 setp.gt.u32 %r154,%r109,32; @ %r154 bra $L5; .loc 1 85 0 setp.le.s32 %r155,%r101,%r104; @ %r155 bra $L6; .loc 1 86 0 set.u32.lt.u64 %r157,%r100,%r102; neg.s32 %r158,%r157; set.u32.le.s32 %r160,%r105,7; neg.s32 %r161,%r160; cvt.u16.u32 %r163,%r158; cvt.u16.u32 %r164,%r161; and.b16 %r162,%r163,%r164; cvt.u32.u16 %r165,%r162; cvt.u16.u8 %r166,%r165; setp.eq.u16 %r167,%r166,0; @ %r167 bra $L7; .loc 1 55 0 sub.u32 %r113,%r225,%r105; .loc 1 56 0 shl.b32 %r114,%r113,2; .loc 1 57 0 mov.u32 %r169,32; sub.u32 %r115,%r169,%r114; ld.u32 %r121,[%r100]; add.u64 %r132,%r100,4; mov.u64 %r116,%r100; $L8: .loc 1 59 0 ld.u32 %r118,[%r132]; shl.b32 %r170,%r118,%r115; or.b32 %r171,%r170,%r121; st.u32 [%r116],%r171; .loc 1 60 0 shr.u32 %r121,%r118,%r114; st.u32 [%r132],%r121; .loc 1 61 0 add.u64 %r116,%r116,4; add.u64 %r132,%r132,4; setp.gt.u64 %r172,%r102,%r116; @ %r172 bra $L8; $L7: .loc 1 88 0 setp.le.u64 %r173,%r100,%r144; @ %r173 bra $L25; .loc 1 93 0 add.u64 %r102,%r100,-4; st.u32 [%r100+-4],%r223; mov.u32 %r104,%r101; mov.u64 %r100,%r102; .loc 1 95 0 mov.u32 %r105,0; bra $L6; $L5: .loc 1 99 0 setp.eq.u32 %r175,%r109,41; @ %r175 bra $L9; $L15: .loc 1 103 0 mov.u32 %r141,4; bra $L1; $L9: .loc 1 100 0 add.u64 %r176,%r103,2; st.u64 [%r142],%r176; .loc 1 101 0 bra $L11; $L4: .loc 1 105 0 add.u32 %r101,%r101,1; .loc 1 106 0 add.u32 %r105,%r105,1; setp.gt.s32 %r177,%r105,8; @ %r177 bra $L12; ld.u32 %r178,[%r100]; shl.b32 %r140,%r178,4; bra $L13; $L12: .loc 1 107 0 setp.le.u64 %r179,%r100,%r144; @ %r179 bra $L6; .loc 1 110 0 st.u32 [%r100+-4],%r223; add.u64 %r100,%r100,-4; mov.u32 %r140,%r149; .loc 1 109 0 mov.u32 %r105,1; $L13: .loc 1 112 0 cvt.u16.u32 %r182,%r80; and.b16 %r181,%r182,15; cvt.u32.u16 %r184,%r181; cvt.u32.u8 %r183,%r184; or.b32 %r185,%r183,%r140; st.u32 [%r100],%r185; bra $L6; $L25: .loc 1 89 0 mov.u32 %r105,8; $L6: .loc 1 95 0 mov.u64 %r103,%r108; $L3: .loc 1 82 0 add.u64 %r108,%r103,1; ld.u8 %r109,[%r108]; setp.ne.u32 %r186,%r109,0; @ %r186 bra $L14; $L11: .loc 1 114 0 setp.eq.u32 %r187,%r101,0; @ %r187 bra $L15; .loc 1 116 0 set.u32.lt.u64 %r189,%r100,%r102; neg.s32 %r190,%r189; set.u32.le.s32 %r192,%r105,7; neg.s32 %r193,%r192; cvt.u16.u32 %r195,%r190; cvt.u16.u32 %r196,%r193; and.b16 %r194,%r195,%r196; cvt.u32.u16 %r197,%r194; cvt.u16.u8 %r198,%r197; setp.eq.u16 %r199,%r198,0; @ %r199 bra $L16; .loc 1 55 0 mov.u32 %r200,8; sub.u32 %r122,%r200,%r105; .loc 1 56 0 shl.b32 %r123,%r122,2; .loc 1 57 0 mov.u32 %r201,32; sub.u32 %r124,%r201,%r123; ld.u32 %r130,[%r100]; add.u64 %r131,%r100,4; mov.u64 %r125,%r100; $L17: .loc 1 59 0 ld.u32 %r127,[%r131]; shl.b32 %r202,%r127,%r124; or.b32 %r203,%r202,%r130; st.u32 [%r125],%r203; .loc 1 60 0 shr.u32 %r130,%r127,%r123; st.u32 [%r131],%r130; .loc 1 61 0 add.u64 %r125,%r125,4; add.u64 %r131,%r131,4; setp.gt.u64 %r204,%r102,%r125; @ %r204 bra $L17; $L16: .loc 1 118 0 setp.le.u64 %r205,%r100,%r144; @ %r205 bra $L18; mov.u64 %r126,%r100; mov.u64 %r85,%r144; $L19: add.u64 %r93,%r85,4; .loc 1 120 0 ld.u32 %r94,[%r126]; st.u32 [%r85],%r94; add.u64 %r126,%r126,4; mov.u64 %r85,%r93; .loc 1 121 0 setp.ge.u64 %r206,%r112,%r126; @ %r206 bra $L19; .loc 1 122 0 mov.u32 %r207,0; $L20: st.u32 [%r93],%r207; add.u64 %r93,%r93,4; .loc 1 123 0 setp.ge.u64 %r208,%r112,%r93; @ %r208 bra $L20; ld.u32 %r95,[%r99+-4]; bra $L21; $L18: ld.u32 %r95,[%r99+-4]; .loc 1 127 0 @ %r221 bra $L21; .loc 1 128 0 mov.u32 %r211,32; sub.u32 %r210,%r211,%r79; mov.u32 %r213,-1; shr.u32 %r212,%r213,%r210; and.b32 %r95,%r95,%r212; st.u32 [%r99+-4],%r95; $L21: .loc 1 131 0 setp.ne.u32 %r214,%r95,0; @ %r214 bra $L26; .loc 1 133 0 setp.eq.u64 %r215,%r144,%r112; @ ! %r215 bra $L23; bra $L22; $L24: setp.ne.u64 %r216,%r144,%r112; @ %r216 bra $L23; $L22: .loc 1 134 0 mov.u32 %r217,1; st.u32 [%r144],%r217; .loc 1 138 0 mov.u32 %r141,5; .loc 1 135 0 bra $L1; $L23: .loc 1 130 0 add.u64 %r112,%r112,-4; .loc 1 131 0 ld.u32 %r218,[%r112]; setp.eq.u32 %r219,%r218,0; @ %r219 bra $L24; .loc 1 138 0 mov.u32 %r141,5; bra $L1; $L26: mov.u32 %r141,5; $L1: .loc 1 139 0 mov.u32 %value,%r141; st.param.u32 [%value_out],%value; ret; } lib_a-impure.o/ 0 0 0 644 823 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN VAR DEF: impure_data .global .align 8 .u64 impure_data[233] = {0,0,0,0,0,0,0,0,0,generic($LC0),0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,-1842796655094713586,47245025004,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: _global_impure_ptr .visible .const .align 8 .u64 _global_impure_ptr[1] = {generic(impure_data) }; // BEGIN GLOBAL VAR DEF: _impure_ptr .visible .global .align 8 .u64 _impure_ptr[1] = {generic(impure_data) }; lib_a-index.o/ 0 0 0 644 1005 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: index .visible .func (.param .u64 %value_out) index (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/string/index.c" // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: index .visible .func (.param .u64 %value_out) index (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u64 %r27; mov.u64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 44 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r27,[%value_in]; } .loc 1 45 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } lib_a-isalnum.o/0 0 0 644 905 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isalnum .visible .func (.param .u32 %value_out) isalnum (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isalnum.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isalnum .visible .func (.param .u32 %value_out) isalnum (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 44 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,7; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 45 0 st.param.u32 [%value_out],%value; ret; } lib_a-isalpha.o/0 0 0 644 905 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isalpha .visible .func (.param .u32 %value_out) isalpha (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isalpha.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isalpha .visible .func (.param .u32 %value_out) isalpha (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 42 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,3; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-iscntrl.o/0 0 0 644 906 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: iscntrl .visible .func (.param .u32 %value_out) iscntrl (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/iscntrl.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: iscntrl .visible .func (.param .u32 %value_out) iscntrl (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 45 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,32; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 46 0 st.param.u32 [%value_out],%value; ret; } lib_a-isdigit.o/0 0 0 644 905 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isdigit .visible .func (.param .u32 %value_out) isdigit (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isdigit.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isdigit .visible .func (.param .u32 %value_out) isdigit (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 42 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,4; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-islower.o/0 0 0 644 1023 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: islower .visible .func (.param .u32 %value_out) islower (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/islower.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: islower .visible .func (.param .u32 %value_out) islower (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u16 %r45; mov.u32 %r30,%ar0; .loc 1 42 0 cvt.s64.s32 %r32,%r30; ld.global.u64 %r33,[__ctype_ptr__]; add.u64 %r34,%r33,%r32; ld.u8 %r45,[%r34+1]; mov.u16 %r38,%r45; and.b16 %r37,%r38,3; cvt.u32.u16 %r42,%r37; cvt.s32.s8 %r41,%r42; cvt.u16.u32 %r40,%r41; set.u32.eq.u16 %r43,%r40,2; neg.s32 %value,%r43; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-isprint.o/0 0 0 644 1482 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isgraph .visible .func (.param .u32 %value_out) isgraph (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isprint.c" // BEGIN GLOBAL FUNCTION DECL: isprint .visible .func (.param .u32 %value_out) isprint (.param .u32 %in_ar0); // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isgraph .visible .func (.param .u32 %value_out) isgraph (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 51 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,23; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 52 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: isprint .visible .func (.param .u32 %value_out) isprint (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r35; mov.u32 %r29,%ar0; .loc 1 59 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.s8 %r35,[%r33+1]; and.b32 %value,%r35,151; .loc 1 60 0 st.param.u32 [%value_out],%value; ret; } lib_a-ispunct.o/0 0 0 644 906 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ispunct .visible .func (.param .u32 %value_out) ispunct (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/ispunct.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: ispunct .visible .func (.param .u32 %value_out) ispunct (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 44 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,16; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 45 0 st.param.u32 [%value_out],%value; ret; } lib_a-isspace.o/0 0 0 644 905 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isspace .visible .func (.param .u32 %value_out) isspace (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isspace.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isspace .visible .func (.param .u32 %value_out) isspace (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 42 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,8; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-isupper.o/0 0 0 644 1023 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isupper .visible .func (.param .u32 %value_out) isupper (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isupper.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isupper .visible .func (.param .u32 %value_out) isupper (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u16 %r45; mov.u32 %r30,%ar0; .loc 1 41 0 cvt.s64.s32 %r32,%r30; ld.global.u64 %r33,[__ctype_ptr__]; add.u64 %r34,%r33,%r32; ld.u8 %r45,[%r34+1]; mov.u16 %r38,%r45; and.b16 %r37,%r38,3; cvt.u32.u16 %r42,%r37; cvt.s32.s8 %r41,%r42; cvt.u16.u32 %r40,%r41; set.u32.eq.u16 %r43,%r40,1; neg.s32 %value,%r43; .loc 1 42 0 st.param.u32 [%value_out],%value; ret; } /84 0 0 0 644 911 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isxdigit .visible .func (.param .u32 %value_out) isxdigit (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/isxdigit.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isxdigit .visible .func (.param .u32 %value_out) isxdigit (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 43 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,68; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 44 0 st.param.u32 [%value_out],%value; ret; } lib_a-jrand48.o/0 0 0 644 1883 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _jrand48_r .visible .func (.param .u64 %value_out) _jrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/jrand48.c" // BEGIN GLOBAL FUNCTION DECL: jrand48 .visible .func (.param .u64 %value_out) jrand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _jrand48_r .visible .func (.param .u64 %value_out) _jrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; mov.u64 %r28,%ar0; mov.u64 %r29,%ar1; .loc 1 21 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r29; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r33,[%r29+4]; shl.b64 %r34,%r33,16; ld.u16 %r35,[%r29+2]; add.u64 %value,%r34,%r35; .loc 1 23 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: jrand48 .visible .func (.param .u64 %value_out) jrand48 (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r29; .reg .u64 %r32; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; mov.u64 %r29,%ar0; .loc 1 21 0 ld.global.u64 %r32,[_impure_ptr]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r29; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r34,[%r29+4]; shl.b64 %r35,%r34,16; ld.u16 %r36,[%r29+2]; add.u64 %value,%r35,%r36; .loc 1 31 0 st.param.u64 [%value_out],%value; ret; } lib_a-l64a.o/ 0 0 0 644 3937 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: l64a .visible .func (.param .u64 %value_out) l64a (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/l64a.c" // BEGIN GLOBAL FUNCTION DECL: _l64a_r .visible .func (.param .u64 %value_out) _l64a_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN VAR DEF: R64_ARRAY .const .align 1 .u8 R64_ARRAY[65] = {46,47,48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,0 }; // BEGIN GLOBAL FUNCTION DEF: l64a .visible .func (.param .u64 %value_out) l64a (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r65; .reg .u64 %r67; .reg .u64 %r68; .reg .u64 %r72; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .pred %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .pred %r96; .reg .u64 %r98; mov.u64 %r80,%ar0; .loc 1 33 0 ld.global.u64 %r65,[_impure_ptr]; .loc 1 44 0 and.b64 %r67,%r80,4294967295; .loc 1 47 0 add.u64 %r79,%r65,280; .loc 1 52 0 setp.eq.u64 %r81,%r67,0; @ %r81 bra $L6; .loc 1 59 0 cvta.const.u64 %r98,R64_ARRAY; .loc 1 58 0 cvt.u32.u64 %r84,%r80; and.b32 %r83,%r84,63; .loc 1 59 0 cvt.s64.s32 %r85,%r83; add.u64 %r86,%r98,%r85; ld.u8 %r87,[%r86]; st.u8 [%r65+280],%r87; .loc 1 60 0 shr.u64 %r72,%r67,6; .loc 1 59 0 add.u64 %r77,%r65,281; add.u64 %r68,%r65,286; bra $L3; $L6: .loc 1 48 0 mov.u64 %r78,%r79; $L2: .loc 1 54 0 mov.u32 %r88,0; st.u8 [%r78],%r88; bra $L1; $L10: .loc 1 58 0 cvt.u32.u64 %r91,%r72; and.b32 %r90,%r91,63; .loc 1 59 0 cvt.s64.s32 %r92,%r90; add.u64 %r93,%r98,%r92; ld.u8 %r94,[%r93]; st.u8 [%r77],%r94; .loc 1 60 0 shr.u64 %r72,%r72,6; add.u64 %r77,%r77,1; .loc 1 50 0 setp.eq.u64 %r95,%r68,%r77; @ %r95 bra $L1; $L3: mov.u64 %r78,%r77; .loc 1 52 0 setp.eq.u64 %r96,%r72,0; @ ! %r96 bra $L10; bra $L2; $L1: .loc 1 34 0 mov.u64 %value,%r79; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _l64a_r .visible .func (.param .u64 %value_out) _l64a_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r40; .reg .u64 %r42; .reg .u64 %r44; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .pred %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .u64 %r71; mov.u64 %r52,%ar0; mov.u64 %r53,%ar1; .loc 1 44 0 and.b64 %r42,%r53,4294967295; .loc 1 47 0 add.u64 %r51,%r52,280; .loc 1 52 0 setp.eq.u64 %r54,%r42,0; @ %r54 bra $L16; .loc 1 59 0 cvta.const.u64 %r71,R64_ARRAY; .loc 1 58 0 cvt.u32.u64 %r57,%r53; and.b32 %r56,%r57,63; .loc 1 59 0 cvt.s64.s32 %r58,%r56; add.u64 %r59,%r71,%r58; ld.u8 %r60,[%r59]; st.u8 [%r52+280],%r60; .loc 1 60 0 shr.u64 %r44,%r42,6; .loc 1 59 0 add.u64 %r49,%r52,281; add.u64 %r40,%r52,286; bra $L13; $L16: .loc 1 48 0 mov.u64 %r50,%r51; $L12: .loc 1 54 0 mov.u32 %r61,0; st.u8 [%r50],%r61; .loc 1 55 0 bra $L11; $L20: .loc 1 58 0 cvt.u32.u64 %r64,%r44; and.b32 %r63,%r64,63; .loc 1 59 0 cvt.s64.s32 %r65,%r63; add.u64 %r66,%r71,%r65; ld.u8 %r67,[%r66]; st.u8 [%r49],%r67; .loc 1 60 0 shr.u64 %r44,%r44,6; add.u64 %r49,%r49,1; .loc 1 50 0 setp.eq.u64 %r68,%r40,%r49; @ %r68 bra $L11; $L13: mov.u64 %r50,%r49; .loc 1 52 0 setp.eq.u64 %r69,%r44,0; @ ! %r69 bra $L20; bra $L12; $L11: .loc 1 64 0 mov.u64 %value,%r51; st.param.u64 [%value_out],%value; ret; } lib_a-labs.o/ 0 0 0 644 521 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: labs .visible .func (.param .u64 %value_out) labs (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/labs.c" // BEGIN GLOBAL FUNCTION DEF: labs .visible .func (.param .u64 %value_out) labs (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; mov.u64 %r23,%ar0; .loc 1 48 0 abs.s64 %value,%r23; .loc 1 49 0 st.param.u64 [%value_out],%value; ret; } lib_a-lcong48.o/0 0 0 644 1986 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _lcong48_r .visible .func _lcong48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/lcong48.c" // BEGIN GLOBAL FUNCTION DECL: lcong48 .visible .func lcong48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: _lcong48_r .visible .func _lcong48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r29; .reg .u64 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; .reg .u16 %r34; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; mov.u64 %r29,%ar0; mov.u64 %r30,%ar1; .loc 1 22 0 ld.u16 %r31,[%r30]; st.u16 [%r29+240],%r31; .loc 1 23 0 ld.u16 %r32,[%r30+2]; st.u16 [%r29+242],%r32; .loc 1 24 0 ld.u16 %r33,[%r30+4]; st.u16 [%r29+244],%r33; .loc 1 25 0 ld.u16 %r34,[%r30+6]; st.u16 [%r29+246],%r34; .loc 1 26 0 ld.u16 %r35,[%r30+8]; st.u16 [%r29+248],%r35; .loc 1 27 0 ld.u16 %r36,[%r30+10]; st.u16 [%r29+250],%r36; .loc 1 28 0 ld.u16 %r37,[%r30+12]; st.u16 [%r29+252],%r37; .loc 1 29 0 ret; } // BEGIN GLOBAL FUNCTION DEF: lcong48 .visible .func lcong48 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u64 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; .reg .u16 %r34; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; mov.u64 %r30,%ar0; .loc 1 36 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 22 0 ld.u16 %r31,[%r30]; st.u16 [%r22+240],%r31; .loc 1 23 0 ld.u16 %r32,[%r30+2]; st.u16 [%r22+242],%r32; .loc 1 24 0 ld.u16 %r33,[%r30+4]; st.u16 [%r22+244],%r33; .loc 1 25 0 ld.u16 %r34,[%r30+6]; st.u16 [%r22+246],%r34; .loc 1 26 0 ld.u16 %r35,[%r30+8]; st.u16 [%r22+248],%r35; .loc 1 27 0 ld.u16 %r36,[%r30+10]; st.u16 [%r22+250],%r36; .loc 1 28 0 ld.u16 %r37,[%r30+12]; st.u16 [%r22+252],%r37; .loc 1 37 0 ret; } lib_a-lctype.o/ 0 0 0 644 3340 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __ctype_load_locale .visible .func (.param .u32 %value_out) __ctype_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../newlib/libc/locale/lctype.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_ctype_locale .visible .func (.param .u64 %value_out) __get_current_ctype_locale; // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {65,83,67,73,73,0 }; // BEGIN VAR DEF: _ctype_using_locale .global .align 4 .u32 _ctype_using_locale[1]; // BEGIN VAR DEF: _ctype_locale .global .align 8 .u64 _ctype_locale[2]; // BEGIN VAR DEF: numone .global .align 1 .u8 numone[2] = {1,0 }; // BEGIN VAR DEF: _C_ctype_locale .const .align 8 .u64 _C_ctype_locale[2] = {generic($LC1),generic(numone) }; // BEGIN VAR DEF: _ctype_locale_buf .global .align 1 .u8 _ctype_locale_buf[34]; // BEGIN GLOBAL FUNCTION DEF: __ctype_load_locale .visible .func (.param .u32 %value_out) __ctype_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %r26; .reg .u64 %r28; .reg .u32 %r29; .reg .u64 %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u64 %r35; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r41; .reg .u64 %r43; .reg .u32 %r44; mov.u64 %r26,%ar0; mov.u64 %r28,%ar2; mov.u32 %r29,%ar3; .loc 1 81 0 cvta.const.u64 %r31,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r32,[%value_in]; } setp.ne.u32 %r33,%r32,0; @ %r33 bra $L2; .loc 1 82 0 st.global.u32 [_ctype_using_locale],%r32; bra $L3; $L2: .loc 1 85 0 cvta.global.u64 %r35,_ctype_locale_buf; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r35; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r28; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r37,[%value_in]; } cvta.global.u64 %r38,_ctype_locale; st.u64 [%r38],%r37; .loc 1 87 0 st.u8 [%r35+32],%r29; .loc 1 88 0 mov.u32 %r41,0; st.u8 [%r35+33],%r41; .loc 1 89 0 add.u64 %r43,%r35,32; st.u64 [%r38+8],%r43; .loc 1 90 0 mov.u32 %r44,1; st.global.u32 [_ctype_using_locale],%r44; $L3: .loc 1 102 0 mov.u32 %value,0; .loc 1 103 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_ctype_locale .visible .func (.param .u64 %value_out) __get_current_ctype_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 110 0 ld.global.u32 %r24,[_ctype_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L6; cvta.const.u64 %r23,_C_ctype_locale; bra $L4; $L6: cvta.global.u64 %r23,_ctype_locale; $L4: .loc 1 111 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-ldiv.o/ 0 0 0 644 1152 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldiv .visible .func ldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/stdlib/ldiv.c" // BEGIN GLOBAL FUNCTION DEF: ldiv .visible .func ldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 98 0 div.s64 %r22,%r25,%r26; .loc 1 99 0 rem.s64 %r23,%r25,%r26; .loc 1 100 0 setp.lt.s64 %r27,%r25,0; @ %r27 bra $L2; setp.ge.s64 %r28,%r23,0; @ %r28 bra $L3; .loc 1 101 0 add.u64 %r22,%r22,1; .loc 1 102 0 sub.u64 %r23,%r23,%r26; bra $L3; $L2: .loc 1 104 0 setp.le.s64 %r29,%r23,0; @ %r29 bra $L3; .loc 1 105 0 add.u64 %r22,%r22,-1; .loc 1 106 0 add.u64 %r23,%r23,%r26; $L3: .loc 1 108 0 st.u64 [%r24],%r22; st.u64 [%r24+8],%r23; .loc 1 109 0 ret; } lib_a-ldpart.o/ 0 0 0 644 12947 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .visible .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); .file 1 "../../../../../newlib/libc/locale/ldpart.c" // BEGIN GLOBAL VAR DECL: _PathLocale .extern .global .align 8 .u64 _PathLocale[1]; // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcat .extern .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: open .extern .func (.param .u32 %value_out) open (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: fstat .extern .func (.param .u32 %value_out) fstat (.param .u32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __nvptx_realloc .extern .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: read .extern .func (.param .u32 %value_out) read (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: close .extern .func (.param .u32 %value_out) close (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN VAR DEF: num_lines$2134 .global .align 4 .u32 num_lines$2134[1]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {80,79,83,73,88,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[2] = {47,0 }; // BEGIN VAR DEF: locale_buf_C$2133 .global .align 1 .u8 locale_buf_C$2133[2] = {67,0 }; // BEGIN GLOBAL FUNCTION DEF: __part_load_locale .visible .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u64 %ar6; ld.param.u64 %ar6,[%in_ar6]; .reg .u64 %stack; mov.u64 %stack,0; .local .align 8 .b8 %frame_ar[1128]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r54; .reg .u64 %r56; .reg .u64 %r59; .reg .u64 %r63; .reg .u32 %r74; .reg .u64 %r76; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r84; .reg .u32 %r85; .reg .u64 %r88; .reg .u64 %r91; .reg .u64 %r93; .reg .u32 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r110; .reg .u32 %r111; .reg .pred %r112; .reg .u64 %r114; .reg .u32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .u32 %r120; .reg .pred %r121; .reg .pred %r122; .reg .u32 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u32 %r131; .reg .u64 %r133; .reg .pred %r134; .reg .u64 %r137; .reg .u64 %r139; .reg .u64 %r140; .reg .u64 %r143; .reg .u64 %r146; .reg .u64 %r149; .reg .u32 %r151; .reg .u32 %r152; .reg .pred %r154; .reg .u64 %r157; .reg .u32 %r158; .reg .pred %r159; .reg .pred %r160; .reg .u64 %r161; .reg .u32 %r163; .reg .u32 %r164; .reg .u64 %r166; .reg .u32 %r167; .reg .u32 %r168; .reg .u16 %r169; .reg .u16 %r170; .reg .u16 %r171; .reg .u32 %r172; .reg .u16 %r173; .reg .pred %r174; .reg .u64 %r176; .reg .pred %r177; .reg .u64 %r180; .reg .pred %r181; .reg .u64 %r185; .reg .u32 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .pred %r192; .reg .u32 %r194; .reg .pred %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u32 %r198; .reg .u16 %r199; .reg .u32 %r200; .reg .pred %r201; .reg .pred %r202; .reg .u32 %r204; .reg .u64 %r205; .reg .u32 %r206; .reg .pred %r207; .reg .pred %r208; .reg .pred %r209; .reg .pred %r210; .reg .u32 %r211; .reg .u64 %r212; .reg .u64 %r213; .reg .u64 %r214; .reg .u64 %r216; .reg .u64 %r217; .reg .pred %r218; .reg .u32 %r221; mov.u64 %r100,%ar0; mov.u64 %r101,%ar1; mov.u64 %r102,%ar2; mov.u64 %r103,%ar3; mov.u32 %r104,%ar4; mov.u32 %r105,%ar5; mov.u64 %r106,%ar6; .loc 1 70 0 ld.u32 %r74,[%r101]; .loc 1 71 0 mov.u32 %r107,0; st.u32 [%r101],%r107; .loc 1 73 0 setp.eq.u64 %r108,%r100,0; @ %r108 bra $L2; .loc 1 76 0 cvta.const.u64 %r110,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r110; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r111,[%value_in]; } setp.ne.u32 %r112,%r111,0; @ %r112 bra $L3; $L5: .loc 1 77 0 mov.u32 %r99,0; bra $L1; $L3: .loc 1 76 0 cvta.const.u64 %r114,$LC1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r114; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r115,[%value_in]; } setp.eq.u32 %r116,%r115,0; @ %r116 bra $L5; .loc 1 83 0 setp.eq.u64 %r117,%r102,0; @ %r117 bra $L6; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r102; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r120,[%value_in]; } setp.ne.u32 %r121,%r120,0; @ %r121 bra $L6; .loc 1 84 0 ld.global.u32 %r54,[num_lines$2134]; .loc 1 189 0 setp.le.s32 %r122,%r54,0; @ %r122 bra $L7; add.u32 %r123,%r54,-1; cvt.u64.u32 %r124,%r123; add.u64 %r125,%r124,1; shl.b64 %r126,%r125,3; add.u64 %r93,%r106,%r126; $L8: .loc 1 190 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r128,[%value_in]; } add.u64 %r129,%r128,1; add.u64 %r102,%r102,%r129; st.u64 [%r106],%r102; .loc 1 189 0 add.u64 %r106,%r106,8; setp.ne.u64 %r130,%r106,%r93; @ %r130 bra $L8; $L7: .loc 1 85 0 mov.u32 %r131,1; st.u32 [%r101],%r131; .loc 1 86 0 mov.u32 %r99,0; bra $L1; $L6: .loc 1 92 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r133,[%value_in]; } add.u64 %r76,%r133,1; .loc 1 94 0 ld.global.u64 %r56,[_PathLocale]; setp.eq.u64 %r134,%r56,0; @ %r134 bra $L2; .loc 1 97 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r56; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r137,[%value_in]; } .loc 1 98 0 cvta.const.u64 %r139,$LC2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r139; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r140,[%value_in]; } .loc 1 99 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r100; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r143,[%value_in]; } .loc 1 100 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r139; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r146,[%value_in]; } .loc 1 101 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r103; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r149,[%value_in]; } .loc 1 102 0 mov.u32 %r151,0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r151; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),open,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r152,[%value_in]; } .loc 1 103 0 setp.lt.s32 %r154,%r152,0; @ %r154 bra $L2; .loc 1 108 0 add.u64 %r157,%frame,1024; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r157; call (%value_in),fstat,(%out_arg1,%out_arg2); ld.param.u32 %r158,[%value_in]; } setp.ne.u32 %r159,%r158,0; @ %r159 bra $L9; .loc 1 111 0 ld.u64 %r59,[%frame+1040]; setp.le.s64 %r160,%r59,0; @ %r160 bra $L9; .loc 1 113 0 add.u64 %r161,%r59,1; add.u64 %r78,%r161,%r76; .loc 1 116 0 set.u32.eq.u64 %r163,%r102,0; neg.s32 %r164,%r163; cvta.global.u64 %r166,locale_buf_C$2133; set.u32.eq.u64 %r167,%r102,%r166; neg.s32 %r168,%r167; cvt.u16.u32 %r170,%r164; cvt.u16.u32 %r171,%r168; or.b16 %r169,%r170,%r171; cvt.u32.u16 %r172,%r169; cvt.u16.u8 %r173,%r172; setp.eq.u16 %r174,%r173,0; @ %r174 bra $L10; .loc 1 118 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r78; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r176,[%value_in]; } mov.u64 %r88,%r176; .loc 1 128 0 setp.eq.u64 %r177,%r88,0; @ ! %r177 bra $L11; .loc 1 164 0 bra $L9; $L10: .loc 1 122 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r78; call (%value_in),__nvptx_realloc,(%out_arg1,%out_arg2); ld.param.u64 %r180,[%value_in]; } mov.u64 %r88,%r180; .loc 1 123 0 setp.ne.u64 %r181,%r180,0; @ %r181 bra $L11; .loc 1 124 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; call __nvptx_free,(%out_arg1); } bra $L9; $L11: .loc 1 130 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r88; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r100; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r185,[%value_in]; } .loc 1 131 0 add.u64 %r84,%r88,%r76; .loc 1 132 0 ld.u64 %r63,[%frame+1040]; add.u64 %r79,%r84,%r63; .loc 1 133 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r84; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r63; call (%value_in),read,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r189,[%value_in]; } cvt.s64.s32 %r190,%r189; ld.u64 %r191,[%frame+1040]; setp.ne.u64 %r192,%r190,%r191; @ %r192 bra $L19; .loc 1 135 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; call (%value_in),close,(%out_arg1); ld.param.u32 %r194,[%value_in]; } setp.ne.u32 %r195,%r194,0; @ %r195 bra $L19; .loc 1 140 0 ld.u64 %r196,[%frame+1040]; add.u64 %r197,%r84,%r196; cvt.u32.u32 %r198,%r194; st.u8 [%r197],%r198; .loc 1 141 0 ld.s8 %r200,[%r79+-1]; cvt.u16.u32 %r199,%r200; setp.ne.u16 %r201,%r199,10; @ %r201 bra $L19; .loc 1 176 0 setp.ge.u64 %r202,%r84,%r79; @ %r202 bra $L20; mov.u32 %r85,%r194; $L14: .loc 1 177 0 mov.u32 %r204,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r84; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r204; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r205,[%value_in]; } .loc 1 178 0 add.u64 %r84,%r205,1; mov.u32 %r206,0; st.u8 [%r205],%r206; .loc 1 176 0 add.u32 %r85,%r85,1; setp.gt.u64 %r207,%r79,%r84; @ %r207 bra $L14; bra $L13; $L20: mov.u32 %r85,%r194; $L13: .loc 1 144 0 setp.gt.s32 %r208,%r104,%r85; @ %r208 bra $L15; .loc 1 145 0 st.global.u32 [num_lines$2134],%r104; bra $L16; $L15: .loc 1 146 0 setp.le.s32 %r209,%r105,%r85; @ %r209 bra $L17; .loc 1 143 0 st.global.u32 [num_lines$2134],%r85; .loc 1 161 0 mov.u32 %r74,%r194; bra $L19; $L17: .loc 1 147 0 st.global.u32 [num_lines$2134],%r105; mov.u32 %r104,%r105; $L16: .loc 1 189 0 setp.le.s32 %r210,%r104,0; @ %r210 bra $L7; add.u32 %r211,%r104,-1; cvt.u64.u32 %r212,%r211; add.u64 %r213,%r212,1; shl.b64 %r214,%r213,3; add.u64 %r91,%r106,%r214; $L18: .loc 1 190 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r88; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r216,[%value_in]; } add.u64 %r217,%r216,1; add.u64 %r88,%r88,%r217; st.u64 [%r106],%r88; .loc 1 189 0 add.u64 %r106,%r106,8; setp.ne.u64 %r218,%r106,%r91; @ %r218 bra $L18; bra $L7; $L12: $L19: .loc 1 163 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r88; call __nvptx_free,(%out_arg1); } $L9: .loc 1 165 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; call (%value_in),close,(%out_arg1); ld.param.u32 %r221,[%value_in]; } $L2: .loc 1 167 0 st.u32 [%r101],%r74; .loc 1 168 0 mov.u32 %r99,-1; $L1: .loc 1 169 0 mov.u32 %value,%r99; st.param.u32 [%value_out],%value; ret; } lib_a-ldtoa.o/ 0 0 0 644 178751 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: eshdn1 .func eshdn1 (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/ldtoa.c" // BEGIN FUNCTION DECL: eshup1 .func eshup1 (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: m16m .func m16m (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: edivm .func (.param .u32 %value_out) edivm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: emulm .func (.param .u32 %value_out) emulm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: eisnan$part$0 .func (.param .u32 %value_out) eisnan$part$0 (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: eneg .func eneg (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: eisneg .func (.param .u32 %value_out) eisneg (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: emovi .func emovi (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: ecmp .func (.param .u32 %value_out) ecmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: eisinf$part$1 .func (.param .u32 %value_out) eisinf$part$1 (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: eshift$part$4 .func (.param .u32 %value_out) eshift$part$4 (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN FUNCTION DECL: enormlz .func (.param .u32 %value_out) enormlz (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: emdnorm .func emdnorm (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); // BEGIN FUNCTION DECL: eiremain .func eiremain (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: emovo$isra$7 .func emovo$isra$7 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: e53toe$isra$9 .func e53toe$isra$9 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: emul .func emul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN FUNCTION DECL: ediv .func ediv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _ldtoa_r .visible .func (.param .u64 %value_out) _ldtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: _ldcheck .visible .func (.param .u32 %value_out) _ldcheck (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _strtold .visible .func (.param .f64 %value_out) _strtold (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sprintf .extern .func (.param .u32 %value_out) sprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: calloc .extern .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN VAR DEF: etens .const .align 2 .u16 etens[130] = {25974,19090,32842,5439,51532,38810,35360,20994,50272,29989,27186,52818,12954,10446,42829,24036,50493,15197,40587,23186,21100,20686,61835,15656,25869,3095,33141,30086,51574,19784,40038,22776,48208,23636,52325,37318,42510,41134,58137,18083,34078,60087,39166,36891,56763,56973,40441,60411,43646,17233,565,311,14001,13164,50799,36063,33001,18377,37818,16808,20728,9723,51051,27505,15551,42709,65487,8009,49784,16595,0,0,0,0,61472,46493,11120,44456,40389,16489,0,0,0,0,0,0,1024,51647,36379,16436,0,0,0,0,0,0,0,8192,48828,16409,0,0,0,0,0,0,0,0,40000,16396,0,0,0,0,0,0,0,0,51200,16389,0,0,0,0,0,0,0,0,40960,16386 }; // BEGIN VAR DEF: emtens .const .align 2 .u16 emtens[130] = {8240,53244,41411,33059,11747,40926,53966,1224,42717,2776,33380,53963,62186,4820,18725,11748,13366,21327,52910,9579,62783,63128,27603,344,34726,49341,55895,33445,41638,12981,59185,1236,58354,54066,28978,53788,56099,60978,36937,14682,41534,21256,65275,4437,64145,6457,25466,17189,49201,15532,57965,56286,53341,46070,44156,58528,25788,18044,56784,15957,10784,25124,18355,39127,16163,59813,42297,59943,43135,16170,2907,19186,42369,6381,26590,38074,17721,7853,53169,16276,49009,43443,31113,48744,19502,57691,50253,38078,59029,16329,15693,31805,14010,3371,64962,52988,33889,30481,43980,16356,49493,42152,16462,24851,54211,25899,57881,5976,53687,16369,55050,28835,2621,41943,15728,55050,28835,2621,41943,16376,52429,52428,52428,52428,52428,52428,52428,52428,52428,16379 }; // BEGIN VAR DEF: bmask .const .align 2 .u16 bmask[17] = {65535,65534,65532,65528,65520,65504,65472,65408,65280,65024,64512,63488,61440,57344,49152,32768,0 }; // BEGIN VAR DEF: eone .const .align 2 .u16 eone[10] = {0,0,0,0,0,0,0,0,32768,16383 }; // BEGIN VAR DEF: ezero .const .align 2 .u16 ezero[10]; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {32,78,97,78,32,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[12] = {32,45,73,110,102,105,110,105,116,121,32,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[11] = {32,73,110,102,105,110,105,116,121,32,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {78,97,78,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[4] = {69,37,100,0 }; // BEGIN FUNCTION DEF: eshdn1 .func eshdn1 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r52; .reg .u64 %r55; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u16 %r61; .reg .u16 %r62; .reg .pred %r63; .reg .u16 %r64; .reg .u16 %r65; .reg .u32 %r66; .reg .u16 %r67; .reg .u16 %r68; .reg .u16 %r69; .reg .pred %r70; .reg .u16 %r72; .reg .u16 %r74; .reg .u16 %r75; .reg .pred %r76; mov.u64 %r60,%ar0; .loc 1 778 0 add.u64 %r59,%r60,4; add.u64 %r55,%r60,26; .loc 1 780 0 mov.u32 %r58,0; $L5: .loc 1 783 0 ld.u16 %r52,[%r59]; cvt.u16.u32 %r62,%r52; and.b16 %r61,%r62,1; setp.eq.u16 %r63,%r61,0; @ %r63 bra $L2; .loc 1 784 0 cvt.u16.u32 %r65,%r58; or.b16 %r64,%r65,1; cvt.u32.u16 %r58,%r64; $L2: .loc 1 785 0 shr.u32 %r66,%r52,1; cvt.u16.u32 %r67,%r66; .loc 1 786 0 cvt.u16.u32 %r69,%r58; and.b16 %r68,%r69,2; setp.ne.u16 %r70,%r68,0; @ %r70 bra $L3; .loc 1 785 0 st.u16 [%r59],%r67; bra $L4; $L3: .loc 1 787 0 or.b16 %r72,%r67,-32768; st.u16 [%r59],%r72; $L4: .loc 1 788 0 cvt.u16.u32 %r74,%r58; add.u16 %r75,%r74,%r74; cvt.u32.u16 %r58,%r75; .loc 1 789 0 add.u64 %r59,%r59,2; .loc 1 781 0 setp.ne.u64 %r76,%r55,%r59; @ %r76 bra $L5; .loc 1 791 0 ret; } // BEGIN FUNCTION DEF: eshup1 .func eshup1 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r25; .reg .u64 %r29; .reg .u32 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r34; .reg .pred %r35; .reg .u16 %r36; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u16 %r41; .reg .pred %r42; .reg .u16 %r44; .reg .u16 %r46; .reg .u16 %r47; .reg .pred %r48; mov.u64 %r33,%ar0; .loc 1 804 0 add.u64 %r32,%r33,24; add.u64 %r29,%r33,2; .loc 1 805 0 mov.u32 %r31,0; $L14: .loc 1 809 0 ld.u16 %r25,[%r32]; cvt.u16.u32 %r34,%r25; setp.ge.s16 %r35,%r34,0; @ %r35 bra $L11; .loc 1 810 0 cvt.u16.u32 %r37,%r31; or.b16 %r36,%r37,1; cvt.u32.u16 %r31,%r36; $L11: .loc 1 811 0 cvt.u16.u32 %r38,%r25; add.u16 %r39,%r38,%r38; .loc 1 812 0 cvt.u16.u32 %r41,%r31; and.b16 %r40,%r41,2; setp.ne.u16 %r42,%r40,0; @ %r42 bra $L12; .loc 1 811 0 st.u16 [%r32],%r39; bra $L13; $L12: .loc 1 813 0 or.b16 %r44,%r39,1; st.u16 [%r32],%r44; $L13: .loc 1 814 0 cvt.u16.u32 %r46,%r31; add.u16 %r47,%r46,%r46; cvt.u32.u16 %r31,%r47; .loc 1 815 0 add.u64 %r32,%r32,-2; .loc 1 807 0 setp.ne.u64 %r48,%r29,%r32; @ %r48 bra $L14; .loc 1 817 0 ret; } // BEGIN FUNCTION DEF: m16m .func m16m (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[32]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u64 %r40; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u16 %r66; .reg .u16 %r67; .reg .pred %r69; .reg .u64 %r71; .reg .u16 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .pred %r79; .reg .u16 %r80; .reg .pred %r81; .reg .u16 %r82; mov.u32 %r63,%ar0; mov.u64 %r64,%ar1; mov.u64 %r65,%ar2; .loc 1 970 0 cvt.u16.u32 %r66,%r63; cvt.u64.u16 %r52,%r66; .loc 1 972 0 mov.u16 %r67,0; st.u16 [%frame+22],%r67; .loc 1 973 0 st.u16 [%frame+24],%r67; .loc 1 974 0 add.u64 %r57,%r64,24; add.u64 %r58,%r64,4; .loc 1 972 0 add.u64 %r62,%frame,24; .loc 1 982 0 mov.u16 %r82,%r67; $L19: .loc 1 978 0 ld.u16 %r34,[%r57]; add.u64 %r57,%r57,-2; add.u64 %r62,%r62,-2; setp.ne.u32 %r69,%r34,0; @ %r69 bra $L17; .loc 1 982 0 st.u16 [%r62+-2],%r82; bra $L18; $L17: .loc 1 986 0 cvt.u16.u32 %r72,%r34; cvt.u64.u16 %r71,%r72; mul.lo.u64 %r53,%r71,%r52; .loc 1 987 0 and.b64 %r73,%r53,65535; ld.u16 %r74,[%r62+2]; add.u64 %r54,%r73,%r74; .loc 1 988 0 st.u16 [%r62+2],%r54; .loc 1 989 0 shr.u64 %r40,%r54,16; shr.u64 %r75,%r53,16; ld.u16 %r76,[%r62]; add.u64 %r77,%r75,%r76; add.u64 %r55,%r77,%r40; .loc 1 990 0 st.u16 [%r62],%r55; .loc 1 991 0 shr.u64 %r78,%r55,16; st.u16 [%r62+-2],%r78; $L18: .loc 1 976 0 setp.ne.u64 %r79,%r57,%r58; @ %r79 bra $L19; add.u64 %r49,%frame,4; add.u64 %r56,%r65,4; add.u64 %r50,%frame,26; $L20: .loc 1 995 0 ld.u16 %r80,[%r49]; st.u16 [%r56],%r80; add.u64 %r49,%r49,2; add.u64 %r56,%r56,2; .loc 1 994 0 setp.ne.u64 %r81,%r49,%r50; @ %r81 bra $L20; .loc 1 996 0 ret; } // BEGIN FUNCTION DEF: edivm .func (.param .u32 %value_out) edivm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[32]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r68; .reg .u64 %r69; .reg .u32 %r72; .reg .u64 %r74; .reg .u64 %r76; .reg .u64 %r78; .reg .u32 %r79; .reg .u64 %r83; .reg .u32 %r88; .reg .u64 %r89; .reg .u32 %r90; .reg .u64 %r93; .reg .u64 %r96; .reg .u64 %r103; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r116; .reg .u64 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r124; .reg .u64 %r131; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .u32 %r142; .reg .u64 %r144; .reg .u64 %r145; .reg .u64 %r147; .reg .u64 %r150; .reg .u64 %r151; .reg .u32 %r154; .reg .u64 %r156; .reg .u64 %r157; .reg .u64 %r158; .reg .u16 %r159; .reg .u16 %r160; .reg .u16 %r161; .reg .pred %r162; .reg .u64 %r165; .reg .u64 %r167; .reg .u64 %r168; .reg .u64 %r169; .reg .pred %r170; .reg .u64 %r172; .reg .u16 %r175; .reg .u16 %r179; .reg .u16 %r180; .reg .pred %r181; .reg .pred %r182; .reg .pred %r185; .reg .u16 %r186; .reg .u16 %r187; .reg .u64 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .u32 %r194; .reg .pred %r196; .reg .u16 %r197; .reg .u16 %r198; .reg .pred %r199; .reg .pred %r200; .reg .pred %r203; .reg .u16 %r204; .reg .u16 %r205; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u32 %r212; .reg .pred %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .u64 %r217; .reg .u64 %r218; .reg .u64 %r219; .reg .u32 %r221; .reg .pred %r222; .reg .u16 %r223; .reg .u16 %r224; .reg .pred %r225; .reg .u16 %r226; .reg .pred %r227; .reg .u16 %r228; .reg .u16 %r229; .reg .u16 %r230; .reg .pred %r231; .reg .u32 %r232; .reg .u16 %r233; .reg .u32 %r234; .reg .u32 %r235; .reg .u16 %r236; .reg .pred %r237; .reg .u64 %r239; .reg .u64 %r241; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u32 %r245; .reg .u64 %r246; mov.u64 %r156,%ar0; mov.u64 %r157,%ar1; mov.u64 %r158,%ar2; .loc 1 1010 0 add.u64 %r83,%r158,52; .loc 1 1013 0 ld.u16 %r159,[%r157]; st.u16 [%r158+52],%r159; .loc 1 1014 0 ld.u16 %r160,[%r157+2]; st.u16 [%r158+54],%r160; add.u64 %r239,%r158,56; mov.u64 %r74,%r239; add.u64 %r140,%r158,78; .loc 1 1018 0 mov.u16 %r161,0; $L24: st.u16 [%r74],%r161; add.u64 %r74,%r74,2; .loc 1 1016 0 setp.ne.u64 %r162,%r140,%r74; @ %r162 bra $L24; .loc 1 1020 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r157; call eshdn1,(%out_arg1); } .loc 1 1028 0 ld.u16 %r68,[%r156+6]; shl.b64 %r165,%r68,16; sub.u64 %r69,%r165,%r68; add.u64 %r144,%r157,4; add.u64 %r145,%r157,24; mov.u64 %r78,%r239; mov.u64 %r151,%r83; add.u64 %r76,%r151,26; add.u64 %r241,%frame,4; add.u64 %r244,%frame,26; add.u64 %r243,%frame,24; add.u64 %r242,%r157,2; .loc 1 940 0 mov.u32 %r245,0; add.u64 %r246,%frame,2; $L35: .loc 1 1025 0 ld.u16 %r167,[%r157+4]; shl.b64 %r168,%r167,16; ld.u16 %r169,[%r157+6]; add.u64 %r89,%r168,%r169; .loc 1 1028 0 setp.lt.u64 %r170,%r69,%r89; @ %r170 bra $L38; .loc 1 1031 0 div.u64 %r172,%r89,%r68; cvt.u16.u64 %r175,%r172; cvt.u32.u16 %r79,%r175; bra $L25; $L38: .loc 1 1029 0 mov.u32 %r79,65535; $L25: .loc 1 1040 0 { .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r79; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r156; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call m16m,(%out_arg1,%out_arg2,%out_arg3); } mov.u64 %r124,%r241; mov.u64 %r147,%r144; mov.u64 %r93,%r144; mov.u64 %r96,%r241; $L27: .loc 1 756 0 ld.u16 %r179,[%r96]; ld.u16 %r180,[%r93]; setp.ne.u16 %r181,%r179,%r180; @ %r181 bra $L26; add.u64 %r96,%r96,2; add.u64 %r93,%r93,2; .loc 1 754 0 setp.ne.u64 %r182,%r244,%r96; @ %r182 bra $L27; bra $L28; $L26: .loc 1 762 0 setp.le.u16 %r185,%r179,%r180; @ %r185 bra $L28; .loc 1 1044 0 cvt.u16.u32 %r187,%r79; add.u16 %r186,%r187,-1; cvt.u32.u16 %r90,%r186; .loc 1 938 0 add.u64 %r119,%r156,24; mov.u64 %r106,%r119; .loc 1 940 0 mov.u32 %r154,%r245; .loc 1 939 0 mov.u64 %r107,%r243; $L29: .loc 1 943 0 ld.u16 %r188,[%r107]; ld.u16 %r189,[%r106]; sub.u64 %r190,%r188,%r189; cvt.u64.u32 %r191,%r154; sub.u64 %r103,%r190,%r191; .loc 1 948 0 st.u16 [%r107],%r103; .loc 1 949 0 add.u64 %r106,%r106,-2; .loc 1 950 0 add.u64 %r107,%r107,-2; .loc 1 944 0 shr.u64 %r192,%r103,16; cvt.u32.u64 %r194,%r192; and.b32 %r154,%r194,1; .loc 1 941 0 setp.ne.u64 %r196,%r107,%r246; @ %r196 bra $L29; mov.u64 %r121,%r144; $L31: .loc 1 756 0 ld.u16 %r197,[%r124]; ld.u16 %r198,[%r121]; setp.ne.u16 %r199,%r197,%r198; @ %r199 bra $L30; add.u64 %r124,%r124,2; add.u64 %r121,%r121,2; .loc 1 754 0 setp.ne.u64 %r200,%r244,%r124; @ %r200 bra $L31; .loc 1 1044 0 mov.u32 %r79,%r90; bra $L28; $L30: .loc 1 762 0 setp.le.u16 %r203,%r197,%r198; @ %r203 bra $L39; .loc 1 1048 0 cvt.u16.u32 %r205,%r79; add.u16 %r204,%r205,-2; cvt.u32.u16 %r79,%r204; .loc 1 940 0 mov.u32 %r142,%r245; .loc 1 939 0 mov.u64 %r120,%r243; $L32: .loc 1 943 0 ld.u16 %r206,[%r120]; ld.u16 %r207,[%r119]; sub.u64 %r208,%r206,%r207; cvt.u64.u32 %r209,%r142; sub.u64 %r116,%r208,%r209; .loc 1 948 0 st.u16 [%r120],%r116; .loc 1 949 0 add.u64 %r119,%r119,-2; .loc 1 950 0 add.u64 %r120,%r120,-2; .loc 1 944 0 shr.u64 %r210,%r116,16; cvt.u32.u64 %r212,%r210; and.b32 %r142,%r212,1; .loc 1 941 0 setp.ne.u64 %r214,%r120,%r246; @ %r214 bra $L32; bra $L28; $L39: .loc 1 1044 0 mov.u32 %r79,%r90; $L28: .loc 1 939 0 mov.u64 %r135,%r145; .loc 1 940 0 mov.u32 %r141,%r245; .loc 1 938 0 mov.u64 %r134,%r243; $L33: .loc 1 943 0 ld.u16 %r215,[%r135]; ld.u16 %r216,[%r134]; sub.u64 %r217,%r215,%r216; cvt.u64.u32 %r218,%r141; sub.u64 %r131,%r217,%r218; .loc 1 948 0 st.u16 [%r135],%r131; .loc 1 949 0 add.u64 %r134,%r134,-2; .loc 1 950 0 add.u64 %r135,%r135,-2; .loc 1 944 0 shr.u64 %r219,%r131,16; cvt.u32.u64 %r221,%r219; and.b32 %r141,%r221,1; .loc 1 941 0 setp.ne.u64 %r222,%r135,%r242; @ %r222 bra $L33; .loc 1 1071 0 cvt.u16.u32 %r223,%r79; st.u16 [%r78],%r223; mov.u64 %r138,%r144; .loc 1 873 0 mov.u64 %r122,%r144; $L34: .loc 1 877 0 add.u64 %r122,%r122,2; ld.u16 %r224,[%r122]; st.u16 [%r138],%r224; add.u64 %r138,%r138,2; .loc 1 876 0 setp.ne.u64 %r225,%r122,%r145; @ %r225 bra $L34; .loc 1 879 0 mov.u16 %r226,0; st.u16 [%r157+24],%r226; add.u64 %r78,%r78,2; .loc 1 1022 0 setp.ne.u64 %r227,%r76,%r78; @ %r227 bra $L35; mov.u64 %r150,%r157; add.u64 %r139,%r150,26; .loc 1 1076 0 mov.u32 %r88,0; $L36: .loc 1 1079 0 ld.u16 %r229,[%r147]; cvt.u16.u32 %r230,%r88; or.b16 %r228,%r229,%r230; cvt.u32.u16 %r88,%r228; add.u64 %r147,%r147,2; .loc 1 1077 0 setp.ne.u64 %r231,%r139,%r147; @ %r231 bra $L36; .loc 1 1081 0 cvt.u16.u32 %r233,%r88; set.u32.ne.u16 %r234,%r233,0; neg.s32 %r235,%r234; cvt.u32.u32 %r232,%r235; cvt.u32.u8 %r72,%r232; $L37: .loc 1 1085 0 ld.u16 %r236,[%r151]; st.u16 [%r150],%r236; add.u64 %r151,%r151,2; add.u64 %r150,%r150,2; .loc 1 1084 0 setp.ne.u64 %r237,%r78,%r151; @ %r237 bra $L37; .loc 1 1088 0 mov.u32 %value,%r72; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: emulm .func (.param .u32 %value_out) emulm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[32]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r48; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r55; .reg .u32 %r57; .reg .u64 %r65; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u32 %r75; .reg .u64 %r78; .reg .u64 %r81; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .pred %r89; .reg .pred %r90; .reg .u16 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u32 %r103; .reg .pred %r105; .reg .u16 %r106; .reg .pred %r107; .reg .u16 %r108; .reg .pred %r109; .reg .u16 %r110; .reg .pred %r111; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r116; mov.u64 %r83,%ar0; mov.u64 %r84,%ar1; mov.u64 %r85,%ar2; .loc 1 1101 0 ld.u16 %r86,[%r84]; st.u16 [%r85+52],%r86; .loc 1 1102 0 ld.u16 %r87,[%r84+2]; st.u16 [%r85+54],%r87; add.u64 %r113,%r85,56; mov.u64 %r52,%r113; .loc 1 1099 0 add.u64 %r78,%r85,52; add.u64 %r114,%r85,78; .loc 1 1104 0 mov.u16 %r88,0; $L51: st.u16 [%r52],%r88; add.u64 %r52,%r52,2; .loc 1 1103 0 setp.ne.u64 %r89,%r114,%r52; @ %r89 bra $L51; .loc 1 1107 0 add.u64 %r81,%r83,24; add.u64 %r55,%r85,76; add.u64 %r53,%r83,4; .loc 1 1106 0 mov.u32 %r57,0; add.u64 %r116,%frame,2; $L56: .loc 1 1111 0 ld.u16 %r48,[%r81]; add.u64 %r81,%r81,-2; setp.ne.u32 %r90,%r48,0; @ %r90 bra $L52; $L55: .loc 1 1120 0 ld.u16 %r92,[%r85+76]; cvt.u16.u32 %r93,%r57; or.b16 %r91,%r92,%r93; cvt.u32.u16 %r57,%r91; .loc 1 892 0 mov.u64 %r73,%r114; .loc 1 891 0 mov.u64 %r72,%r55; bra $L53; $L52: .loc 1 1117 0 { .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r48; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r84; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call m16m,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 912 0 mov.u64 %r69,%r55; .loc 1 913 0 mov.u32 %r75,0; .loc 1 911 0 add.u64 %r68,%frame,24; $L54: .loc 1 916 0 ld.u16 %r97,[%r68]; ld.u16 %r98,[%r69]; add.u64 %r99,%r97,%r98; cvt.u64.u32 %r100,%r75; add.u64 %r65,%r99,%r100; .loc 1 921 0 st.u16 [%r69],%r65; .loc 1 922 0 add.u64 %r68,%r68,-2; .loc 1 923 0 add.u64 %r69,%r69,-2; .loc 1 917 0 shr.u64 %r101,%r65,16; cvt.u32.u64 %r103,%r101; and.b32 %r75,%r103,1; .loc 1 914 0 setp.ne.u64 %r105,%r68,%r116; @ %r105 bra $L54; bra $L55; $L53: .loc 1 895 0 add.u64 %r72,%r72,-2; add.u64 %r73,%r73,-2; ld.u16 %r106,[%r72]; st.u16 [%r73],%r106; .loc 1 894 0 setp.ne.u64 %r107,%r113,%r72; @ %r107 bra $L53; .loc 1 897 0 mov.u16 %r108,0; st.u16 [%r85+56],%r108; .loc 1 1109 0 setp.ne.u64 %r109,%r53,%r81; @ %r109 bra $L56; mov.u64 %r71,%r84; $L57: .loc 1 1125 0 ld.u16 %r110,[%r78]; st.u16 [%r71],%r110; add.u64 %r78,%r78,2; add.u64 %r71,%r71,2; .loc 1 1124 0 setp.ne.u64 %r111,%r52,%r78; @ %r111 bra $L57; .loc 1 1129 0 mov.u32 %value,%r57; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eisnan$part$0 .func (.param .u32 %value_out) eisnan$part$0 (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r25; .reg .u64 %r28; .reg .u32 %r29; .reg .u16 %r31; .reg .pred %r32; .reg .pred %r33; mov.u64 %r25,%ar0; add.u64 %r28,%r25,18; $L65: .loc 1 526 0 ld.u16 %r31,[%r25]; setp.ne.u16 %r32,%r31,0; @ %r32 bra $L66; add.u64 %r25,%r25,2; .loc 1 524 0 setp.ne.u64 %r33,%r25,%r28; @ %r33 bra $L65; .loc 1 530 0 mov.u32 %r29,0; bra $L63; $L66: .loc 1 527 0 mov.u32 %r29,1; $L63: .loc 1 531 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eneg .func eneg (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u64 %r26; .reg .u16 %r27; .reg .u16 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .u16 %r33; .reg .u16 %r34; mov.u64 %r26,%ar0; .loc 1 521 0 ld.u16 %r23,[%r26+18]; cvt.u16.u32 %r28,%r23; and.b16 %r27,%r28,32767; setp.ne.u16 %r29,%r27,32767; @ %r29 bra $L69; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r31,[%value_in]; } .loc 1 470 0 setp.ne.u32 %r32,%r31,0; @ %r32 bra $L68; $L69: .loc 1 473 0 cvt.u16.u32 %r34,%r23; add.u16 %r33,%r34,-32768; st.u16 [%r26+18],%r33; $L68: .loc 1 474 0 ret; } // BEGIN FUNCTION DEF: eisneg .func (.param .u32 %value_out) eisneg (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u16 %r30; .reg .pred %r31; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .u16 %r37; mov.u64 %r28,%ar0; .loc 1 521 0 ld.u16 %r23,[%r28+18]; cvt.u16.u32 %r30,%r23; and.b16 %r29,%r30,32767; setp.ne.u16 %r31,%r29,32767; @ %r31 bra $L72; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r33,[%value_in]; } .loc 1 485 0 setp.ne.u32 %r34,%r33,0; @ %r34 bra $L74; $L72: .loc 1 488 0 cvt.u16.u32 %r37,%r23; cvt.s32.s16 %r36,%r37; shr.u32 %r27,%r36,31; bra $L71; $L74: .loc 1 486 0 mov.u32 %r27,0; $L71: .loc 1 492 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: emovi .func emovi (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r33; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r51; .reg .u64 %r53; .reg .u64 %r55; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u16 %r60; .reg .pred %r61; .reg .u16 %r62; .reg .u16 %r63; .reg .u16 %r64; .reg .u16 %r65; .reg .pred %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .pred %r71; .reg .u32 %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; .reg .pred %r77; .reg .u16 %r78; .reg .pred %r79; .reg .u16 %r80; .reg .u16 %r81; .reg .pred %r82; .reg .u16 %r83; mov.u64 %r58,%ar0; mov.u64 %r59,%ar1; .loc 1 592 0 ld.u16 %r60,[%r58+18]; setp.ge.s16 %r61,%r60,0; @ %r61 bra $L76; .loc 1 593 0 mov.u16 %r62,-1; st.u16 [%r59],%r62; bra $L77; $L76: .loc 1 595 0 mov.u16 %r63,0; st.u16 [%r59],%r63; $L77: .loc 1 597 0 add.u64 %r44,%r58,16; .loc 1 598 0 ld.u16 %r65,[%r58+18]; and.b16 %r64,%r65,32767; st.u16 [%r59+2],%r64; .loc 1 600 0 setp.ne.u16 %r68,%r64,32767; @ %r68 bra $L78; .loc 1 521 0 ld.u16 %r70,[%r58+18]; and.b16 %r69,%r70,32767; setp.ne.u16 %r71,%r69,32767; @ %r71 bra $L79; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r58; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r73,[%value_in]; } .loc 1 603 0 setp.eq.u32 %r74,%r73,0; @ %r74 bra $L79; .loc 1 605 0 mov.u16 %r75,0; st.u16 [%r59+4],%r75; mov.u64 %r55,%r44; add.u64 %r53,%r59,6; add.u64 %r43,%r58,-4; $L80: .loc 1 607 0 ld.u16 %r76,[%r55]; st.u16 [%r53],%r76; add.u64 %r55,%r55,-2; add.u64 %r53,%r53,2; .loc 1 606 0 setp.ne.u64 %r77,%r43,%r55; @ %r77 bra $L80; bra $L75; $L79: add.u64 %r40,%r59,4; add.u64 %r39,%r59,26; .loc 1 612 0 mov.u16 %r78,0; $L82: st.u16 [%r40],%r78; add.u64 %r40,%r40,2; .loc 1 611 0 setp.ne.u64 %r79,%r39,%r40; @ %r79 bra $L82; bra $L75; $L78: .loc 1 617 0 mov.u16 %r80,0; st.u16 [%r59+4],%r80; mov.u64 %r33,%r44; add.u64 %r51,%r59,6; add.u64 %r57,%r58,-2; $L84: .loc 1 620 0 ld.u16 %r81,[%r33]; st.u16 [%r51],%r81; add.u64 %r33,%r33,-2; add.u64 %r51,%r51,2; .loc 1 619 0 setp.ne.u64 %r82,%r33,%r57; @ %r82 bra $L84; .loc 1 622 0 mov.u16 %r83,0; st.u16 [%r59+24],%r83; $L75: .loc 1 623 0 ret; } // BEGIN FUNCTION DEF: ecmp .func (.param .u32 %value_out) ecmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[56]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r34; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u64 %r47; .reg .u64 %r50; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r55; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u16 %r61; .reg .u16 %r62; .reg .pred %r63; .reg .u32 %r65; .reg .pred %r66; .reg .u16 %r67; .reg .u16 %r68; .reg .pred %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r75; .reg .u16 %r78; .reg .u16 %r79; .reg .pred %r80; .reg .u16 %r83; .reg .pred %r84; .reg .u16 %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .pred %r89; .reg .u16 %r91; .reg .u16 %r92; .reg .pred %r93; .reg .pred %r94; .reg .pred %r97; mov.u64 %r59,%ar0; mov.u64 %r60,%ar1; .loc 1 521 0 ld.u16 %r62,[%r59+18]; and.b16 %r61,%r62,32767; setp.ne.u16 %r63,%r61,32767; @ %r63 bra $L92; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r59; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r65,[%value_in]; } .loc 1 2356 0 setp.ne.u32 %r66,%r65,0; @ %r66 bra $L102; $L92: .loc 1 521 0 ld.u16 %r68,[%r60+18]; and.b16 %r67,%r68,32767; setp.ne.u16 %r69,%r67,32767; @ %r69 bra $L94; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r60; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r71,[%value_in]; } .loc 1 2356 0 setp.ne.u32 %r72,%r71,0; @ %r72 bra $L103; $L94: .loc 1 2359 0 add.u64 %r75,%frame,26; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r59; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r75; call emovi,(%out_arg1,%out_arg2); } .loc 1 2361 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r60; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call emovi,(%out_arg1,%out_arg2); } .loc 1 2364 0 ld.u16 %r34,[%frame+26]; ld.u16 %r78,[%frame]; cvt.u16.u32 %r79,%r34; setp.eq.u16 %r80,%r78,%r79; @ %r80 bra $L95; add.u64 %r40,%frame,28; add.u64 %r47,%frame,2; add.u64 %r50,%frame,50; $L97: .loc 1 2369 0 ld.u16 %r83,[%r40]; setp.ne.u16 %r84,%r83,0; @ %r84 bra $L96; .loc 1 2371 0 ld.u16 %r85,[%r47]; setp.ne.u16 %r86,%r85,0; @ %r86 bra $L96; add.u64 %r40,%r40,2; add.u64 %r47,%r47,2; .loc 1 2367 0 setp.ne.u64 %r87,%r40,%r50; @ %r87 bra $L97; .loc 1 2374 0 mov.u32 %r58,0; bra $L91; $L96: .loc 1 2376 0 setp.eq.u32 %r88,%r34,0; .loc 1 2379 0 selp.u32 %r58,1,-1,%r88; bra $L91; $L95: .loc 1 2382 0 setp.eq.u32 %r89,%r34,0; .loc 1 2385 0 selp.u32 %r58,1,-1,%r89; add.u64 %r52,%frame,2; add.u64 %r53,%frame,28; add.u64 %r55,%frame,24; bra $L99; $L101: .loc 1 2389 0 ld.u16 %r38,[%r53]; ld.u16 %r39,[%r52]; add.u64 %r52,%r52,2; add.u64 %r53,%r53,2; cvt.u16.u32 %r91,%r38; cvt.u16.u32 %r92,%r39; setp.ne.u16 %r93,%r91,%r92; @ %r93 bra $L100; $L99: .loc 1 2394 0 setp.ne.u64 %r94,%r52,%r55; @ %r94 bra $L101; .loc 1 2374 0 mov.u32 %r58,0; bra $L91; $L100: .loc 1 2402 0 setp.gt.u16 %r97,%r91,%r92; @ %r97 bra $L91; .loc 1 2405 0 neg.s32 %r58,%r58; bra $L91; $L102: .loc 1 2357 0 mov.u32 %r58,-2; bra $L91; $L103: mov.u32 %r58,-2; $L91: .loc 1 2406 0 mov.u32 %value,%r58; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eisinf$part$1 .func (.param .u32 %value_out) eisinf$part$1 (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r25; .reg .u32 %r27; .reg .u32 %r30; mov.u64 %r25,%ar0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r27,[%value_in]; } .loc 1 504 0 set.u32.eq.u32 %r30,%r27,0; neg.s32 %value,%r30; .loc 1 511 0 st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eshift$part$4 .func (.param .u32 %value_out) eshift$part$4 (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u32 %r59; .reg .u64 %r62; .reg .u64 %r64; .reg .u32 %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u32 %r75; .reg .u64 %r80; .reg .u32 %r83; .reg .u64 %r90; .reg .u64 %r95; .reg .u64 %r97; .reg .u64 %r103; .reg .u32 %r104; .reg .u64 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .u16 %r113; .reg .u16 %r114; .reg .u16 %r115; .reg .u16 %r116; .reg .pred %r117; .reg .u16 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u16 %r121; .reg .u16 %r123; .reg .u16 %r124; .reg .u32 %r126; .reg .u16 %r127; .reg .u16 %r128; .reg .u16 %r129; .reg .u32 %r130; .reg .u16 %r131; .reg .pred %r132; .reg .pred %r137; .reg .u16 %r138; .reg .u16 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .pred %r144; .reg .u16 %r145; .reg .pred %r146; .reg .u16 %r147; .reg .pred %r148; .reg .pred %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .u16 %r156; .reg .u16 %r157; .reg .u32 %r158; .reg .u16 %r159; .reg .pred %r160; .reg .pred %r165; .reg .pred %r167; .reg .u16 %r169; .reg .u32 %r170; .reg .u64 %r173; .reg .u64 %r174; mov.u64 %r108,%ar0; mov.u32 %r109,%ar1; .loc 1 2426 0 setp.lt.s32 %r110,%r109,0; @ %r110 bra $L109; .loc 1 2452 0 setp.gt.s32 %r111,%r109,15; @ %r111 bra $L110; bra $L111; $L109: .loc 1 2428 0 neg.s32 %r72,%r109; .loc 1 2429 0 setp.ge.s32 %r112,%r109,-15; @ %r112 bra $L126; add.u64 %r97,%r108,26; add.u64 %r95,%r108,24; .loc 1 2423 0 mov.u32 %r71,0; add.u64 %r173,%r108,4; .loc 1 897 0 cvt.u16.u32 %r118,%r71; $L114: .loc 1 2431 0 ld.u16 %r114,[%r108+24]; cvt.u16.u32 %r115,%r71; or.b16 %r113,%r114,%r115; cvt.u32.u16 %r71,%r113; .loc 1 892 0 mov.u64 %r52,%r97; .loc 1 891 0 mov.u64 %r50,%r95; $L113: .loc 1 895 0 add.u64 %r50,%r50,-2; add.u64 %r52,%r52,-2; ld.u16 %r116,[%r50]; st.u16 [%r52],%r116; .loc 1 894 0 setp.ne.u64 %r117,%r173,%r50; @ %r117 bra $L113; .loc 1 897 0 st.u16 [%r108+4],%r118; .loc 1 2433 0 add.u32 %r72,%r72,-16; .loc 1 2429 0 setp.gt.s32 %r119,%r72,15; @ %r119 bra $L114; bra $L112; $L126: .loc 1 2423 0 mov.u32 %r71,0; $L112: .loc 1 2436 0 setp.le.s32 %r120,%r72,7; @ %r120 bra $L115; add.u64 %r64,%r108,4; .loc 1 2438 0 ld.u8 %r121,[%r108+24]; cvt.u16.u32 %r124,%r71; or.b16 %r123,%r121,%r124; cvt.u32.u16 %r71,%r123; add.u64 %r90,%r108,26; .loc 1 831 0 mov.u32 %r83,0; $L116: .loc 1 834 0 ld.u16 %r59,[%r64]; .loc 1 835 0 shr.u32 %r126,%r59,8; .loc 1 836 0 cvt.u16.u32 %r128,%r126; cvt.u16.u32 %r129,%r83; or.b16 %r127,%r128,%r129; st.u16 [%r64],%r127; .loc 1 838 0 add.u64 %r64,%r64,2; .loc 1 834 0 shl.b32 %r130,%r59,8; .loc 1 837 0 cvt.u16.u32 %r131,%r130; cvt.u32.u16 %r83,%r131; .loc 1 832 0 setp.ne.u64 %r132,%r64,%r90; @ %r132 bra $L116; and.b32 %r72,%r72,7; $L115: .loc 1 2443 0 setp.eq.u32 %r137,%r72,0; @ %r137 bra $L117; $L118: .loc 1 2445 0 ld.u16 %r139,[%r108+24]; and.b16 %r138,%r139,1; cvt.u16.u32 %r141,%r71; or.b16 %r140,%r138,%r141; cvt.u32.u16 %r71,%r140; .loc 1 2446 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshdn1,(%out_arg1); } .loc 1 2447 0 add.u32 %r72,%r72,-1; .loc 1 2443 0 setp.ne.u32 %r144,%r72,0; @ %r144 bra $L118; bra $L117; $L110: add.u64 %r106,%r108,4; .loc 1 2452 0 mov.u32 %r51,%r109; add.u64 %r174,%r108,24; .loc 1 879 0 mov.u16 %r147,0; $L120: mov.u64 %r62,%r106; .loc 1 873 0 mov.u64 %r73,%r106; $L119: .loc 1 877 0 add.u64 %r73,%r73,2; ld.u16 %r145,[%r73]; st.u16 [%r62],%r145; add.u64 %r62,%r62,2; .loc 1 876 0 setp.ne.u64 %r146,%r73,%r174; @ %r146 bra $L119; .loc 1 879 0 st.u16 [%r108+24],%r147; .loc 1 2455 0 add.u32 %r51,%r51,-16; .loc 1 2452 0 setp.gt.s32 %r148,%r51,15; @ %r148 bra $L120; and.b32 %r109,%r109,15; $L111: .loc 1 2458 0 setp.le.s32 %r153,%r109,7; @ %r153 bra $L121; add.u64 %r80,%r108,24; add.u64 %r103,%r108,2; .loc 1 852 0 mov.u32 %r104,0; $L122: .loc 1 856 0 ld.u16 %r75,[%r80]; .loc 1 857 0 shl.b32 %r154,%r75,8; .loc 1 858 0 cvt.u16.u32 %r156,%r154; cvt.u16.u32 %r157,%r104; or.b16 %r155,%r156,%r157; st.u16 [%r80],%r155; .loc 1 860 0 add.u64 %r80,%r80,-2; .loc 1 856 0 shr.u32 %r158,%r75,8; .loc 1 859 0 cvt.u16.u32 %r159,%r158; cvt.u32.u16 %r104,%r159; .loc 1 854 0 setp.ne.u64 %r160,%r80,%r103; @ %r160 bra $L122; and.b32 %r109,%r109,7; $L121: .loc 1 2464 0 setp.ne.u32 %r165,%r109,0; @ %r165 bra $L123; $L125: .loc 1 852 0 mov.u32 %r107,0; bra $L108; $L123: .loc 1 2466 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshup1,(%out_arg1); } .loc 1 2467 0 add.u32 %r109,%r109,-1; .loc 1 2464 0 setp.ne.u32 %r167,%r109,0; @ %r167 bra $L123; bra $L125; $L117: .loc 1 2470 0 cvt.u16.u32 %r169,%r71; set.u32.ne.u16 %r170,%r169,0; neg.s32 %r107,%r170; $L108: .loc 1 2473 0 mov.u32 %value,%r107; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: enormlz .func (.param .u32 %value_out) enormlz (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r82; .reg .u32 %r84; .reg .u64 %r87; .reg .u32 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u32 %r94; .reg .u64 %r98; .reg .u64 %r101; .reg .u32 %r102; .reg .u32 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u16 %r110; .reg .pred %r111; .reg .u16 %r112; .reg .pred %r113; .reg .pred %r115; .reg .pred %r116; .reg .u16 %r117; .reg .u16 %r118; .reg .pred %r119; .reg .u32 %r120; .reg .u16 %r121; .reg .u16 %r122; .reg .u16 %r123; .reg .u32 %r124; .reg .u16 %r125; .reg .pred %r126; .reg .u16 %r127; .reg .u16 %r128; .reg .pred %r129; .reg .pred %r131; .reg .u16 %r132; .reg .pred %r133; .reg .u16 %r134; .reg .u16 %r135; .reg .pred %r136; .reg .u32 %r137; .reg .u16 %r138; .reg .u32 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .u16 %r142; .reg .pred %r143; .reg .pred %r145; .reg .u64 %r148; .reg .pred %r149; .reg .u64 %r151; .reg .u16 %r152; mov.u64 %r108,%ar0; .loc 1 2490 0 ld.u16 %r106,[%r108+4]; setp.ne.u32 %r149,%r106,0; @ %r149 bra $L140; .loc 1 2493 0 ld.u16 %r102,[%r108+6]; cvt.u16.u32 %r110,%r102; setp.lt.s16 %r111,%r110,0; @ %r111 bra $L156; .loc 1 2488 0 mov.u32 %r107,%r106; add.u64 %r151,%r108,26; .loc 1 879 0 cvt.u16.u32 %r152,%r107; bra $L142; $L145: .loc 1 874 0 add.u64 %r90,%r108,6; .loc 1 873 0 add.u64 %r91,%r108,4; $L144: .loc 1 877 0 add.u64 %r90,%r90,2; cvt.u16.u32 %r112,%r102; st.u16 [%r91],%r112; add.u64 %r91,%r91,2; .loc 1 876 0 setp.eq.u64 %r113,%r90,%r151; @ %r113 bra $L143; ld.u16 %r102,[%r90]; bra $L144; $L143: .loc 1 879 0 st.u16 [%r108+24],%r152; .loc 1 2498 0 add.u32 %r107,%r107,16; .loc 1 2502 0 setp.eq.u32 %r115,%r107,160; @ %r115 bra $L139; ld.u16 %r102,[%r108+6]; $L142: .loc 1 2495 0 setp.eq.u32 %r116,%r102,0; @ %r116 bra $L145; cvt.u16.u32 %r118,%r102; and.b16 %r117,%r118,-256; cvt.u32.u16 %r88,%r117; .loc 1 2506 0 setp.ne.u32 %r119,%r88,0; @ %r119 bra $L149; add.u64 %r101,%r108,24; add.u64 %r148,%r108,2; $L148: .loc 1 852 0 mov.u32 %r105,%r88; .loc 1 851 0 mov.u64 %r98,%r101; $L147: .loc 1 856 0 ld.u16 %r94,[%r98]; .loc 1 857 0 shl.b32 %r120,%r94,8; .loc 1 858 0 cvt.u16.u32 %r122,%r120; cvt.u16.u32 %r123,%r105; or.b16 %r121,%r122,%r123; st.u16 [%r98],%r121; .loc 1 860 0 add.u64 %r98,%r98,-2; .loc 1 856 0 shr.u32 %r124,%r94,8; .loc 1 859 0 cvt.u16.u32 %r125,%r124; cvt.u32.u16 %r105,%r125; .loc 1 854 0 setp.ne.u64 %r126,%r148,%r98; @ %r126 bra $L147; .loc 1 2509 0 add.u32 %r107,%r107,8; .loc 1 2506 0 ld.u16 %r102,[%r108+6]; cvt.u16.u32 %r128,%r102; and.b16 %r127,%r128,-256; setp.eq.u16 %r129,%r127,0; @ %r129 bra $L148; bra $L149; $L150: .loc 1 2514 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshup1,(%out_arg1); } .loc 1 2515 0 add.u32 %r107,%r107,1; .loc 1 2516 0 setp.gt.s32 %r131,%r107,160; @ %r131 bra $L139; ld.u16 %r102,[%r108+6]; $L149: .loc 1 2512 0 cvt.u16.u32 %r132,%r102; setp.ge.s16 %r133,%r132,0; @ %r133 bra $L150; bra $L139; $L140: .loc 1 2528 0 cvt.u16.u32 %r135,%r106; and.b16 %r134,%r135,-256; setp.eq.u16 %r136,%r134,0; @ %r136 bra $L157; .loc 1 830 0 add.u64 %r87,%r108,4; add.u64 %r92,%r108,26; .loc 1 831 0 mov.u32 %r82,0; $L153: .loc 1 834 0 shl.b32 %r137,%r106,8; cvt.u16.u32 %r138,%r137; cvt.u32.u16 %r84,%r138; .loc 1 835 0 shr.u32 %r139,%r106,8; .loc 1 836 0 cvt.u16.u32 %r141,%r139; cvt.u16.u32 %r142,%r82; or.b16 %r140,%r141,%r142; st.u16 [%r87],%r140; .loc 1 838 0 add.u64 %r87,%r87,2; .loc 1 832 0 setp.ne.u64 %r143,%r87,%r92; @ %r143 bra $L152; ld.u16 %r106,[%r108+4]; .loc 1 2531 0 mov.u32 %r107,-8; setp.ne.u32 %r149,%r106,0; bra $L154; $L152: ld.u16 %r106,[%r87]; .loc 1 837 0 mov.u32 %r82,%r84; bra $L153; $L155: .loc 1 2535 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshdn1,(%out_arg1); } .loc 1 2536 0 add.u32 %r107,%r107,-1; .loc 1 2538 0 setp.eq.u32 %r145,%r107,-145; @ %r145 bra $L139; ld.u16 %r106,[%r108+4]; setp.ne.u32 %r149,%r106,0; bra $L154; $L157: .loc 1 2488 0 mov.u32 %r107,0; $L154: .loc 1 2533 0 @ %r149 bra $L155; bra $L139; $L156: .loc 1 2494 0 mov.u32 %r107,%r106; $L139: .loc 1 2545 0 mov.u32 %value,%r107; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: emdnorm .func emdnorm (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u32 %r52; .reg .u32 %r57; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u64 %r80; .reg .u32 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u32 %r88; .reg .u32 %r89; .reg .u64 %r102; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r132; .reg .u32 %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .u32 %r142; .reg .u64 %r143; .reg .u32 %r144; .reg .u64 %r145; .reg .u32 %r147; .reg .u64 %r148; .reg .u32 %r150; .reg .u32 %r151; .reg .u32 %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .u16 %r156; .reg .u16 %r157; .reg .u32 %r158; .reg .u16 %r159; .reg .pred %r160; .reg .u16 %r161; .reg .pred %r162; .reg .pred %r163; .reg .pred %r164; .reg .u32 %r166; .reg .u32 %r167; .reg .pred %r168; .reg .u16 %r169; .reg .pred %r170; .reg .pred %r171; .reg .u32 %r172; .reg .pred %r173; .reg .u16 %r174; .reg .pred %r175; .reg .pred %r176; .reg .pred %r177; .reg .pred %r178; .reg .pred %r179; .reg .pred %r180; .reg .pred %r181; .reg .u32 %r182; .reg .u32 %r183; .reg .u16 %r184; .reg .u32 %r185; .reg .u32 %r186; .reg .u32 %r187; .reg .u16 %r188; .reg .u32 %r190; .reg .u32 %r191; .reg .u16 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .u32 %r195; .reg .u16 %r196; .reg .u32 %r198; .reg .u32 %r199; .reg .u16 %r200; .reg .u32 %r202; .reg .u32 %r203; .reg .u16 %r204; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u16 %r211; .reg .pred %r212; .reg .pred %r213; .reg .u16 %r214; .reg .u16 %r215; .reg .u32 %r216; .reg .u64 %r218; .reg .u64 %r219; .reg .u16 %r220; .reg .u16 %r221; .reg .u16 %r222; .reg .pred %r223; .reg .pred %r224; .reg .u64 %r225; .reg .u32 %r226; .reg .u32 %r227; .reg .u64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u16 %r233; .reg .pred %r234; .reg .u16 %r235; .reg .u16 %r236; .reg .u16 %r237; .reg .pred %r238; .reg .u16 %r239; .reg .u16 %r240; .reg .u16 %r241; .reg .u16 %r242; .reg .u16 %r243; .reg .u16 %r244; .reg .u16 %r245; .reg .pred %r246; .reg .pred %r249; .reg .pred %r250; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .u16 %r254; .reg .u16 %r255; .reg .u16 %r256; .reg .pred %r257; .reg .pred %r258; .reg .u64 %r259; .reg .u64 %r260; .reg .u64 %r261; .reg .u64 %r262; .reg .u64 %r263; .reg .u32 %r265; .reg .pred %r266; .reg .u32 %r268; .reg .u32 %r269; .reg .u32 %r271; .reg .u32 %r272; .reg .u16 %r273; .reg .u16 %r274; .reg .u16 %r275; .reg .u32 %r276; .reg .u16 %r277; .reg .pred %r278; .reg .u16 %r280; .reg .pred %r281; .reg .u16 %r283; .reg .pred %r284; .reg .u16 %r285; .reg .u16 %r286; .reg .pred %r287; .reg .pred %r288; .reg .u64 %r290; .reg .u64 %r291; .reg .u16 %r292; .reg .u16 %r293; .reg .u16 %r294; mov.u64 %r140,%ar0; mov.u32 %r141,%ar1; mov.u32 %r142,%ar2; mov.u64 %r143,%ar3; mov.u32 %r144,%ar4; mov.u64 %r145,%ar5; .loc 1 1172 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r147,[%value_in]; } .loc 1 1182 0 cvt.s64.s32 %r148,%r147; sub.u64 %r80,%r143,%r148; .loc 1 1187 0 set.u32.gt.s32 %r150,%r147,144; neg.s32 %r151,%r150; set.u32.le.s64 %r153,%r80,32766; neg.s32 %r154,%r153; cvt.u16.u32 %r156,%r151; cvt.u16.u32 %r157,%r154; and.b16 %r155,%r156,%r157; cvt.u32.u16 %r158,%r155; cvt.u16.u8 %r159,%r158; setp.eq.u16 %r160,%r159,0; @ %r160 bra $L168; .loc 1 681 0 add.u64 %r132,%r140,2; add.u64 %r129,%r140,26; .loc 1 683 0 mov.u16 %r161,0; $L169: st.u16 [%r132],%r161; add.u64 %r132,%r132,2; .loc 1 682 0 setp.ne.u64 %r162,%r129,%r132; @ %r162 bra $L169; bra $L167; $L168: .loc 1 1193 0 setp.ge.s64 %r163,%r80,0; @ %r163 bra $L173; .loc 1 1195 0 setp.lt.s64 %r164,%r80,-144; @ %r164 bra $L172; cvt.u32.u64 %r166,%r80; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r166; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r167,[%value_in]; } .loc 1 1199 0 setp.ne.u32 %r168,%r167,0; .loc 1 1200 0 selp.u32 %r141,1,%r141,%r168; bra $L173; $L172: .loc 1 681 0 add.u64 %r84,%r140,2; add.u64 %r122,%r140,26; .loc 1 683 0 mov.u16 %r169,%r159; $L174: st.u16 [%r84],%r169; add.u64 %r84,%r84,2; .loc 1 682 0 setp.ne.u64 %r170,%r122,%r84; @ %r170 bra $L174; bra $L167; $L173: .loc 1 1209 0 setp.eq.u32 %r171,%r144,0; @ %r171 bra $L176; .loc 1 1212 0 ld.u32 %r52,[%r145+4]; ld.u32 %r172,[%r145]; setp.eq.u32 %r173,%r52,%r172; @ %r173 bra $L177; .loc 1 1214 0 add.u64 %r108,%r145,26; add.u64 %r85,%r145,52; .loc 1 672 0 mov.u16 %r174,0; $L178: st.u16 [%r108],%r174; add.u64 %r108,%r108,2; .loc 1 671 0 setp.ne.u64 %r175,%r85,%r108; @ %r175 bra $L178; .loc 1 1215 0 setp.eq.u32 %r176,%r52,56; @ %r176 bra $L180; setp.gt.s32 %r177,%r52,56; @ %r177 bra $L181; setp.eq.u32 %r178,%r52,24; @ %r178 bra $L182; setp.eq.u32 %r179,%r52,53; @ %r179 bra $L183; bra $L179; $L181: setp.eq.u32 %r180,%r52,64; @ %r180 bra $L184; setp.eq.u32 %r181,%r52,113; @ %r181 bra $L185; $L179: .loc 1 1219 0 mov.u32 %r182,12; st.u32 [%r145+8],%r182; .loc 1 1220 0 mov.u32 %r183,-2147418113; st.u32 [%r145+20],%r183; .loc 1 1221 0 mov.u16 %r184,1; st.u16 [%r145+24],%r184; .loc 1 1223 0 mov.u32 %r185,11; st.u32 [%r145+12],%r185; .loc 1 1224 0 mov.u32 %r139,1; mov.u32 %r138,%r185; bra $L186; $L185: .loc 1 1226 0 mov.u32 %r186,10; st.u32 [%r145+8],%r186; .loc 1 1227 0 mov.u32 %r187,1073774591; st.u32 [%r145+20],%r187; .loc 1 1228 0 mov.u16 %r188,-32768; st.u16 [%r145+24],%r188; .loc 1 1230 0 st.u32 [%r145+12],%r186; .loc 1 1231 0 mov.u32 %r139,32768; mov.u32 %r138,%r186; bra $L186; $L184: .loc 1 1233 0 mov.u32 %r190,7; st.u32 [%r145+8],%r190; .loc 1 1234 0 mov.u32 %r191,-2147418113; st.u32 [%r145+20],%r191; .loc 1 1235 0 mov.u16 %r192,1; st.u16 [%r145+24],%r192; .loc 1 1237 0 mov.u32 %r193,6; st.u32 [%r145+12],%r193; .loc 1 1238 0 mov.u32 %r139,1; mov.u32 %r138,%r193; bra $L186; $L180: .loc 1 1241 0 mov.u32 %r194,6; st.u32 [%r145+8],%r194; .loc 1 1242 0 mov.u32 %r195,8388863; st.u32 [%r145+20],%r195; .loc 1 1243 0 mov.u16 %r196,256; st.u16 [%r145+24],%r196; .loc 1 1245 0 st.u32 [%r145+12],%r194; .loc 1 1246 0 mov.u32 %r139,256; mov.u32 %r138,%r194; bra $L186; $L183: .loc 1 1248 0 mov.u32 %r198,6; st.u32 [%r145+8],%r198; .loc 1 1249 0 mov.u32 %r199,67110911; st.u32 [%r145+20],%r199; .loc 1 1250 0 mov.u16 %r200,2048; st.u16 [%r145+24],%r200; .loc 1 1252 0 st.u32 [%r145+12],%r198; .loc 1 1253 0 mov.u32 %r139,2048; mov.u32 %r138,%r198; bra $L186; $L182: .loc 1 1255 0 mov.u32 %r202,4; st.u32 [%r145+8],%r202; .loc 1 1256 0 mov.u32 %r203,8388863; st.u32 [%r145+20],%r203; .loc 1 1257 0 mov.u16 %r204,256; st.u16 [%r145+24],%r204; .loc 1 1259 0 st.u32 [%r145+12],%r202; .loc 1 1260 0 mov.u32 %r139,256; mov.u32 %r138,%r202; $L186: .loc 1 1262 0 cvt.s64.s32 %r206,%r138; add.u64 %r207,%r206,12; add.u64 %r208,%r207,%r207; add.u64 %r209,%r145,%r208; cvt.u16.u32 %r211,%r139; st.u16 [%r209+2],%r211; .loc 1 1263 0 st.u32 [%r145],%r52; $L177: .loc 1 1272 0 setp.gt.s64 %r212,%r80,0; @ %r212 bra $L187; setp.eq.u32 %r213,%r52,144; @ %r213 bra $L188; .loc 1 1277 0 ld.u16 %r215,[%r140+24]; and.b16 %r214,%r215,1; cvt.u32.u16 %r216,%r214; or.b32 %r141,%r141,%r216; .loc 1 1278 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call eshdn1,(%out_arg1); } ld.u32 %r52,[%r145+4]; $L187: .loc 1 1283 0 ld.u32 %r57,[%r145+8]; cvt.s64.s32 %r218,%r57; add.u64 %r219,%r218,%r218; add.u64 %r60,%r140,%r219; ld.u16 %r61,[%r60]; ld.u16 %r62,[%r145+20]; cvt.u16.u32 %r221,%r61; cvt.u16.u32 %r222,%r62; and.b16 %r220,%r221,%r222; cvt.u32.u16 %r83,%r220; .loc 1 1284 0 setp.gt.s32 %r223,%r52,143; @ %r223 bra $L189; .loc 1 1286 0 add.u32 %r89,%r57,1; .loc 1 1287 0 setp.gt.s32 %r224,%r89,12; @ %r224 bra $L189; add.u64 %r225,%r219,2; add.u64 %r121,%r140,%r225; mov.u32 %r227,11; sub.u32 %r226,%r227,%r57; cvt.u64.u32 %r228,%r226; cvt.s64.s32 %r229,%r89; add.u64 %r230,%r228,%r229; add.u64 %r231,%r230,%r230; add.u64 %r232,%r140,2; add.u64 %r109,%r231,%r232; .loc 1 1291 0 mov.u16 %r237,0; $L191: .loc 1 1289 0 ld.u16 %r233,[%r121]; setp.eq.u16 %r234,%r233,0; @ %r234 bra $L190; .loc 1 1290 0 cvt.u16.u32 %r236,%r83; or.b16 %r235,%r236,1; cvt.u32.u16 %r83,%r235; $L190: .loc 1 1291 0 st.u16 [%r121],%r237; add.u64 %r121,%r121,2; .loc 1 1287 0 setp.ne.u64 %r238,%r109,%r121; @ %r238 bra $L191; ld.u16 %r61,[%r60]; ld.u16 %r62,[%r145+20]; $L189: .loc 1 1295 0 cvt.u16.u32 %r240,%r62; not.b16 %r239,%r240; cvt.u16.u32 %r242,%r61; and.b16 %r241,%r239,%r242; st.u16 [%r60],%r241; .loc 1 1296 0 ld.u16 %r244,[%r145+22]; cvt.u16.u32 %r245,%r83; and.b16 %r243,%r244,%r245; setp.eq.u16 %r246,%r243,0; @ %r246 bra $L192; .loc 1 1298 0 setp.ne.u16 %r249,%r244,%r245; @ %r249 bra $L193; .loc 1 1300 0 setp.ne.u32 %r250,%r141,0; @ %r250 bra $L194; .loc 1 1302 0 ld.s32 %r251,[%r145+12]; add.u64 %r252,%r251,%r251; add.u64 %r253,%r140,%r252; ld.u16 %r255,[%r253]; ld.u16 %r256,[%r145+24]; and.b16 %r254,%r255,%r256; setp.eq.u16 %r257,%r254,0; @ %r257 bra $L192; bra $L193; $L194: .loc 1 1307 0 setp.ne.u32 %r258,%r142,0; @ %r258 bra $L192; $L193: .loc 1 911 0 add.u64 %r105,%r145,50; .loc 1 912 0 add.u64 %r106,%r140,24; add.u64 %r123,%r140,2; .loc 1 913 0 mov.u32 %r88,0; $L195: .loc 1 916 0 ld.u16 %r259,[%r105]; ld.u16 %r260,[%r106]; add.u64 %r261,%r259,%r260; cvt.u64.u32 %r262,%r88; add.u64 %r102,%r261,%r262; .loc 1 921 0 st.u16 [%r106],%r102; .loc 1 922 0 add.u64 %r105,%r105,-2; .loc 1 923 0 add.u64 %r106,%r106,-2; .loc 1 917 0 shr.u64 %r263,%r102,16; cvt.u32.u64 %r265,%r263; and.b32 %r88,%r265,1; .loc 1 914 0 setp.ne.u64 %r266,%r106,%r123; @ %r266 bra $L195; $L192: .loc 1 1315 0 set.u32.ne.u32 %r268,%r52,144; neg.s32 %r269,%r268; set.u32.le.s64 %r271,%r80,0; neg.s32 %r272,%r271; cvt.u16.u32 %r274,%r269; cvt.u16.u32 %r275,%r272; and.b16 %r273,%r274,%r275; cvt.u32.u16 %r276,%r273; cvt.u16.u8 %r277,%r276; setp.eq.u16 %r278,%r277,0; @ %r278 bra $L196; .loc 1 1320 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call eshup1,(%out_arg1); } $L196: .loc 1 1322 0 ld.u16 %r280,[%r140+4]; setp.eq.u16 %r281,%r280,0; @ %r281 bra $L176; .loc 1 1324 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call eshdn1,(%out_arg1); } .loc 1 1325 0 add.u64 %r80,%r80,1; $L176: .loc 1 1328 0 mov.u16 %r283,0; st.u16 [%r140+24],%r283; .loc 1 1329 0 setp.le.s64 %r284,%r80,32766; @ %r284 bra $L197; .loc 1 1335 0 mov.u16 %r285,32767; st.u16 [%r140+2],%r285; add.u64 %r128,%r140,4; add.u64 %r124,%r140,24; .loc 1 1337 0 mov.u16 %r286,%r283; $L198: st.u16 [%r128],%r286; add.u64 %r128,%r128,2; .loc 1 1336 0 setp.ne.u64 %r287,%r124,%r128; @ %r287 bra $L198; bra $L167; $L197: .loc 1 1356 0 setp.ge.s64 %r288,%r80,0; @ %r288 bra $L199; .loc 1 1357 0 st.u16 [%r140+2],%r283; bra $L167; $L199: .loc 1 1359 0 st.u16 [%r140+2],%r80; bra $L167; $L188: .loc 1 1283 0 ld.s32 %r290,[%r145+8]; add.u64 %r291,%r290,%r290; add.u64 %r60,%r140,%r291; ld.u16 %r61,[%r60]; ld.u16 %r62,[%r145+20]; cvt.u16.u32 %r293,%r62; cvt.u16.u32 %r294,%r61; and.b16 %r292,%r293,%r294; cvt.u32.u16 %r83,%r292; bra $L189; $L167: .loc 1 1360 0 ret; } // BEGIN FUNCTION DEF: eiremain .func eiremain (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r35; .reg .u32 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r42; .reg .u64 %r43; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r59; .reg .u64 %r62; .reg .u64 %r63; .reg .u32 %r66; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r71; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u32 %r79; .reg .u64 %r80; .reg .u32 %r82; .reg .u64 %r83; .reg .u16 %r84; .reg .pred %r85; .reg .pred %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .pred %r89; .reg .pred %r90; .reg .pred %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u32 %r100; .reg .pred %r101; .reg .u16 %r103; .reg .u16 %r104; .reg .u16 %r105; .reg .pred %r107; .reg .u32 %r112; .reg .u64 %r114; .reg .u64 %r115; mov.u64 %r75,%ar0; mov.u64 %r76,%ar1; mov.u64 %r77,%ar2; .loc 1 3653 0 add.u64 %r39,%r77,52; .loc 1 3655 0 ld.u16 %r40,[%r75+2]; .loc 1 3656 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r75; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r79,[%value_in]; } cvt.s64.s32 %r80,%r79; sub.u64 %r42,%r40,%r80; .loc 1 3657 0 ld.u16 %r43,[%r76+2]; .loc 1 3658 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r82,[%value_in]; } cvt.s64.s32 %r83,%r82; sub.u64 %r46,%r43,%r83; mov.u64 %r69,%r39; add.u64 %r68,%r77,78; .loc 1 672 0 mov.u16 %r84,0; $L226: st.u16 [%r69],%r84; add.u64 %r69,%r69,2; .loc 1 671 0 setp.ne.u64 %r85,%r68,%r69; @ %r85 bra $L226; .loc 1 3660 0 setp.gt.s64 %r86,%r42,%r46; @ %r86 bra $L227; add.u64 %r74,%r75,4; add.u64 %r73,%r76,4; add.u64 %r71,%r42,-1; add.u64 %r114,%r75,26; add.u64 %r115,%r76,2; $L233: mov.u64 %r45,%r74; mov.u64 %r35,%r73; $L229: .loc 1 756 0 ld.u16 %r87,[%r45]; ld.u16 %r88,[%r35]; setp.ne.u16 %r89,%r87,%r88; @ %r89 bra $L228; add.u64 %r45,%r45,2; add.u64 %r35,%r35,2; .loc 1 754 0 setp.ne.u64 %r90,%r114,%r45; @ %r90 bra $L229; bra $L230; $L228: .loc 1 762 0 setp.gt.u16 %r93,%r87,%r88; @ %r93 bra $L234; $L230: .loc 1 938 0 add.u64 %r62,%r75,24; .loc 1 939 0 add.u64 %r63,%r76,24; .loc 1 940 0 mov.u32 %r66,0; $L232: .loc 1 943 0 ld.u16 %r94,[%r63]; ld.u16 %r95,[%r62]; sub.u64 %r96,%r94,%r95; cvt.u64.u32 %r97,%r66; sub.u64 %r59,%r96,%r97; .loc 1 948 0 st.u16 [%r63],%r59; .loc 1 949 0 add.u64 %r62,%r62,-2; .loc 1 950 0 add.u64 %r63,%r63,-2; .loc 1 944 0 shr.u64 %r98,%r59,16; cvt.u32.u64 %r100,%r98; and.b32 %r66,%r100,1; .loc 1 941 0 setp.ne.u64 %r101,%r115,%r63; @ %r101 bra $L232; .loc 1 3665 0 mov.u32 %r38,1; bra $L231; $L234: .loc 1 3669 0 mov.u32 %r38,0; $L231: .loc 1 3671 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; call eshup1,(%out_arg1); } .loc 1 3672 0 ld.u16 %r104,[%r77+76]; cvt.u16.u32 %r105,%r38; or.b16 %r103,%r104,%r105; st.u16 [%r77+76],%r103; .loc 1 3673 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; call eshup1,(%out_arg1); } .loc 1 3674 0 add.u64 %r46,%r46,-1; .loc 1 3660 0 setp.ne.u64 %r107,%r46,%r71; @ %r107 bra $L233; $L227: .loc 1 3676 0 mov.u32 %r112,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r112; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r112; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r46; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r112; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r77; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3677 0 ret; } // BEGIN FUNCTION DEF: emovo$isra$7 .func emovo$isra$7 (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r44; .reg .u64 %r45; .reg .u64 %r47; .reg .u64 %r50; .reg .u32 %r53; .reg .u64 %r55; .reg .u64 %r62; .reg .u64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u16 %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; .reg .u16 %r77; .reg .u16 %r78; .reg .pred %r79; .reg .u16 %r80; .reg .pred %r81; .reg .pred %r82; .reg .u16 %r83; .reg .pred %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .pred %r88; .reg .u16 %r89; .reg .u16 %r90; .reg .u16 %r91; .reg .pred %r92; mov.u64 %r71,%ar0; mov.u64 %r72,%ar1; add.u64 %r65,%r71,4; ld.u16 %r53,[%r71+2]; .loc 1 638 0 ld.u16 %r73,[%r71]; setp.eq.u16 %r74,%r73,0; @ %r74 bra $L240; .loc 1 639 0 cvt.u16.u32 %r76,%r53; or.b16 %r75,%r76,-32768; st.u16 [%r72+18],%r75; bra $L241; $L240: .loc 1 641 0 cvt.u16.u32 %r77,%r53; st.u16 [%r72+18],%r77; $L241: .loc 1 643 0 ld.u16 %r78,[%r71+2]; setp.ne.u16 %r79,%r78,32767; @ %r79 bra $L242; add.u64 %r62,%r71,6; add.u64 %r50,%r71,26; $L244: .loc 1 712 0 ld.u16 %r80,[%r62]; setp.ne.u16 %r81,%r80,0; @ %r81 bra $L243; add.u64 %r62,%r62,2; .loc 1 710 0 setp.ne.u64 %r82,%r50,%r62; @ %r82 bra $L244; mov.u64 %r45,%r72; add.u64 %r64,%r72,18; .loc 1 548 0 mov.u16 %r83,%r80; $L245: st.u16 [%r45],%r83; add.u64 %r45,%r45,2; .loc 1 547 0 setp.ne.u64 %r84,%r45,%r64; @ %r84 bra $L245; .loc 1 549 0 ld.u16 %r86,[%r72+18]; or.b16 %r85,%r86,32767; st.u16 [%r72+18],%r85; bra $L239; $L243: mov.u64 %r47,%r72; add.u64 %r44,%r72,16; .loc 1 3750 0 mov.u16 %r87,0; $L247: st.u16 [%r47],%r87; add.u64 %r47,%r47,2; .loc 1 3749 0 setp.ne.u64 %r88,%r44,%r47; @ %r88 bra $L247; .loc 1 3751 0 mov.u16 %r89,-16384; st.u16 [%r72+16],%r89; .loc 1 3757 0 mov.u16 %r90,32767; st.u16 [%r72+18],%r90; bra $L239; $L242: .loc 1 657 0 add.u64 %r55,%r71,6; add.u64 %r66,%r72,16; add.u64 %r70,%r65,20; $L248: .loc 1 660 0 ld.u16 %r91,[%r55]; st.u16 [%r66],%r91; add.u64 %r55,%r55,2; add.u64 %r66,%r66,-2; .loc 1 659 0 setp.ne.u64 %r92,%r55,%r70; @ %r92 bra $L248; $L239: .loc 1 661 0 ret; } // BEGIN FUNCTION DEF: e53toe$isra$9 .func e53toe$isra$9 (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[32]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r39; .reg .u32 %r44; .reg .u64 %r49; .reg .u64 %r51; .reg .u32 %r56; .reg .u64 %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u64 %r67; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u64 %r75; .reg .u64 %r76; .reg .u16 %r77; .reg .pred %r78; .reg .u16 %r79; .reg .pred %r81; .reg .u16 %r83; .reg .u16 %r84; .reg .u16 %r86; .reg .u16 %r88; .reg .u16 %r89; .reg .pred %r91; .reg .u16 %r92; .reg .pred %r94; .reg .u16 %r95; .reg .pred %r96; .reg .u16 %r97; .reg .pred %r98; .reg .u16 %r99; .reg .pred %r100; .reg .u16 %r101; .reg .pred %r102; .reg .u16 %r103; .reg .u16 %r104; .reg .u16 %r105; .reg .pred %r106; .reg .u16 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .u16 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .u32 %r114; .reg .u16 %r115; .reg .pred %r116; .reg .u16 %r117; .reg .u16 %r119; .reg .u16 %r120; .reg .u16 %r121; .reg .u16 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r127; .reg .pred %r128; .reg .u16 %r129; .reg .pred %r130; .reg .u16 %r131; .reg .u16 %r132; .reg .u16 %r133; .reg .u16 %r134; .reg .u16 %r137; .reg .u16 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .u32 %r143; .reg .u32 %r144; mov.u64 %r75,%ar0; mov.u64 %r76,%ar1; mov.u64 %r62,%frame; add.u64 %r63,%frame,26; .loc 1 672 0 mov.u16 %r77,0; $L254: st.u16 [%r62],%r77; add.u64 %r62,%r62,2; .loc 1 671 0 setp.ne.u64 %r78,%r62,%r63; @ %r78 bra $L254; .loc 1 2006 0 ld.u16 %r39,[%r75+6]; .loc 1 2008 0 cvt.u16.u32 %r79,%r39; setp.lt.s16 %r81,%r79,0; @ %r81 bra $L255; .loc 1 2007 0 st.u16 [%frame],%r77; bra $L256; $L255: .loc 1 2009 0 mov.u16 %r83,-1; st.u16 [%frame],%r83; $L256: .loc 1 2010 0 and.b16 %r84,%r79,15; or.b16 %r86,%r84,16; st.u16 [%frame+4],%r86; .loc 1 2011 0 cvt.u16.u32 %r89,%r39; and.b16 %r88,%r89,32752; cvt.u32.u16 %r44,%r88; .loc 1 2013 0 setp.ne.u16 %r91,%r88,32752; @ %r91 bra $L257; .loc 1 2017 0 and.b16 %r92,%r89,15; setp.ne.u16 %r94,%r92,0; @ %r94 bra $L258; ld.u16 %r95,[%r75+4]; setp.ne.u16 %r96,%r95,0; @ %r96 bra $L258; .loc 1 2018 0 ld.u16 %r97,[%r75+2]; setp.ne.u16 %r98,%r97,0; @ %r98 bra $L258; ld.u16 %r99,[%r75]; setp.eq.u16 %r100,%r99,0; @ %r100 bra $L259; $L258: mov.u64 %r67,%r76; add.u64 %r51,%r76,16; .loc 1 3750 0 mov.u16 %r101,0; $L260: st.u16 [%r67],%r101; add.u64 %r67,%r67,2; .loc 1 3749 0 setp.ne.u64 %r102,%r51,%r67; @ %r102 bra $L260; .loc 1 3751 0 mov.u16 %r103,-16384; st.u16 [%r76+16],%r103; .loc 1 3757 0 mov.u16 %r104,32767; st.u16 [%r76+18],%r104; bra $L253; $L259: mov.u64 %r49,%r76; add.u64 %r72,%r76,20; .loc 1 2018 0 mov.u64 %r37,%r76; .loc 1 440 0 mov.u16 %r105,%r99; $L262: st.u16 [%r37],%r105; add.u64 %r37,%r37,2; .loc 1 439 0 setp.ne.u64 %r106,%r72,%r37; @ %r106 bra $L262; add.u64 %r38,%r76,18; .loc 1 548 0 mov.u16 %r107,0; $L263: st.u16 [%r49],%r107; add.u64 %r49,%r49,2; .loc 1 547 0 setp.ne.u64 %r108,%r38,%r49; @ %r108 bra $L263; .loc 1 549 0 ld.u16 %r110,[%r76+18]; or.b16 %r109,%r110,32767; st.u16 [%r76+18],%r109; .loc 1 2034 0 ld.u16 %r111,[%frame]; setp.eq.u16 %r112,%r111,0; @ %r112 bra $L253; .loc 1 2035 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; call eneg,(%out_arg1); } bra $L253; $L257: .loc 1 2039 0 shr.u32 %r114,%r44,4; cvt.u16.u32 %r115,%r114; cvt.u32.u16 %r56,%r115; ld.u16 %r70,[%r75+4]; ld.u16 %r71,[%r75+2]; ld.u16 %r64,[%r75]; .loc 1 2042 0 setp.ne.u32 %r116,%r56,0; @ %r116 bra $L264; .loc 1 2045 0 and.b16 %r117,%r86,-17; st.u16 [%frame+4],%r117; .loc 1 2048 0 mov.u16 %r119,15360; st.u16 [%frame+2],%r119; .loc 1 2051 0 cvt.u16.u32 %r120,%r70; st.u16 [%frame+6],%r120; .loc 1 2052 0 cvt.u16.u32 %r121,%r71; st.u16 [%frame+8],%r121; .loc 1 2053 0 cvt.u16.u32 %r122,%r64; st.u16 [%frame+10],%r122; mov.u32 %r124,-5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r124; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r125,[%value_in]; } .loc 1 2063 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r127,[%value_in]; } setp.le.s32 %r128,%r127,144; @ %r128 bra $L265; add.u64 %r69,%frame,2; .loc 1 683 0 cvt.u16.u32 %r129,%r56; $L266: st.u16 [%r69],%r129; add.u64 %r69,%r69,2; .loc 1 682 0 setp.ne.u64 %r130,%r62,%r69; @ %r130 bra $L266; bra $L267; $L265: .loc 1 2066 0 ld.u16 %r132,[%frame+2]; add.u16 %r131,%r132,1; cvt.u16.u32 %r134,%r127; sub.u16 %r133,%r131,%r134; st.u16 [%frame+2],%r133; $L267: .loc 1 2068 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r76; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L253; $L264: .loc 1 2047 0 add.u16 %r137,%r115,15360; .loc 1 2048 0 st.u16 [%frame+2],%r137; .loc 1 2051 0 cvt.u16.u32 %r139,%r70; st.u16 [%frame+6],%r139; .loc 1 2052 0 cvt.u16.u32 %r140,%r71; st.u16 [%frame+8],%r140; .loc 1 2053 0 cvt.u16.u32 %r141,%r64; st.u16 [%frame+10],%r141; mov.u32 %r143,-5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r143; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r144,[%value_in]; } bra $L267; $L253: .loc 1 2070 0 ret; } // BEGIN FUNCTION DEF: emul .func emul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[56]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r58; .reg .u32 %r64; .reg .u32 %r65; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r90; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r139; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r142; .reg .u64 %r143; .reg .u16 %r144; .reg .pred %r146; .reg .u32 %r148; .reg .pred %r149; .reg .u16 %r150; .reg .pred %r151; .reg .u16 %r152; .reg .pred %r154; .reg .u32 %r156; .reg .pred %r157; .reg .u16 %r158; .reg .pred %r159; .reg .u16 %r160; .reg .pred %r162; .reg .u32 %r164; .reg .pred %r165; .reg .u64 %r167; .reg .u32 %r168; .reg .pred %r169; .reg .u32 %r171; .reg .pred %r172; .reg .u64 %r174; .reg .u32 %r175; .reg .pred %r176; .reg .u16 %r177; .reg .pred %r178; .reg .u16 %r179; .reg .u16 %r180; .reg .u16 %r181; .reg .u16 %r182; .reg .pred %r183; .reg .u16 %r184; .reg .pred %r186; .reg .u32 %r188; .reg .pred %r189; .reg .u32 %r191; .reg .u32 %r193; .reg .pred %r194; .reg .u32 %r196; .reg .pred %r197; .reg .u16 %r198; .reg .u16 %r199; .reg .u16 %r200; .reg .pred %r201; .reg .u16 %r202; .reg .u16 %r203; .reg .pred %r209; .reg .u16 %r210; .reg .pred %r211; .reg .u32 %r214; .reg .u64 %r215; .reg .pred %r218; .reg .u16 %r219; .reg .pred %r220; .reg .u16 %r221; .reg .u16 %r222; .reg .pred %r223; .reg .u16 %r224; .reg .pred %r225; .reg .u32 %r227; .reg .u64 %r228; .reg .pred %r229; .reg .u16 %r230; .reg .pred %r231; .reg .u32 %r236; .reg .u32 %r239; .reg .u32 %r241; .reg .u64 %r243; .reg .u64 %r244; .reg .u16 %r245; .reg .u16 %r246; .reg .pred %r247; .reg .u16 %r248; .reg .u16 %r249; .reg .u16 %r252; .reg .pred %r254; .reg .u16 %r255; .reg .pred %r257; .reg .u16 %r258; .reg .u16 %r259; .reg .pred %r260; .reg .u32 %r262; .reg .pred %r263; .reg .u32 %r268; .reg .pred %r269; .reg .u32 %r271; .reg .pred %r272; .reg .u32 %r274; .reg .pred %r275; .reg .u64 %r276; .reg .u16 %r277; .reg .u16 %r278; mov.u64 %r140,%ar0; mov.u64 %r141,%ar1; mov.u64 %r142,%ar2; mov.u64 %r143,%ar3; .loc 1 521 0 ld.u16 %r277,[%r140+18]; and.b16 %r144,%r277,32767; setp.ne.u16 %r146,%r144,32767; @ %r146 bra $L278; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r148,[%value_in]; } .loc 1 1622 0 setp.eq.u32 %r149,%r148,0; @ %r149 bra $L279; mov.u64 %r135,%r142; mov.u64 %r136,%r140; add.u64 %r139,%r135,20; $L280: .loc 1 455 0 ld.u16 %r150,[%r136]; st.u16 [%r135],%r150; add.u64 %r135,%r135,2; add.u64 %r136,%r136,2; .loc 1 454 0 setp.ne.u64 %r151,%r135,%r139; @ %r151 bra $L280; bra $L277; $L279: .loc 1 521 0 ld.u16 %r278,[%r141+18]; and.b16 %r152,%r278,32767; setp.ne.u16 %r154,%r152,32767; @ %r154 bra $L282; bra $L350; $L354: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r156,[%value_in]; } .loc 1 1627 0 setp.eq.u32 %r157,%r156,0; @ %r157 bra $L286; $L320: mov.u64 %r114,%r141; mov.u64 %r75,%r142; add.u64 %r131,%r114,20; $L285: .loc 1 455 0 ld.u16 %r158,[%r114]; st.u16 [%r75],%r158; add.u64 %r114,%r114,2; add.u64 %r75,%r75,2; .loc 1 454 0 setp.ne.u64 %r159,%r114,%r131; @ %r159 bra $L285; bra $L277; $L288: .loc 1 501 0 and.b16 %r160,%r278,32767; setp.eq.u16 %r162,%r160,32767; @ %r162 bra $L286; ld.u16 %r277,[%r140+18]; bra $L287; $L355: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r164,[%value_in]; } .loc 1 1633 0 setp.eq.u32 %r165,%r164,0; @ %r165 bra $L288; $L322: cvta.const.u64 %r167,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r167; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r168,[%value_in]; } setp.ne.u32 %r169,%r168,0; @ ! %r169 bra $L291; ld.u16 %r278,[%r141+18]; bra $L288; $L291: mov.u64 %r132,%r142; add.u64 %r134,%r142,16; .loc 1 3750 0 mov.u16 %r177,0; bra $L289; $L286: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r171,[%value_in]; } .loc 1 1634 0 setp.eq.u32 %r172,%r171,0; @ %r172 bra $L290; cvta.const.u64 %r174,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r174; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r175,[%value_in]; } setp.eq.u32 %r176,%r175,0; @ %r176 bra $L291; bra $L351; $L289: .loc 1 3750 0 st.u16 [%r132],%r177; add.u64 %r132,%r132,2; .loc 1 3749 0 setp.ne.u64 %r178,%r132,%r134; @ %r178 bra $L289; .loc 1 3751 0 mov.u16 %r179,-16384; st.u16 [%r142+16],%r179; .loc 1 3757 0 mov.u16 %r180,32767; st.u16 [%r142+18],%r180; bra $L277; $L351: .loc 1 501 0 ld.u16 %r182,[%r140+18]; and.b16 %r181,%r182,32767; setp.eq.u16 %r183,%r181,32767; @ %r183 bra $L294; ld.u16 %r278,[%r141+18]; $L297: and.b16 %r184,%r278,32767; setp.eq.u16 %r186,%r184,32767; @ ! %r186 bra $L296; bra $L295; $L294: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r188,[%value_in]; } .loc 1 1643 0 setp.eq.u32 %r189,%r188,0; @ ! %r189 bra $L300; ld.u16 %r278,[%r141+18]; bra $L297; $L300: .loc 1 1645 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r191,[%value_in]; } { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r193,[%value_in]; } setp.ne.u32 %r194,%r191,%r193; @ %r194 bra $L298; bra $L352; $L295: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r196,[%value_in]; } .loc 1 1643 0 setp.ne.u32 %r197,%r196,0; @ %r197 bra $L300; bra $L296; $L298: .loc 1 1646 0 mov.u16 %r198,-32768; st.u16 [%r142+18],%r198; bra $L301; $L352: .loc 1 1648 0 mov.u16 %r199,0; st.u16 [%r142+18],%r199; $L301: mov.u64 %r90,%r142; add.u64 %r96,%r142,18; .loc 1 548 0 mov.u16 %r200,0; $L302: st.u16 [%r90],%r200; add.u64 %r90,%r90,2; .loc 1 547 0 setp.ne.u64 %r201,%r90,%r96; @ %r201 bra $L302; .loc 1 549 0 ld.u16 %r203,[%r142+18]; or.b16 %r202,%r203,32767; st.u16 [%r142+18],%r202; bra $L277; $L296: .loc 1 1653 0 add.u64 %r276,%frame,26; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r276; call emovi,(%out_arg1,%out_arg2); } .loc 1 1654 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call emovi,(%out_arg1,%out_arg2); } .loc 1 1655 0 ld.u16 %r64,[%frame+28]; .loc 1 1656 0 ld.u16 %r65,[%frame+2]; .loc 1 1657 0 setp.eq.u32 %r209,%r64,0; @ %r209 bra $L303; .loc 1 1670 0 bra $L353; $L307: add.u64 %r113,%r113,2; .loc 1 1661 0 ld.u16 %r210,[%r113+-2]; setp.eq.u16 %r211,%r210,0; @ %r211 bra $L305; .loc 1 1663 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r276; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r214,[%value_in]; } cvt.s64.s32 %r215,%r214; neg.s64 %r73,%r215; ld.u16 %r58,[%frame+2]; .loc 1 1664 0 bra $L306; $L303: add.u64 %r113,%frame,30; add.u64 %r110,%frame,50; $L305: .loc 1 1659 0 setp.ne.u64 %r218,%r110,%r113; @ %r218 bra $L307; mov.u64 %r111,%r142; add.u64 %r117,%r111,20; .loc 1 440 0 mov.u16 %r219,0; $L308: st.u16 [%r111],%r219; add.u64 %r111,%r111,2; .loc 1 439 0 setp.ne.u64 %r220,%r117,%r111; @ %r220 bra $L308; bra $L277; $L353: .loc 1 1655 0 cvt.u16.u32 %r221,%r64; cvt.u64.u16 %r73,%r221; mov.u32 %r58,%r65; $L306: .loc 1 1656 0 cvt.u16.u32 %r222,%r65; cvt.u64.u16 %r74,%r222; .loc 1 1672 0 setp.eq.u32 %r223,%r58,0; @ %r223 bra $L309; .loc 1 1685 0 bra $L310; $L312: add.u64 %r107,%r107,2; .loc 1 1676 0 ld.u16 %r224,[%r107+-2]; setp.eq.u16 %r225,%r224,0; @ %r225 bra $L311; .loc 1 1678 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r227,[%value_in]; } cvt.s64.s32 %r228,%r227; sub.u64 %r74,%r74,%r228; .loc 1 1679 0 bra $L310; $L309: add.u64 %r107,%frame,4; add.u64 %r118,%frame,24; $L311: .loc 1 1674 0 setp.ne.u64 %r229,%r107,%r118; @ %r229 bra $L312; mov.u64 %r97,%r142; add.u64 %r108,%r97,20; .loc 1 440 0 mov.u16 %r230,0; $L313: st.u16 [%r97],%r230; add.u64 %r97,%r97,2; .loc 1 439 0 setp.ne.u64 %r231,%r97,%r108; @ %r231 bra $L313; bra $L277; $L310: .loc 1 1688 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r276; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r143; call (%value_in),emulm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r236,[%value_in]; } .loc 1 1690 0 add.u64 %r243,%r73,%r74; add.u64 %r244,%r243,-16382; .loc 1 1691 0 mov.u32 %r241,64; mov.u32 %r239,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r236; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r239; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r244; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r241; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r143; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 1693 0 ld.u16 %r245,[%frame+26]; ld.u16 %r246,[%frame]; setp.ne.u16 %r247,%r245,%r246; @ %r247 bra $L314; .loc 1 1694 0 cvt.u16.u32 %r248,%r239; st.u16 [%frame],%r248; bra $L315; $L314: .loc 1 1696 0 mov.u16 %r249,-1; st.u16 [%frame],%r249; $L315: .loc 1 1697 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r142; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L277; $L278: .loc 1 521 0 ld.u16 %r278,[%r141+18]; and.b16 %r252,%r278,32767; setp.ne.u16 %r254,%r252,32767; @ %r254 bra $L297; bra $L354; $L287: .loc 1 501 0 and.b16 %r255,%r277,32767; setp.eq.u16 %r257,%r255,32767; @ ! %r257 bra $L296; bra $L318; $L290: ld.u16 %r259,[%r140+18]; and.b16 %r258,%r259,32767; setp.eq.u16 %r260,%r258,32767; @ ! %r260 bra $L296; bra $L319; $L350: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r262,[%value_in]; } .loc 1 1627 0 setp.ne.u32 %r263,%r262,0; @ %r263 bra $L320; bra $L355; $L282: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r268,[%value_in]; } .loc 1 1633 0 setp.ne.u32 %r269,%r268,0; @ %r269 bra $L322; bra $L287; $L319: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r271,[%value_in]; } .loc 1 1643 0 setp.ne.u32 %r272,%r271,0; @ ! %r272 bra $L295; bra $L300; $L318: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r274,[%value_in]; } setp.ne.u32 %r275,%r274,0; @ %r275 bra $L300; bra $L296; $L277: .loc 1 1698 0 ret; } // BEGIN FUNCTION DEF: ediv .func ediv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[56]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r74; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r93; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r134; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .pred %r142; .reg .u32 %r144; .reg .pred %r145; .reg .u16 %r146; .reg .pred %r147; .reg .u16 %r148; .reg .u16 %r149; .reg .pred %r150; .reg .u32 %r152; .reg .pred %r153; .reg .u16 %r154; .reg .pred %r155; .reg .u64 %r157; .reg .u32 %r158; .reg .pred %r159; .reg .u16 %r160; .reg .u16 %r161; .reg .u16 %r162; .reg .u16 %r163; .reg .pred %r164; .reg .u32 %r167; .reg .pred %r168; .reg .u32 %r170; .reg .pred %r171; .reg .pred %r173; .reg .u32 %r175; .reg .pred %r176; .reg .u16 %r177; .reg .pred %r178; .reg .u16 %r179; .reg .u16 %r180; .reg .pred %r182; .reg .u32 %r184; .reg .pred %r185; .reg .u32 %r187; .reg .u32 %r189; .reg .pred %r190; .reg .u16 %r191; .reg .u16 %r192; .reg .u16 %r193; .reg .pred %r194; .reg .u16 %r195; .reg .u16 %r196; .reg .u16 %r197; .reg .pred %r198; .reg .pred %r204; .reg .u16 %r205; .reg .pred %r206; .reg .u32 %r208; .reg .u64 %r209; .reg .pred %r210; .reg .u16 %r211; .reg .pred %r212; .reg .u16 %r213; .reg .u16 %r214; .reg .pred %r215; .reg .u16 %r216; .reg .pred %r217; .reg .u32 %r220; .reg .u64 %r221; .reg .pred %r224; .reg .u16 %r225; .reg .u16 %r226; .reg .pred %r227; .reg .u16 %r228; .reg .u16 %r229; .reg .u16 %r230; .reg .pred %r231; .reg .u16 %r232; .reg .u16 %r233; .reg .u32 %r238; .reg .u32 %r241; .reg .u32 %r243; .reg .u64 %r245; .reg .u64 %r246; .reg .u16 %r247; .reg .u16 %r248; .reg .pred %r249; .reg .u16 %r250; .reg .u16 %r251; .reg .pred %r255; .reg .u32 %r257; .reg .pred %r258; .reg .u64 %r259; mov.u64 %r136,%ar0; mov.u64 %r137,%ar1; mov.u64 %r138,%ar2; mov.u64 %r139,%ar3; .loc 1 521 0 ld.u16 %r141,[%r136+18]; and.b16 %r140,%r141,32767; setp.ne.u16 %r142,%r140,32767; @ %r142 bra $L357; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r144,[%value_in]; } .loc 1 1518 0 setp.eq.u32 %r145,%r144,0; @ %r145 bra $L357; mov.u64 %r118,%r138; mov.u64 %r117,%r136; add.u64 %r98,%r118,20; $L358: .loc 1 455 0 ld.u16 %r146,[%r117]; st.u16 [%r118],%r146; add.u64 %r118,%r118,2; add.u64 %r117,%r117,2; .loc 1 454 0 setp.ne.u64 %r147,%r98,%r118; @ %r147 bra $L358; bra $L356; $L357: .loc 1 521 0 ld.u16 %r149,[%r137+18]; and.b16 %r148,%r149,32767; setp.ne.u16 %r150,%r148,32767; @ %r150 bra $L360; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r152,[%value_in]; } .loc 1 1523 0 setp.eq.u32 %r153,%r152,0; @ %r153 bra $L360; mov.u64 %r114,%r137; mov.u64 %r123,%r138; add.u64 %r124,%r114,20; $L361: .loc 1 455 0 ld.u16 %r154,[%r114]; st.u16 [%r123],%r154; add.u64 %r114,%r114,2; add.u64 %r123,%r123,2; .loc 1 454 0 setp.ne.u64 %r155,%r114,%r124; @ %r155 bra $L361; bra $L356; $L360: .loc 1 1529 0 cvta.const.u64 %r157,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r157; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r158,[%value_in]; } setp.eq.u32 %r159,%r158,0; @ %r159 bra $L362; $L365: ld.u16 %r161,[%r137+18]; and.b16 %r160,%r161,32767; .loc 1 501 0 ld.u16 %r163,[%r136+18]; and.b16 %r162,%r163,32767; setp.eq.u16 %r164,%r162,32767; @ ! %r164 bra $L413; bra $L363; $L362: .loc 1 1529 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r157; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r167,[%value_in]; } setp.ne.u32 %r168,%r167,0; @ %r168 bra $L365; $L369: mov.u64 %r125,%r138; add.u64 %r99,%r138,16; .loc 1 3750 0 mov.u16 %r177,0; bra $L366; $L363: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r170,[%value_in]; } .loc 1 1530 0 setp.eq.u32 %r171,%r170,0; @ %r171 bra $L367; .loc 1 501 0 setp.ne.u16 %r173,%r160,32767; @ %r173 bra $L368; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r175,[%value_in]; } .loc 1 1530 0 setp.ne.u32 %r176,%r175,0; @ %r176 bra $L369; bra $L368; $L366: .loc 1 3750 0 st.u16 [%r125],%r177; add.u64 %r125,%r125,2; .loc 1 3749 0 setp.ne.u64 %r178,%r99,%r125; @ %r178 bra $L366; .loc 1 3751 0 mov.u16 %r179,-16384; st.u16 [%r138+16],%r179; .loc 1 3757 0 mov.u16 %r180,32767; st.u16 [%r138+18],%r180; bra $L356; $L367: .loc 1 501 0 setp.ne.u16 %r182,%r160,32767; @ %r182 bra $L371; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r184,[%value_in]; } .loc 1 1539 0 setp.eq.u32 %r185,%r184,0; @ %r185 bra $L371; $L392: .loc 1 1541 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r187,[%value_in]; } { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r189,[%value_in]; } setp.eq.u32 %r190,%r187,%r189; @ %r190 bra $L372; .loc 1 1542 0 mov.u16 %r191,-32768; st.u16 [%r138+18],%r191; bra $L373; $L372: .loc 1 1544 0 mov.u16 %r192,0; st.u16 [%r138+18],%r192; $L373: mov.u64 %r103,%r138; add.u64 %r104,%r138,18; .loc 1 548 0 mov.u16 %r193,0; $L374: st.u16 [%r103],%r193; add.u64 %r103,%r103,2; .loc 1 547 0 setp.ne.u64 %r194,%r104,%r103; @ %r194 bra $L374; .loc 1 549 0 ld.u16 %r196,[%r138+18]; or.b16 %r195,%r196,32767; st.u16 [%r138+18],%r195; bra $L356; $L368: mov.u64 %r128,%r138; add.u64 %r126,%r128,20; .loc 1 440 0 mov.u16 %r197,0; $L375: st.u16 [%r128],%r197; add.u64 %r128,%r128,2; .loc 1 439 0 setp.ne.u64 %r198,%r126,%r128; @ %r198 bra $L375; bra $L356; $L371: .loc 1 1554 0 add.u64 %r259,%frame,26; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r259; call emovi,(%out_arg1,%out_arg2); } .loc 1 1555 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call emovi,(%out_arg1,%out_arg2); } .loc 1 1556 0 ld.u16 %r66,[%frame+28]; .loc 1 1557 0 ld.u16 %r67,[%frame+2]; .loc 1 1558 0 setp.eq.u32 %r204,%r67,0; @ %r204 bra $L376; .loc 1 1571 0 bra $L414; $L380: add.u64 %r110,%r110,2; .loc 1 1562 0 ld.u16 %r205,[%r110+-2]; setp.eq.u16 %r206,%r205,0; @ %r206 bra $L378; .loc 1 1564 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r208,[%value_in]; } cvt.s64.s32 %r209,%r208; neg.s64 %r79,%r209; ld.u16 %r74,[%frame+28]; .loc 1 1565 0 bra $L379; $L376: add.u64 %r110,%frame,4; add.u64 %r115,%frame,24; $L378: .loc 1 1560 0 setp.ne.u64 %r210,%r110,%r115; @ %r210 bra $L380; mov.u64 %r113,%r138; add.u64 %r111,%r113,20; .loc 1 440 0 mov.u16 %r211,0; $L381: st.u16 [%r113],%r211; add.u64 %r113,%r113,2; .loc 1 439 0 setp.ne.u64 %r212,%r111,%r113; @ %r212 bra $L381; bra $L356; $L414: .loc 1 1557 0 cvt.u16.u32 %r213,%r67; cvt.u64.u16 %r79,%r213; mov.u32 %r74,%r66; $L379: .loc 1 1556 0 cvt.u16.u32 %r214,%r66; cvt.u64.u16 %r78,%r214; .loc 1 1573 0 setp.eq.u32 %r215,%r74,0; @ %r215 bra $L382; .loc 1 1591 0 bra $L383; $L385: add.u64 %r134,%r134,2; .loc 1 1577 0 ld.u16 %r216,[%r134+-2]; setp.eq.u16 %r217,%r216,0; @ %r217 bra $L384; .loc 1 1579 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r259; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r220,[%value_in]; } cvt.s64.s32 %r221,%r220; sub.u64 %r78,%r78,%r221; .loc 1 1580 0 bra $L383; $L382: add.u64 %r134,%frame,30; add.u64 %r129,%frame,50; $L384: .loc 1 1575 0 setp.ne.u64 %r224,%r129,%r134; @ %r224 bra $L385; .loc 1 1583 0 ld.u16 %r225,[%frame+26]; ld.u16 %r226,[%frame]; setp.ne.u16 %r227,%r225,%r226; @ %r227 bra $L386; .loc 1 1584 0 mov.u16 %r228,0; st.u16 [%r138+18],%r228; bra $L387; $L386: .loc 1 1586 0 mov.u16 %r229,-32768; st.u16 [%r138+18],%r229; $L387: mov.u64 %r93,%r138; add.u64 %r80,%r138,18; .loc 1 548 0 mov.u16 %r230,0; $L388: st.u16 [%r93],%r230; add.u64 %r93,%r93,2; .loc 1 547 0 setp.ne.u64 %r231,%r80,%r93; @ %r231 bra $L388; .loc 1 549 0 ld.u16 %r233,[%r138+18]; or.b16 %r232,%r233,32767; st.u16 [%r138+18],%r232; bra $L356; $L383: .loc 1 1593 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r259; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r139; call (%value_in),edivm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r238,[%value_in]; } .loc 1 1595 0 sub.u64 %r245,%r79,%r78; add.u64 %r246,%r245,16383; .loc 1 1596 0 mov.u32 %r243,64; mov.u32 %r241,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r238; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r241; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r246; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r243; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r139; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 1598 0 ld.u16 %r247,[%frame+26]; ld.u16 %r248,[%frame]; setp.ne.u16 %r249,%r247,%r248; @ %r249 bra $L389; .loc 1 1599 0 cvt.u16.u32 %r250,%r241; st.u16 [%frame],%r250; bra $L390; $L389: .loc 1 1601 0 mov.u16 %r251,-1; st.u16 [%frame],%r251; $L390: .loc 1 1602 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r138; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L356; $L413: .loc 1 501 0 setp.ne.u16 %r255,%r160,32767; @ %r255 bra $L371; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r257,[%value_in]; } .loc 1 1539 0 setp.ne.u32 %r258,%r257,0; @ %r258 bra $L392; bra $L371; $L356: .loc 1 1603 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _ldtoa_r .visible .func (.param .u64 %value_out) _ldtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u64 %ar6; ld.param.u64 %ar6,[%in_ar6]; .local .align 8 .b8 %stack_ar[8]; .reg .u64 %stack; cvta.local.u64 %stack,%stack_ar; .local .align 8 .b8 %frame_ar[352]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r271; .reg .u32 %r272; .reg .u64 %r273; .reg .u32 %r275; .reg .u32 %r278; .reg .u32 %r279; .reg .u64 %r293; .reg .u32 %r294; .reg .u32 %r304; .reg .u32 %r305; .reg .u64 %r306; .reg .u32 %r308; .reg .u64 %r310; .reg .u32 %r313; .reg .u64 %r316; .reg .u64 %r317; .reg .u32 %r319; .reg .u64 %r320; .reg .u32 %r323; .reg .u64 %r327; .reg .u32 %r329; .reg .u64 %r331; .reg .u64 %r332; .reg .u32 %r335; .reg .u64 %r341; .reg .u64 %r344; .reg .u64 %r347; .reg .u32 %r348; .reg .u64 %r355; .reg .u64 %r356; .reg .u64 %r357; .reg .u32 %r359; .reg .u64 %r370; .reg .u64 %r376; .reg .u64 %r378; .reg .u64 %r381; .reg .u64 %r382; .reg .u64 %r390; .reg .u64 %r395; .reg .u64 %r397; .reg .u64 %r398; .reg .u32 %r401; .reg .u32 %r402; .reg .u64 %r406; .reg .u64 %r409; .reg .u32 %r411; .reg .u32 %r416; .reg .u64 %r417; .reg .u64 %r421; .reg .u32 %r422; .reg .u32 %r427; .reg .u64 %r428; .reg .u64 %r429; .reg .u32 %r430; .reg .u32 %r435; .reg .u64 %r436; .reg .u64 %r445; .reg .u64 %r448; .reg .u64 %r449; .reg .u64 %r450; .reg .u64 %r452; .reg .u64 %r455; .reg .u32 %r462; .reg .u32 %r467; .reg .u64 %r468; .reg .u32 %r473; .reg .u64 %r475; .reg .u32 %r479; .reg .u64 %r480; .reg .u32 %r482; .reg .u32 %r484; .reg .u32 %r488; .reg .u64 %r489; .reg .u64 %r490; .reg .u64 %r497; .reg .u64 %r500; .reg .u64 %r501; .reg .u32 %r502; .reg .u64 %r506; .reg .u32 %r507; .reg .u64 %r508; .reg .u64 %r510; .reg .u32 %r512; .reg .u32 %r520; .reg .u64 %r522; .reg .u32 %r524; .reg .u32 %r525; .reg .u32 %r527; .reg .u32 %r529; .reg .u64 %r531; .reg .u64 %r533; .reg .u32 %r535; .reg .u32 %r538; .reg .u32 %r539; .reg .u64 %r540; .reg .u64 %r549; .reg .u64 %r550; .reg .u64 %r552; .reg .u64 %r558; .reg .u64 %r559; .reg .u64 %r560; .reg .u64 %r564; .reg .u64 %r565; .reg .u64 %r568; .reg .u64 %r573; .reg .u64 %r574; .reg .u64 %r578; .reg .u64 %r579; .reg .u64 %r581; .reg .u64 %r588; .reg .u64 %r589; .reg .u32 %r591; .reg .u64 %r592; .reg .u32 %r596; .reg .u32 %r602; .reg .u64 %r603; .reg .u64 %r604; .reg .u64 %r609; .reg .u64 %r610; .reg .u64 %r615; .reg .u32 %r620; .reg .u64 %r625; .reg .u64 %r628; .reg .u64 %r629; .reg .u64 %r637; .reg .u64 %r640; .reg .u64 %r641; .reg .u32 %r642; .reg .u32 %r643; .reg .u64 %r644; .reg .u64 %r645; .reg .u32 %r646; .reg .u64 %r647; .reg .u32 %r648; .reg .u64 %r653; .reg .u64 %r654; .reg .u64 %r656; .reg .u32 %r658; .reg .u64 %r661; .reg .u64 %r662; .reg .u32 %r663; .reg .u32 %r664; .reg .u64 %r668; .reg .u64 %r671; .reg .u64 %r672; .reg .u64 %r674; .reg .u32 %r676; .reg .u64 %r679; .reg .u64 %r681; .reg .u64 %r682; .reg .u64 %r683; .reg .u32 %r685; .reg .u64 %r687; .reg .u32 %r688; .reg .u64 %r689; .reg .u32 %r693; .reg .u64 %r694; .reg .u64 %r695; .reg .u64 %r698; .reg .u64 %r699; .reg .u64 %r701; .reg .u32 %r704; .reg .u64 %r705; .reg .u64 %r706; .reg .u32 %r713; .reg .u64 %r719; .reg .u32 %r722; .reg .u32 %r723; .reg .u64 %r727; .reg .u32 %r732; .reg .u32 %r734; .reg .u64 %r740; .reg .f64 %r741; .reg .u32 %r742; .reg .u32 %r743; .reg .u64 %r744; .reg .u64 %r745; .reg .u64 %r746; .reg .u32 %r771; .reg .u32 %r772; .reg .pred %r773; .reg .u32 %r774; .reg .u32 %r775; .reg .u64 %r778; .reg .u64 %r782; .reg .u32 %r785; .reg .pred %r786; .reg .u32 %r787; .reg .pred %r789; .reg .pred %r790; .reg .u16 %r791; .reg .u16 %r792; .reg .pred %r793; .reg .u32 %r796; .reg .pred %r797; .reg .u64 %r799; .reg .u32 %r801; .reg .u32 %r803; .reg .u16 %r804; .reg .pred %r805; .reg .u16 %r806; .reg .pred %r807; .reg .u16 %r808; .reg .u16 %r811; .reg .pred %r812; .reg .pred %r813; .reg .u16 %r814; .reg .pred %r815; .reg .pred %r816; .reg .pred %r817; .reg .u64 %r819; .reg .u32 %r821; .reg .u64 %r824; .reg .u32 %r826; .reg .u16 %r828; .reg .pred %r829; .reg .u64 %r831; .reg .u32 %r833; .reg .u32 %r838; .reg .pred %r839; .reg .pred %r840; .reg .u16 %r841; .reg .pred %r842; .reg .u16 %r843; .reg .u16 %r850; .reg .pred %r851; .reg .u16 %r852; .reg .u16 %r853; .reg .u32 %r854; .reg .pred %r855; .reg .u16 %r856; .reg .u32 %r866; .reg .u16 %r867; .reg .pred %r868; .reg .pred %r869; .reg .pred %r870; .reg .u32 %r871; .reg .u64 %r872; .reg .u16 %r874; .reg .pred %r875; .reg .u64 %r877; .reg .u64 %r878; .reg .u32 %r879; .reg .u32 %r881; .reg .u64 %r883; .reg .u64 %r884; .reg .u64 %r885; .reg .u64 %r886; .reg .u16 %r887; .reg .u16 %r888; .reg .u16 %r889; .reg .u16 %r890; .reg .pred %r891; .reg .u16 %r892; .reg .u16 %r893; .reg .pred %r894; .reg .u16 %r895; .reg .u16 %r896; .reg .pred %r897; .reg .u32 %r900; .reg .pred %r901; .reg .u32 %r904; .reg .pred %r905; .reg .u16 %r913; .reg .u16 %r914; .reg .u16 %r916; .reg .u64 %r917; .reg .pred %r918; .reg .u16 %r919; .reg .pred %r920; .reg .u16 %r921; .reg .u16 %r922; .reg .pred %r923; .reg .u16 %r924; .reg .u16 %r925; .reg .pred %r926; .reg .u16 %r927; .reg .pred %r928; .reg .pred %r929; .reg .u32 %r931; .reg .u32 %r933; .reg .u16 %r936; .reg .u16 %r937; .reg .pred %r938; .reg .pred %r939; .reg .pred %r942; .reg .u16 %r943; .reg .pred %r945; .reg .u16 %r946; .reg .pred %r956; .reg .u16 %r957; .reg .pred %r958; .reg .u16 %r959; .reg .pred %r960; .reg .u16 %r961; .reg .u16 %r962; .reg .u16 %r963; .reg .u16 %r964; .reg .u16 %r966; .reg .u16 %r967; .reg .pred %r968; .reg .u16 %r969; .reg .u16 %r971; .reg .u16 %r972; .reg .pred %r975; .reg .u16 %r978; .reg .pred %r979; .reg .pred %r980; .reg .u16 %r981; .reg .pred %r982; .reg .u16 %r983; .reg .u16 %r984; .reg .pred %r985; .reg .u16 %r986; .reg .u16 %r987; .reg .pred %r988; .reg .u16 %r989; .reg .u16 %r990; .reg .u16 %r991; .reg .pred %r992; .reg .u64 %r993; .reg .u64 %r994; .reg .u64 %r995; .reg .u64 %r996; .reg .u64 %r997; .reg .u32 %r999; .reg .pred %r1002; .reg .u64 %r1003; .reg .u64 %r1004; .reg .u64 %r1005; .reg .u64 %r1006; .reg .u64 %r1007; .reg .u32 %r1009; .reg .pred %r1012; .reg .u32 %r1017; .reg .pred %r1024; .reg .u16 %r1025; .reg .u16 %r1026; .reg .pred %r1027; .reg .pred %r1028; .reg .u16 %r1029; .reg .pred %r1030; .reg .u32 %r1031; .reg .u16 %r1032; .reg .pred %r1034; .reg .u16 %r1035; .reg .u16 %r1036; .reg .u16 %r1037; .reg .u16 %r1038; .reg .u16 %r1039; .reg .pred %r1040; .reg .u16 %r1041; .reg .pred %r1042; .reg .u32 %r1046; .reg .pred %r1047; .reg .u32 %r1060; .reg .u16 %r1061; .reg .pred %r1063; .reg .u32 %r1068; .reg .pred %r1069; .reg .u16 %r1070; .reg .pred %r1071; .reg .u16 %r1072; .reg .pred %r1073; .reg .u16 %r1081; .reg .pred %r1082; .reg .u16 %r1087; .reg .u16 %r1088; .reg .pred %r1089; .reg .u16 %r1090; .reg .pred %r1091; .reg .u16 %r1092; .reg .u64 %r1097; .reg .u64 %r1098; .reg .u64 %r1099; .reg .u64 %r1100; .reg .u64 %r1101; .reg .u32 %r1103; .reg .pred %r1106; .reg .u16 %r1109; .reg .pred %r1110; .reg .u16 %r1115; .reg .pred %r1116; .reg .u16 %r1117; .reg .pred %r1118; .reg .pred %r1120; .reg .u16 %r1121; .reg .pred %r1122; .reg .u16 %r1123; .reg .pred %r1124; .reg .u16 %r1129; .reg .pred %r1130; .reg .u16 %r1131; .reg .pred %r1132; .reg .u32 %r1136; .reg .pred %r1137; .reg .u32 %r1151; .reg .u32 %r1152; .reg .pred %r1154; .reg .u32 %r1160; .reg .pred %r1161; .reg .u16 %r1172; .reg .pred %r1173; .reg .u16 %r1174; .reg .u16 %r1179; .reg .pred %r1180; .reg .u16 %r1181; .reg .pred %r1187; .reg .u16 %r1188; .reg .pred %r1189; .reg .u16 %r1190; .reg .u16 %r1191; .reg .u16 %r1192; .reg .u16 %r1193; .reg .u16 %r1194; .reg .u16 %r1195; .reg .pred %r1196; .reg .u16 %r1198; .reg .u16 %r1200; .reg .u16 %r1201; .reg .pred %r1204; .reg .u16 %r1205; .reg .pred %r1206; .reg .u16 %r1207; .reg .u16 %r1208; .reg .pred %r1209; .reg .u16 %r1210; .reg .u16 %r1211; .reg .u16 %r1212; .reg .u16 %r1213; .reg .u16 %r1214; .reg .u16 %r1215; .reg .pred %r1216; .reg .u16 %r1218; .reg .u16 %r1220; .reg .u16 %r1221; .reg .pred %r1224; .reg .u16 %r1225; .reg .pred %r1226; .reg .u16 %r1227; .reg .u16 %r1228; .reg .u16 %r1229; .reg .u16 %r1230; .reg .u16 %r1231; .reg .u16 %r1232; .reg .pred %r1233; .reg .u16 %r1235; .reg .u16 %r1237; .reg .u16 %r1238; .reg .pred %r1241; .reg .u64 %r1242; .reg .u64 %r1243; .reg .u64 %r1244; .reg .u64 %r1245; .reg .u64 %r1246; .reg .u32 %r1248; .reg .pred %r1251; .reg .pred %r1257; .reg .u32 %r1261; .reg .pred %r1262; .reg .pred %r1263; .reg .u32 %r1264; .reg .u32 %r1265; .reg .pred %r1266; .reg .pred %r1267; .reg .pred %r1268; .reg .u32 %r1269; .reg .u32 %r1270; .reg .u32 %r1271; .reg .pred %r1272; .reg .u32 %r1273; .reg .u32 %r1274; .reg .pred %r1275; .reg .u32 %r1276; .reg .pred %r1277; .reg .u16 %r1279; .reg .u16 %r1280; .reg .u32 %r1281; .reg .u32 %r1282; .reg .u16 %r1284; .reg .u16 %r1285; .reg .u32 %r1286; .reg .u32 %r1287; .reg .pred %r1288; .reg .u16 %r1289; .reg .pred %r1290; .reg .u16 %r1291; .reg .u16 %r1292; .reg .u16 %r1293; .reg .u16 %r1294; .reg .u16 %r1295; .reg .u16 %r1296; .reg .pred %r1297; .reg .u16 %r1299; .reg .u16 %r1301; .reg .u16 %r1302; .reg .pred %r1305; .reg .u16 %r1306; .reg .pred %r1307; .reg .u16 %r1308; .reg .u16 %r1309; .reg .pred %r1310; .reg .u16 %r1311; .reg .u16 %r1312; .reg .u16 %r1313; .reg .u16 %r1314; .reg .u16 %r1315; .reg .u16 %r1316; .reg .pred %r1317; .reg .u16 %r1319; .reg .u16 %r1321; .reg .u16 %r1322; .reg .pred %r1325; .reg .u16 %r1326; .reg .pred %r1327; .reg .u16 %r1328; .reg .u16 %r1329; .reg .u16 %r1330; .reg .u16 %r1331; .reg .u16 %r1332; .reg .u16 %r1333; .reg .pred %r1334; .reg .u16 %r1336; .reg .u16 %r1338; .reg .u16 %r1339; .reg .pred %r1342; .reg .u64 %r1343; .reg .u64 %r1344; .reg .u64 %r1345; .reg .u64 %r1346; .reg .u64 %r1347; .reg .u32 %r1349; .reg .pred %r1352; .reg .u16 %r1359; .reg .u16 %r1360; .reg .u32 %r1361; .reg .pred %r1362; .reg .u64 %r1363; .reg .u64 %r1364; .reg .u16 %r1365; .reg .pred %r1366; .reg .pred %r1367; .reg .u64 %r1373; .reg .u32 %r1375; .reg .pred %r1376; .reg .pred %r1377; .reg .u64 %r1378; .reg .u16 %r1379; .reg .u32 %r1380; .reg .u64 %r1383; .reg .u16 %r1385; .reg .u16 %r1386; .reg .u32 %r1387; .reg .u16 %r1388; .reg .u32 %r1389; .reg .pred %r1390; .reg .u16 %r1392; .reg .u16 %r1393; .reg .u32 %r1394; .reg .pred %r1395; .reg .u16 %r1396; .reg .pred %r1397; .reg .pred %r1398; .reg .u32 %r1399; .reg .pred %r1400; .reg .u32 %r1401; .reg .pred %r1402; .reg .u32 %r1403; .reg .u16 %r1405; .reg .u16 %r1406; .reg .u32 %r1407; .reg .u16 %r1408; .reg .pred %r1409; .reg .u64 %r1411; .reg .u32 %r1412; .reg .u16 %r1414; .reg .u16 %r1415; .reg .pred %r1416; .reg .u32 %r1419; .reg .pred %r1420; .reg .u32 %r1423; .reg .pred %r1424; .reg .u32 %r1425; .reg .u32 %r1426; .reg .pred %r1427; .reg .u16 %r1428; .reg .pred %r1429; .reg .u16 %r1430; .reg .pred %r1431; .reg .pred %r1432; .reg .u32 %r1433; .reg .pred %r1434; .reg .u16 %r1436; .reg .u32 %r1437; .reg .u32 %r1438; .reg .u32 %r1439; .reg .u32 %r1442; .reg .u32 %r1443; .reg .u16 %r1444; .reg .u16 %r1445; .reg .u16 %r1446; .reg .u32 %r1447; .reg .u16 %r1448; .reg .pred %r1449; .reg .pred %r1451; .reg .u32 %r1452; .reg .u16 %r1454; .reg .u32 %r1455; .reg .u32 %r1456; .reg .u32 %r1459; .reg .u32 %r1460; .reg .u16 %r1461; .reg .u16 %r1462; .reg .u16 %r1463; .reg .u32 %r1464; .reg .u16 %r1465; .reg .pred %r1466; .reg .u16 %r1468; .reg .u32 %r1469; .reg .u32 %r1470; .reg .u32 %r1473; .reg .u32 %r1474; .reg .u16 %r1475; .reg .u16 %r1476; .reg .u16 %r1477; .reg .u32 %r1478; .reg .u16 %r1479; .reg .pred %r1480; .reg .u32 %r1481; .reg .pred %r1482; .reg .pred %r1483; .reg .u32 %r1484; .reg .u16 %r1485; .reg .pred %r1486; .reg .u32 %r1487; .reg .u16 %r1488; .reg .u32 %r1489; .reg .pred %r1490; .reg .u64 %r1491; .reg .pred %r1492; .reg .u64 %r1493; .reg .pred %r1494; .reg .pred %r1495; .reg .u32 %r1496; .reg .u32 %r1497; .reg .pred %r1498; .reg .u32 %r1499; .reg .u32 %r1500; .reg .u32 %r1501; .reg .pred %r1502; .reg .u64 %r1504; .reg .u64 %r1505; .reg .pred %r1506; .reg .u64 %r1509; .reg .u64 %r1513; .reg .pred %r1514; .reg .u64 %r1516; .reg .u64 %r1517; .reg .u16 %r1519; .reg .pred %r1520; .reg .u32 %r1521; .reg .u16 %r1522; .reg .u32 %r1524; .reg .u16 %r1525; .reg .pred %r1526; .reg .u64 %r1527; .reg .pred %r1528; .reg .u64 %r1529; .reg .u64 %r1530; .reg .u64 %r1532; .reg .u64 %r1533; .reg .u64 %r1534; .reg .u64 %r1535; .reg .u64 %r1536; .reg .u64 %r1537; .reg .u16 %r1538; .reg .u64 %r1539; .reg .u64 %r1540; .reg .u64 %r1541; .reg .u64 %r1542; .reg .u64 %r1543; .reg .u64 %r1544; .reg .u64 %r1545; .reg .u64 %r1546; .reg .u64 %r1547; .reg .u64 %r1548; .reg .u64 %r1549; .reg .u64 %r1550; .reg .u64 %r1551; .reg .u64 %r1552; .reg .u32 %r1568; .reg .u64 %r1569; .reg .u64 %r1570; .reg .u64 %r1571; .reg .u64 %r1572; .reg .u64 %r1573; .reg .u64 %r1574; .reg .u64 %r1575; .reg .u64 %r1576; .reg .u64 %r1577; .reg .u64 %r1578; .reg .u64 %r1579; .reg .u64 %r1580; .reg .u64 %r1581; .reg .u64 %r1582; .reg .u64 %r1583; .reg .u64 %r1584; .reg .u64 %r1585; .reg .u16 %r1596; mov.u64 %r740,%ar0; mov.f64 %r741,%ar1; mov.u32 %r742,%ar2; mov.u32 %r743,%ar3; mov.u64 %r744,%ar4; mov.u64 %r745,%ar5; mov.u64 %r746,%ar6; .loc 1 2721 0 st.f64 [%frame+344],%r741; .loc 1 2724 0 mov.u32 %r771,-1; st.u32 [%frame],%r771; .loc 1 2725 0 mov.u32 %r772,144; st.u32 [%frame+4],%r772; .loc 1 2730 0 ld.u64 %r271,[%r740+96]; setp.eq.u64 %r773,%r271,0; @ %r773 bra $L416; .loc 1 2732 0 ld.u32 %r272,[%r740+104]; st.u32 [%r271+8],%r272; .loc 1 2733 0 mov.u32 %r775,1; shl.b32 %r774,%r775,%r272; st.u32 [%r271+12],%r774; .loc 1 2734 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r740; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r271; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 2735 0 mov.u64 %r778,0; st.u64 [%r740+96],%r778; $L416: .loc 1 2741 0 add.u64 %r1542,%frame,294; add.u64 %r782,%frame,344; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r782; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1542; call e53toe$isra$9,(%out_arg1,%out_arg2); } .loc 1 2748 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r785,[%value_in]; } setp.eq.u32 %r786,%r785,0; @ %r786 bra $L417; .loc 1 2749 0 mov.u32 %r787,1; st.u32 [%r745],%r787; bra $L418; $L417: .loc 1 2751 0 st.u32 [%r745],%r785; $L418: .loc 1 2753 0 setp.eq.u32 %r789,%r742,3; @ %r789 bra $L582; .loc 1 2758 0 setp.eq.u32 %r790,%r742,0; @ %r790 bra $L583; .loc 1 2754 0 add.u32 %r313,%r743,-1; bra $L419; $L582: mov.u32 %r313,%r743; $L419: min.s32 %r304,%r313,42; bra $L420; $L583: .loc 1 2759 0 mov.u32 %r304,20; $L420: .loc 1 2910 0 ld.u32 %r323,[%frame+4]; .loc 1 521 0 ld.u16 %r792,[%frame+312]; and.b16 %r791,%r792,32767; setp.ne.u16 %r793,%r791,32767; @ %r793 bra $L421; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r796,[%value_in]; } .loc 1 2912 0 setp.eq.u32 %r797,%r796,0; @ %r797 bra $L421; .loc 1 2914 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r799,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r799; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r801,[%value_in]; } .loc 1 2915 0 mov.u32 %r529,9999; bra $L422; $L421: .loc 1 2919 0 mov.u32 %r803,144; st.u32 [%frame+4],%r803; mov.u64 %r699,%r1542; add.u64 %r1539,%frame,268; add.u64 %r695,%frame,314; mov.u64 %r698,%r1539; $L423: .loc 1 455 0 ld.u16 %r804,[%r699]; st.u16 [%r698],%r804; add.u64 %r699,%r699,2; add.u64 %r698,%r698,2; .loc 1 454 0 setp.ne.u64 %r805,%r695,%r699; @ %r805 bra $L423; .loc 1 2921 0 ld.u16 %r329,[%frame+286]; cvt.u16.u32 %r806,%r329; setp.ge.s16 %r807,%r806,0; @ %r807 bra $L584; .loc 1 2924 0 and.b16 %r808,%r806,32767; cvt.u32.u16 %r329,%r808; st.u16 [%frame+286],%r808; .loc 1 2923 0 mov.u32 %r335,65535; bra $L424; $L584: .loc 1 2928 0 mov.u32 %r335,0; $L424: add.u64 %r1537,%frame,242; mov.u64 %r421,%r1537; add.u64 %r701,%frame,262; .loc 1 2923 0 mov.u64 %r588,%r1537; mov.u32 %r658,0; cvta.const.u64 %r1532,eone; mov.u64 %r331,%r1532; $L426: .loc 1 455 0 add.u64 %r331,%r331,2; cvt.u16.u32 %r811,%r658; st.u16 [%r588],%r811; add.u64 %r588,%r588,2; .loc 1 454 0 setp.eq.u64 %r812,%r701,%r588; @ %r812 bra $L425; ld.u16 %r658,[%r331]; bra $L426; $L425: .loc 1 2934 0 setp.ne.u32 %r813,%r329,0; @ %r813 bra $L427; add.u64 %r564,%r1539,18; mov.u64 %r592,%r1539; $L429: .loc 1 2938 0 ld.u16 %r814,[%r592]; setp.ne.u16 %r815,%r814,0; @ %r815 bra $L428; add.u64 %r592,%r592,2; .loc 1 2936 0 setp.ne.u64 %r816,%r564,%r592; @ %r816 bra $L429; $L432: .loc 1 2930 0 mov.u32 %r529,0; add.u64 %r1550,%frame,80; add.u64 %r1530,%frame,190; add.u64 %r1533,%frame,214; bra $L430; $L578: .loc 1 2949 0 setp.eq.u32 %r817,%r335,0; @ %r817 bra $L431; .loc 1 2950 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r819,$LC1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r819; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r821,[%value_in]; } .loc 1 2953 0 mov.u32 %r529,9999; bra $L422; $L431: .loc 1 2952 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r824,$LC2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r824; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r826,[%value_in]; } .loc 1 2953 0 mov.u32 %r529,9999; bra $L422; $L689: .loc 1 2960 0 ld.u16 %r828,[%frame+284]; setp.lt.s16 %r829,%r828,0; @ %r829 bra $L428; .loc 1 2963 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r831,$LC3; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r831; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r833,[%value_in]; } .loc 1 2964 0 mov.u32 %r529,9999; bra $L422; $L428: .loc 1 2969 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1532; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r838,[%value_in]; } .loc 1 2970 0 setp.eq.u32 %r839,%r838,0; @ %r839 bra $L432; .loc 1 2973 0 setp.ge.s32 %r840,%r838,0; @ %r840 bra $L433; add.u64 %r1534,%frame,216; mov.u64 %r397,%r1534; add.u64 %r552,%r1539,20; mov.u64 %r560,%r1534; mov.u64 %r558,%r1539; $L434: .loc 1 455 0 ld.u16 %r841,[%r558]; st.u16 [%r560],%r841; add.u64 %r558,%r558,2; add.u64 %r560,%r560,2; .loc 1 454 0 setp.ne.u64 %r842,%r552,%r558; @ %r842 bra $L434; .loc 1 2977 0 mov.u16 %r843,16526; st.u16 [%frame+234],%r843; .loc 1 2980 0 mov.u32 %r348,16; .loc 1 2930 0 mov.u32 %r529,0; .loc 1 2979 0 cvta.const.u64 %r341,etens+160; add.u64 %r1550,%frame,80; add.u64 %r1544,%frame,320; add.u64 %r1530,%frame,190; add.u64 %r1548,%r1537,18; add.u64 %r1547,%r341,100; add.u64 %r1574,%frame,338; .loc 1 1421 0 add.u64 %r1575,%frame,164; .loc 1 1422 0 add.u64 %r1576,%frame,138; add.u64 %r1577,%frame,140; add.u64 %r1578,%frame,166; add.u64 %r1579,%frame,162; add.u64 %r1580,%frame,188; add.u64 %r1581,%frame,104; add.u64 %r1582,%frame,340; $L480: .loc 1 2983 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r341; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call ediv,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } mov.u64 %r344,%r1544; mov.u64 %r687,%r1544; mov.u64 %r689,%r1537; $L435: .loc 1 455 0 ld.u16 %r850,[%r689]; st.u16 [%r687],%r850; add.u64 %r689,%r689,2; add.u64 %r687,%r687,2; .loc 1 454 0 setp.ne.u64 %r851,%r689,%r588; @ %r851 bra $L435; .loc 1 3610 0 ld.u16 %r535,[%frame+338]; .loc 1 3611 0 cvt.u16.u32 %r853,%r535; and.b16 %r852,%r853,32767; cvt.u32.u16 %r854,%r852; add.u32 %r538,%r854,-16382; .loc 1 3612 0 setp.gt.s32 %r855,%r538,0; @ %r855 bra $L436; .loc 1 440 0 mov.u16 %r856,0; st.u16 [%frame+190],%r856; st.u16 [%frame+192],%r856; st.u16 [%frame+194],%r856; st.u16 [%frame+196],%r856; st.u16 [%frame+198],%r856; st.u16 [%frame+200],%r856; st.u16 [%frame+202],%r856; st.u16 [%frame+204],%r856; st.u16 [%frame+206],%r856; st.u16 [%frame+208],%r856; mov.u32 %r693,0; bra $L437; $L436: .loc 1 3618 0 mov.u32 %r866,144; sub.u32 %r704,%r866,%r538; mov.u64 %r506,%r1530; mov.u64 %r531,%r1530; mov.u64 %r293,%r1544; $L438: .loc 1 455 0 ld.u16 %r867,[%r293]; st.u16 [%r531],%r867; add.u64 %r293,%r293,2; add.u64 %r531,%r531,2; .loc 1 454 0 setp.ne.u64 %r868,%r293,%r1582; @ %r868 bra $L438; .loc 1 3620 0 setp.le.s32 %r869,%r704,0; @ %r869 bra $L439; .loc 1 3624 0 setp.le.s32 %r870,%r704,15; @ %r870 bra $L585; add.u32 %r871,%r704,-16; shr.u32 %r648,%r871,4; cvt.u64.u32 %r719,%r648; add.u64 %r872,%r719,%r719; add.u64 %r1549,%r1530,2; add.u64 %r565,%r872,%r1549; .loc 1 3626 0 mov.u16 %r874,0; $L441: st.u16 [%r506],%r874; mov.u64 %r506,%r1549; .loc 1 3624 0 setp.ne.u64 %r875,%r1549,%r565; @ ! %r875 bra $L684; add.u64 %r1549,%r1549,2; bra $L441; $L684: add.u64 %r877,%r719,1; add.u64 %r878,%r877,%r877; add.u64 %r705,%r1530,%r878; mov.u32 %r879,128; sub.u32 %r723,%r879,%r538; shl.b32 %r881,%r648,4; sub.u32 %r704,%r723,%r881; bra $L440; $L585: .loc 1 3623 0 mov.u64 %r705,%r1530; $L440: .loc 1 3630 0 cvta.const.u64 %r883,bmask; cvt.s64.s32 %r884,%r704; add.u64 %r885,%r884,%r884; add.u64 %r886,%r883,%r885; ld.u16 %r888,[%r705]; ld.u16 %r889,[%r886]; and.b16 %r887,%r888,%r889; st.u16 [%r705],%r887; ld.u16 %r693,[%frame+190]; $L437: .loc 1 3634 0 cvt.u16.u32 %r890,%r535; setp.ge.s16 %r891,%r890,0; @ %r891 bra $L476; mov.u64 %r589,%r1530; mov.u32 %r539,%r693; $L475: .loc 1 3638 0 ld.u16 %r892,[%r344]; cvt.u16.u32 %r893,%r539; setp.eq.u16 %r894,%r892,%r893; @ %r894 bra $L443; .loc 1 521 0 ld.u16 %r896,[%frame+208]; and.b16 %r895,%r896,32767; setp.ne.u16 %r897,%r895,32767; @ %r897 bra $L444; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r900,[%value_in]; } .loc 1 1381 0 setp.ne.u32 %r901,%r900,0; @ %r901 bra $L476; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r904,[%value_in]; } .loc 1 1415 0 setp.ne.u32 %r905,%r904,0; @ %r905 bra $L476; $L444: .loc 1 1421 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1532; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1575; call emovi,(%out_arg1,%out_arg2); } .loc 1 1422 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1576; call emovi,(%out_arg1,%out_arg2); } .loc 1 1424 0 ld.u16 %r914,[%frame+164]; not.b16 %r913,%r914; cvt.u32.u16 %r275,%r913; st.u16 [%frame+164],%r913; .loc 1 1428 0 ld.u16 %r602,[%frame+140]; cvt.u16.u32 %r916,%r602; cvt.u64.u16 %r573,%r916; .loc 1 1427 0 ld.u16 %r917,[%frame+166]; .loc 1 1429 0 sub.u64 %r574,%r917,%r573; .loc 1 1430 0 setp.le.s64 %r918,%r574,0; @ %r918 bra $L446; mov.u64 %r306,%r1576; mov.u64 %r332,%r1550; mov.u64 %r681,%r1550; mov.u64 %r694,%r1576; $L447: .loc 1 696 0 ld.u16 %r919,[%r694]; st.u16 [%r681],%r919; add.u64 %r694,%r694,2; add.u64 %r681,%r681,2; .loc 1 695 0 setp.ne.u64 %r920,%r1579,%r694; @ %r920 bra $L447; .loc 1 698 0 mov.u16 %r921,0; st.u16 [%frame+104],%r921; mov.u64 %r578,%r1575; $L449: .loc 1 696 0 add.u64 %r578,%r578,2; cvt.u16.u32 %r922,%r275; st.u16 [%r306],%r922; add.u64 %r306,%r306,2; .loc 1 695 0 setp.eq.u64 %r923,%r306,%r694; @ %r923 bra $L448; ld.u16 %r275,[%r578]; bra $L449; $L448: .loc 1 698 0 mov.u16 %r924,0; st.u16 [%frame+162],%r924; mov.u64 %r327,%r1575; $L450: .loc 1 696 0 ld.u16 %r925,[%r332]; st.u16 [%r327],%r925; add.u64 %r332,%r332,2; add.u64 %r327,%r327,2; .loc 1 695 0 setp.ne.u64 %r926,%r1581,%r332; @ %r926 bra $L450; .loc 1 698 0 mov.u16 %r927,0; st.u16 [%frame+188],%r927; .loc 1 1435 0 ld.u16 %r573,[%frame+140]; .loc 1 1436 0 neg.s64 %r574,%r574; bra $L451; $L446: .loc 1 1439 0 setp.eq.u64 %r928,%r574,0; @ %r928 bra $L452; $L451: .loc 1 1441 0 setp.ge.s64 %r929,%r574,-145; @ ! %r929 bra $L454; cvt.u32.u64 %r931,%r574; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1575; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r931; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r933,[%value_in]; } mov.u32 %r642,%r933; ld.u16 %r275,[%frame+164]; bra $L455; $L452: add.u64 %r549,%frame,168; add.u64 %r727,%frame,142; mov.u64 %r661,%r1575; $L457: .loc 1 756 0 ld.u16 %r936,[%r549]; ld.u16 %r937,[%r727]; setp.ne.u16 %r938,%r936,%r937; @ %r938 bra $L456; add.u64 %r549,%r549,2; add.u64 %r727,%r727,2; .loc 1 754 0 setp.ne.u64 %r939,%r1530,%r549; @ %r939 bra $L457; bra $L685; $L456: .loc 1 762 0 setp.gt.u16 %r942,%r936,%r937; @ %r942 bra $L459; .loc 1 1438 0 mov.u32 %r642,0; bra $L455; $L685: .loc 1 1453 0 ld.u16 %r943,[%frame+138]; setp.eq.u16 %r945,%r943,%r913; @ %r945 bra $L460; .loc 1 440 0 mov.u16 %r946,0; st.u16 [%frame+190],%r946; st.u16 [%frame+192],%r946; st.u16 [%frame+194],%r946; st.u16 [%frame+196],%r946; st.u16 [%frame+198],%r946; st.u16 [%frame+200],%r946; st.u16 [%frame+202],%r946; st.u16 [%frame+204],%r946; st.u16 [%frame+206],%r946; st.u16 [%frame+208],%r946; mov.u32 %r693,0; bra $L476; $L460: .loc 1 1460 0 setp.ne.u32 %r956,%r602,0; @ %r956 bra $L461; ld.u16 %r957,[%frame+144]; setp.lt.s16 %r958,%r957,0; @ %r958 bra $L461; .loc 1 804 0 add.u64 %r603,%frame,162; $L464: .loc 1 809 0 ld.u16 %r596,[%r603]; cvt.u16.u32 %r959,%r596; setp.ge.s16 %r960,%r959,0; @ %r960 bra $L462; .loc 1 810 0 cvt.u16.u32 %r962,%r602; or.b16 %r961,%r962,1; cvt.u32.u16 %r602,%r961; $L462: .loc 1 811 0 cvt.u16.u32 %r963,%r596; add.u16 %r964,%r963,%r963; st.u16 [%r603],%r964; .loc 1 812 0 cvt.u16.u32 %r967,%r602; and.b16 %r966,%r967,2; setp.eq.u16 %r968,%r966,0; @ %r968 bra $L463; .loc 1 813 0 or.b16 %r969,%r964,1; st.u16 [%r603],%r969; $L463: .loc 1 814 0 cvt.u16.u32 %r971,%r602; add.u16 %r972,%r971,%r971; cvt.u32.u16 %r602,%r972; .loc 1 815 0 add.u64 %r603,%r603,-2; .loc 1 807 0 setp.ne.u64 %r975,%r603,%r1577; @ %r975 bra $L464; bra $L454; $L461: add.u64 %r273,%frame,140; $L468: .loc 1 1468 0 ld.u16 %r978,[%r273]; setp.eq.u16 %r979,%r978,0; @ %r979 bra $L466; .loc 1 1471 0 add.u64 %r573,%r573,1; bra $L467; $L466: add.u64 %r273,%r273,2; .loc 1 1466 0 setp.ne.u64 %r980,%r1579,%r273; @ %r980 bra $L468; $L467: .loc 1 1475 0 st.u16 [%frame+140],%r573; bra $L454; $L459: mov.u64 %r653,%r1576; mov.u64 %r662,%r1550; .loc 1 762 0 mov.u64 %r568,%r1550; mov.u64 %r647,%r1576; $L469: .loc 1 696 0 ld.u16 %r981,[%r647]; st.u16 [%r568],%r981; add.u64 %r647,%r647,2; add.u64 %r568,%r568,2; .loc 1 695 0 setp.ne.u64 %r982,%r1579,%r647; @ %r982 bra $L469; .loc 1 698 0 mov.u16 %r983,0; st.u16 [%frame+104],%r983; mov.u64 %r654,%r1575; $L470: .loc 1 696 0 ld.u16 %r984,[%r654]; st.u16 [%r653],%r984; add.u64 %r654,%r654,2; add.u64 %r653,%r653,2; .loc 1 695 0 setp.ne.u64 %r985,%r1580,%r654; @ %r985 bra $L470; .loc 1 698 0 mov.u16 %r986,0; st.u16 [%frame+162],%r986; $L471: .loc 1 696 0 ld.u16 %r987,[%r662]; st.u16 [%r661],%r987; add.u64 %r662,%r662,2; add.u64 %r661,%r661,2; .loc 1 695 0 setp.ne.u64 %r988,%r1581,%r662; @ %r988 bra $L471; .loc 1 698 0 mov.u16 %r989,0; st.u16 [%frame+188],%r989; ld.u16 %r275,[%frame+164]; .loc 1 1438 0 mov.u32 %r642,0; $L455: .loc 1 1485 0 ld.u16 %r990,[%frame+138]; cvt.u16.u32 %r991,%r275; setp.ne.u16 %r992,%r990,%r991; @ %r992 bra $L586; .loc 1 913 0 mov.u32 %r732,0; .loc 1 912 0 mov.u64 %r629,%r1579; .loc 1 911 0 add.u64 %r628,%frame,188; $L473: .loc 1 916 0 ld.u16 %r993,[%r628]; ld.u16 %r994,[%r629]; add.u64 %r995,%r993,%r994; cvt.u64.u32 %r996,%r732; add.u64 %r625,%r995,%r996; .loc 1 921 0 st.u16 [%r629],%r625; .loc 1 922 0 add.u64 %r628,%r628,-2; .loc 1 923 0 add.u64 %r629,%r629,-2; .loc 1 917 0 shr.u64 %r997,%r625,16; cvt.u32.u64 %r999,%r997; and.b32 %r732,%r999,1; .loc 1 914 0 setp.ne.u64 %r1002,%r628,%r1578; @ %r1002 bra $L473; .loc 1 1488 0 mov.u32 %r643,0; bra $L474; $L586: .loc 1 940 0 mov.u32 %r401,0; .loc 1 938 0 add.u64 %r640,%frame,188; .loc 1 939 0 mov.u64 %r641,%r1579; $L472: .loc 1 943 0 ld.u16 %r1003,[%r641]; ld.u16 %r1004,[%r640]; sub.u64 %r1005,%r1003,%r1004; cvt.u64.u32 %r1006,%r401; sub.u64 %r637,%r1005,%r1006; .loc 1 948 0 st.u16 [%r641],%r637; .loc 1 949 0 add.u64 %r640,%r640,-2; .loc 1 950 0 add.u64 %r641,%r641,-2; .loc 1 944 0 shr.u64 %r1007,%r637,16; cvt.u32.u64 %r1009,%r1007; and.b32 %r401,%r1009,1; .loc 1 941 0 setp.ne.u64 %r1012,%r641,%r1577; @ %r1012 bra $L472; .loc 1 1493 0 mov.u32 %r643,1; $L474: .loc 1 1495 0 mov.u32 %r1017,64; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1576; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r642; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r643; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r573; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r1017; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%frame; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } $L454: .loc 1 1498 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1576; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovo$isra$7,(%out_arg1,%out_arg2); } ld.u16 %r693,[%frame+190]; bra $L476; $L443: add.u64 %r344,%r344,2; add.u64 %r589,%r589,2; .loc 1 3636 0 setp.eq.u64 %r1024,%r344,%r1574; @ %r1024 bra $L476; ld.u16 %r539,[%r589]; bra $L475; $L439: ld.u16 %r693,[%frame+190]; $L476: mov.u64 %r347,%r1530; .loc 1 440 0 mov.u64 %r355,%r1537; $L479: .loc 1 2987 0 ld.u16 %r1025,[%r355]; cvt.u16.u32 %r1026,%r693; setp.ne.u16 %r1027,%r1025,%r1026; @ %r1027 bra $L477; add.u64 %r355,%r355,2; add.u64 %r347,%r347,2; .loc 1 2985 0 setp.eq.u64 %r1028,%r1548,%r355; @ %r1028 bra $L587; ld.u16 %r693,[%r347]; bra $L479; $L587: mov.u64 %r370,%r1534; mov.u64 %r376,%r1537; $L478: .loc 1 455 0 ld.u16 %r1029,[%r376]; st.u16 [%r370],%r1029; add.u64 %r376,%r376,2; add.u64 %r370,%r370,2; .loc 1 454 0 setp.ne.u64 %r1030,%r376,%r689; @ %r1030 bra $L478; .loc 1 2991 0 add.u32 %r529,%r529,%r348; $L477: .loc 1 2993 0 add.u64 %r341,%r341,20; .loc 1 2994 0 shr.u32 %r1031,%r348,1; cvt.u16.u32 %r1032,%r1031; cvt.u32.u16 %r348,%r1032; .loc 1 2996 0 setp.ne.u64 %r1034,%r341,%r1547; @ %r1034 bra $L480; .loc 1 2999 0 ld.u16 %r1036,[%frame+234]; ld.u16 %r1037,[%frame+286]; add.u16 %r1035,%r1036,%r1037; add.u16 %r1038,%r1035,-16526; st.u16 [%frame+234],%r1038; add.u64 %r390,%r1534,20; mov.u64 %r395,%r1539; $L481: .loc 1 455 0 ld.u16 %r1039,[%r397]; st.u16 [%r395],%r1039; add.u64 %r397,%r397,2; add.u64 %r395,%r395,2; .loc 1 454 0 setp.ne.u64 %r1040,%r390,%r397; @ %r1040 bra $L481; mov.u64 %r406,%r1537; mov.u32 %r646,0; cvta.const.u64 %r356,eone; $L483: .loc 1 455 0 add.u64 %r356,%r356,2; cvt.u16.u32 %r1041,%r646; st.u16 [%r406],%r1041; add.u64 %r406,%r406,2; .loc 1 454 0 setp.eq.u64 %r1042,%r406,%r689; @ %r1042 bra $L588; ld.u16 %r646,[%r356]; bra $L483; $L485: .loc 1 3007 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r357; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1046,[%value_in]; } setp.gt.s32 %r1047,%r1046,0; @ %r1047 bra $L484; .loc 1 3009 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r357; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1534; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call ediv,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3010 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r357; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1537; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3011 0 add.u32 %r529,%r529,%r359; $L484: .loc 1 3013 0 shr.u32 %r1060,%r359,1; cvt.u16.u32 %r1061,%r1060; cvt.u32.u16 %r359,%r1061; .loc 1 3014 0 setp.eq.u64 %r1063,%r357,%r1546; @ ! %r1063 bra $L686; add.u64 %r1533,%frame,214; bra $L430; $L686: .loc 1 3016 0 add.u64 %r357,%r357,20; bra $L482; $L588: .loc 1 3003 0 mov.u32 %r359,4096; .loc 1 3004 0 cvta.const.u64 %r357,etens; add.u64 %r1546,%r357,240; $L482: .loc 1 3005 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1546; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1068,[%value_in]; } setp.le.s32 %r1069,%r1068,0; @ %r1069 bra $L485; add.u64 %r1533,%frame,214; bra $L430; $L433: .loc 1 3022 0 ld.u16 %r1070,[%frame+286]; setp.ne.u16 %r1071,%r1070,0; @ %r1071 bra $L486; .loc 1 3024 0 ld.u16 %r1072,[%frame+284]; setp.lt.s16 %r1073,%r1072,0; @ %r1073 bra $L589; .loc 1 2930 0 mov.u32 %r529,0; cvta.const.u64 %r1546,etens+240; $L488: .loc 1 3026 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1546; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1539; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3027 0 add.u32 %r529,%r529,-1; .loc 1 3024 0 ld.u16 %r1081,[%frame+284]; setp.ge.s16 %r1082,%r1081,0; @ %r1082 bra $L488; add.u64 %r1530,%frame,190; add.u64 %r1533,%frame,214; bra $L487; $L486: .loc 1 3032 0 add.u64 %r1530,%frame,190; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovi,(%out_arg1,%out_arg2); } .loc 1 2930 0 mov.u32 %r529,0; add.u64 %r1533,%frame,214; add.u64 %r1583,%frame,216; add.u64 %r1584,%frame,192; add.u64 %r1585,%frame,240; $L495: .loc 1 3035 0 ld.u16 %r1088,[%frame+214]; and.b16 %r1087,%r1088,7; setp.ne.u16 %r1089,%r1087,0; @ %r1089 bra $L489; mov.u64 %r682,%r1530; mov.u64 %r679,%r1583; mov.u64 %r559,%r1583; mov.u64 %r540,%r1530; $L490: .loc 1 696 0 ld.u16 %r1090,[%r540]; st.u16 [%r559],%r1090; add.u64 %r540,%r540,2; add.u64 %r559,%r559,2; .loc 1 695 0 setp.ne.u64 %r1091,%r540,%r1533; @ %r1091 bra $L490; .loc 1 698 0 mov.u16 %r1092,0; st.u16 [%frame+240],%r1092; .loc 1 3039 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1583; call eshdn1,(%out_arg1); } .loc 1 3040 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1583; call eshdn1,(%out_arg1); } .loc 1 913 0 mov.u32 %r685,0; .loc 1 912 0 add.u64 %r382,%frame,240; .loc 1 911 0 mov.u64 %r381,%r1533; $L491: .loc 1 916 0 ld.u16 %r1097,[%r381]; ld.u16 %r1098,[%r382]; add.u64 %r1099,%r1097,%r1098; cvt.u64.u32 %r1100,%r685; add.u64 %r378,%r1099,%r1100; .loc 1 921 0 st.u16 [%r382],%r378; .loc 1 922 0 add.u64 %r381,%r381,-2; .loc 1 923 0 add.u64 %r382,%r382,-2; .loc 1 917 0 shr.u64 %r1101,%r378,16; cvt.u32.u64 %r1103,%r1101; and.b32 %r685,%r1103,1; .loc 1 914 0 setp.ne.u64 %r1106,%r381,%r1584; @ %r1106 bra $L491; .loc 1 3042 0 ld.u16 %r1538,[%frame+218]; add.u16 %r1538,%r1538,3; st.u16 [%frame+218],%r1538; .loc 1 3043 0 ld.u16 %r1109,[%frame+220]; setp.eq.u16 %r1110,%r1109,0; @ %r1110 bra $L492; $L493: .loc 1 3045 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1583; call eshdn1,(%out_arg1); } .loc 1 3046 0 ld.u16 %r1538,[%frame+218]; add.u16 %r1538,%r1538,1; st.u16 [%frame+218],%r1538; .loc 1 3043 0 ld.u16 %r1115,[%frame+220]; setp.ne.u16 %r1116,%r1115,0; @ %r1116 bra $L493; $L492: .loc 1 3048 0 ld.u16 %r1117,[%frame+240]; setp.ne.u16 %r1118,%r1117,0; @ %r1118 bra $L489; .loc 1 3050 0 setp.gt.u16 %r1120,%r1538,16382; @ %r1120 bra $L489; $L494: .loc 1 696 0 ld.u16 %r1121,[%r679]; st.u16 [%r682],%r1121; add.u64 %r679,%r679,2; add.u64 %r682,%r682,2; .loc 1 695 0 setp.ne.u64 %r1122,%r1585,%r679; @ %r1122 bra $L494; .loc 1 698 0 mov.u16 %r1123,0; st.u16 [%frame+214],%r1123; .loc 1 3053 0 add.u32 %r529,%r529,-1; .loc 1 3033 0 setp.ne.u32 %r1124,%r529,-43; @ %r1124 bra $L495; $L489: .loc 1 3055 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L487; $L589: .loc 1 2930 0 mov.u32 %r529,0; add.u64 %r1530,%frame,190; add.u64 %r1533,%frame,214; $L487: mov.u64 %r674,%r1530; add.u64 %r672,%r1539,20; mov.u64 %r671,%r1539; $L496: .loc 1 455 0 ld.u16 %r1129,[%r671]; st.u16 [%r674],%r1129; add.u64 %r671,%r671,2; add.u64 %r674,%r674,2; .loc 1 454 0 setp.ne.u64 %r1130,%r671,%r672; @ %r1130 bra $L496; mov.u64 %r644,%r1537; mov.u32 %r676,0; cvta.const.u64 %r398,eone; $L498: .loc 1 455 0 add.u64 %r398,%r398,2; cvt.u16.u32 %r1131,%r676; st.u16 [%r644],%r1131; add.u64 %r644,%r644,2; .loc 1 454 0 setp.eq.u64 %r1132,%r644,%r588; @ %r1132 bra $L590; ld.u16 %r676,[%r398]; bra $L498; $L501: .loc 1 3064 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r522; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1136,[%value_in]; } setp.lt.s32 %r1137,%r1136,0; @ %r1137 bra $L499; .loc 1 3066 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r668; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1530; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3067 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r668; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1537; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3068 0 add.u32 %r529,%r529,%r402; $L499: .loc 1 3070 0 shr.u32 %r1151,%r402,31; add.u32 %r1152,%r1151,%r402; shr.s32 %r402,%r1152,1; add.u64 %r683,%r683,20; .loc 1 3071 0 setp.eq.u64 %r1154,%r683,260; @ ! %r1154 bra $L497; bra $L500; $L590: .loc 1 454 0 mov.u64 %r683,0; .loc 1 3057 0 mov.u32 %r402,-4096; cvta.const.u64 %r1551,etens; cvta.const.u64 %r1545,emtens; $L497: add.u64 %r668,%r1551,%r683; add.u64 %r522,%r1545,%r683; .loc 1 3062 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1532; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1160,[%value_in]; } setp.gt.s32 %r1161,%r1160,0; @ %r1161 bra $L501; $L500: .loc 1 3076 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1532; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call ediv,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } add.u64 %r1550,%frame,80; $L430: .loc 1 3080 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovi,(%out_arg1,%out_arg2); } mov.u64 %r455,%r1530; mov.u64 %r429,%r1530; $L502: .loc 1 696 0 ld.u16 %r1172,[%r429]; st.u16 [%r421],%r1172; add.u64 %r429,%r429,2; add.u64 %r421,%r421,2; .loc 1 695 0 setp.ne.u64 %r1173,%r1533,%r429; @ %r1173 bra $L502; .loc 1 698 0 mov.u16 %r1174,0; st.u16 [%frame+266],%r1174; .loc 1 3082 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovi,(%out_arg1,%out_arg2); } mov.u64 %r450,%r1539; $L503: .loc 1 696 0 ld.u16 %r1179,[%r455]; st.u16 [%r450],%r1179; add.u64 %r455,%r455,2; add.u64 %r450,%r450,2; .loc 1 695 0 setp.ne.u64 %r1180,%r429,%r455; @ %r1180 bra $L503; .loc 1 698 0 mov.u16 %r1181,0; st.u16 [%frame+292],%r1181; .loc 1 3084 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call eiremain,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 3085 0 ld.u16 %r409,[%frame+76]; .loc 1 3086 0 setp.eq.u64 %r1187,%r409,0; @ ! %r1187 bra $L505; cvta.const.u64 %r1529,ezero; .loc 1 804 0 add.u64 %r1569,%frame,292; add.u64 %r1570,%frame,270; add.u64 %r1571,%r1539,24; add.u64 %r1572,%frame,240; add.u64 %r1573,%frame,218; bra $L504; $L592: .loc 1 805 0 mov.u32 %r416,0; .loc 1 804 0 mov.u64 %r417,%r1569; $L509: .loc 1 809 0 ld.u16 %r411,[%r417]; cvt.u16.u32 %r1188,%r411; setp.ge.s16 %r1189,%r1188,0; @ %r1189 bra $L506; .loc 1 810 0 cvt.u16.u32 %r1191,%r416; or.b16 %r1190,%r1191,1; cvt.u32.u16 %r416,%r1190; $L506: .loc 1 811 0 cvt.u16.u32 %r1192,%r411; add.u16 %r1193,%r1192,%r1192; .loc 1 812 0 cvt.u16.u32 %r1195,%r416; and.b16 %r1194,%r1195,2; setp.ne.u16 %r1196,%r1194,0; @ %r1196 bra $L507; .loc 1 811 0 st.u16 [%r417],%r1193; bra $L508; $L507: .loc 1 813 0 or.b16 %r1198,%r1193,1; st.u16 [%r417],%r1198; $L508: .loc 1 814 0 cvt.u16.u32 %r1200,%r416; add.u16 %r1201,%r1200,%r1200; cvt.u32.u16 %r416,%r1201; .loc 1 815 0 add.u64 %r417,%r417,-2; .loc 1 807 0 setp.ne.u64 %r1204,%r417,%r1570; @ %r1204 bra $L509; add.u64 %r475,%frame,216; mov.u64 %r533,%r1539; $L510: .loc 1 696 0 ld.u16 %r1205,[%r533]; st.u16 [%r475],%r1205; add.u64 %r533,%r533,2; add.u64 %r475,%r475,2; .loc 1 695 0 setp.ne.u64 %r1206,%r1571,%r533; @ %r1206 bra $L510; .loc 1 698 0 mov.u16 %r1207,0; st.u16 [%frame+240],%r1207; .loc 1 805 0 mov.u32 %r427,0; .loc 1 804 0 mov.u64 %r428,%r1572; $L514: .loc 1 809 0 ld.u16 %r422,[%r428]; cvt.u16.u32 %r1208,%r422; setp.ge.s16 %r1209,%r1208,0; @ %r1209 bra $L511; .loc 1 810 0 cvt.u16.u32 %r1211,%r427; or.b16 %r1210,%r1211,1; cvt.u32.u16 %r427,%r1210; $L511: .loc 1 811 0 cvt.u16.u32 %r1212,%r422; add.u16 %r1213,%r1212,%r1212; .loc 1 812 0 cvt.u16.u32 %r1215,%r427; and.b16 %r1214,%r1215,2; setp.ne.u16 %r1216,%r1214,0; @ %r1216 bra $L512; .loc 1 811 0 st.u16 [%r428],%r1213; bra $L513; $L512: .loc 1 813 0 or.b16 %r1218,%r1213,1; st.u16 [%r428],%r1218; $L513: .loc 1 814 0 cvt.u16.u32 %r1220,%r427; add.u16 %r1221,%r1220,%r1220; cvt.u32.u16 %r427,%r1221; .loc 1 815 0 add.u64 %r428,%r428,-2; .loc 1 807 0 setp.ne.u64 %r1224,%r428,%r1573; @ %r1224 bra $L514; .loc 1 805 0 mov.u32 %r435,0; .loc 1 804 0 mov.u64 %r436,%r1572; $L518: .loc 1 809 0 ld.u16 %r430,[%r436]; cvt.u16.u32 %r1225,%r430; setp.ge.s16 %r1226,%r1225,0; @ %r1226 bra $L515; .loc 1 810 0 cvt.u16.u32 %r1228,%r435; or.b16 %r1227,%r1228,1; cvt.u32.u16 %r435,%r1227; $L515: .loc 1 811 0 cvt.u16.u32 %r1229,%r430; add.u16 %r1230,%r1229,%r1229; .loc 1 812 0 cvt.u16.u32 %r1232,%r435; and.b16 %r1231,%r1232,2; setp.ne.u16 %r1233,%r1231,0; @ %r1233 bra $L516; .loc 1 811 0 st.u16 [%r436],%r1230; bra $L517; $L516: .loc 1 813 0 or.b16 %r1235,%r1230,1; st.u16 [%r436],%r1235; $L517: .loc 1 814 0 cvt.u16.u32 %r1237,%r435; add.u16 %r1238,%r1237,%r1237; cvt.u32.u16 %r435,%r1238; .loc 1 815 0 add.u64 %r436,%r436,-2; .loc 1 807 0 setp.ne.u64 %r1241,%r436,%r1573; @ %r1241 bra $L518; .loc 1 913 0 mov.u32 %r688,0; .loc 1 912 0 mov.u64 %r449,%r1569; .loc 1 911 0 mov.u64 %r448,%r1572; $L519: .loc 1 916 0 ld.u16 %r1242,[%r448]; ld.u16 %r1243,[%r449]; add.u64 %r1244,%r1242,%r1243; cvt.u64.u32 %r1245,%r688; add.u64 %r445,%r1244,%r1245; .loc 1 921 0 st.u16 [%r449],%r445; .loc 1 922 0 add.u64 %r448,%r448,-2; .loc 1 923 0 add.u64 %r449,%r449,-2; .loc 1 917 0 shr.u64 %r1246,%r445,16; cvt.u32.u64 %r1248,%r1246; and.b32 %r688,%r1248,1; .loc 1 914 0 setp.ne.u64 %r1251,%r448,%r1573; @ %r1251 bra $L519; .loc 1 3093 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call eiremain,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 3094 0 ld.u16 %r452,[%frame+76]; .loc 1 3095 0 add.u32 %r529,%r529,-1; .loc 1 3086 0 setp.ne.u64 %r1257,%r452,0; @ %r1257 bra $L591; $L504: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1529; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1261,[%value_in]; } setp.ne.u32 %r1262,%r1261,0; @ %r1262 bra $L592; bra $L505; $L591: mov.u64 %r409,%r452; $L505: .loc 1 3098 0 setp.eq.u32 %r1263,%r335,0; @ %r1263 bra $L520; .loc 1 3099 0 mov.u32 %r1264,45; st.u8 [%frame+80],%r1264; bra $L521; $L520: .loc 1 3101 0 mov.u32 %r1265,32; st.u8 [%frame+80],%r1265; $L521: .loc 1 3103 0 setp.ne.u32 %r1266,%r742,3; @ %r1266 bra $L593; .loc 1 3104 0 add.u32 %r305,%r304,%r529; .loc 1 3109 0 setp.le.s32 %r1267,%r305,42; @ %r1267 bra $L522; .loc 1 3111 0 setp.ne.u64 %r1268,%r409,10; @ %r1268 bra $L523; .loc 1 3113 0 mov.u32 %r1269,49; st.u8 [%frame+81],%r1269; .loc 1 3114 0 mov.u32 %r1270,46; st.u8 [%frame+82],%r1270; add.u32 %r529,%r529,1; .loc 1 3117 0 mov.u32 %r1271,48; st.u8 [%frame+83],%r1271; mov.u32 %r305,41; add.u64 %r310,%frame,84; bra $L524; $L593: .loc 1 3103 0 mov.u32 %r305,%r304; $L522: .loc 1 3111 0 setp.ne.u64 %r1272,%r409,10; @ %r1272 bra $L525; .loc 1 3113 0 mov.u32 %r1273,49; st.u8 [%frame+81],%r1273; .loc 1 3114 0 mov.u32 %r1274,46; st.u8 [%frame+82],%r1274; add.u32 %r529,%r529,1; .loc 1 3115 0 setp.le.s32 %r1275,%r305,0; @ %r1275 bra $L526; add.u32 %r305,%r305,-1; .loc 1 3117 0 mov.u32 %r1276,48; st.u8 [%frame+83],%r1276; add.u64 %r310,%frame,84; bra $L524; $L526: .loc 1 3121 0 setp.ne.u32 %r1277,%r305,0; @ %r1277 bra $L594; .loc 1 3114 0 add.u64 %r310,%frame,83; bra $L524; $L523: .loc 1 3129 0 cvt.u16.u64 %r1280,%r409; add.u16 %r1279,%r1280,48; cvt.u32.u16 %r1281,%r1279; st.u8 [%frame+81],%r1281; .loc 1 3130 0 mov.u32 %r1282,46; st.u8 [%frame+82],%r1282; .loc 1 3110 0 mov.u32 %r305,42; .loc 1 3130 0 add.u64 %r310,%frame,83; bra $L524; $L525: .loc 1 3129 0 cvt.u16.u64 %r1285,%r409; add.u16 %r1284,%r1285,48; cvt.u32.u16 %r1286,%r1284; st.u8 [%frame+81],%r1286; .loc 1 3130 0 mov.u32 %r1287,46; st.u8 [%frame+82],%r1287; .loc 1 3133 0 setp.lt.s32 %r1288,%r305,0; @ %r1288 bra $L528; .loc 1 3130 0 add.u64 %r310,%frame,83; $L524: mov.u64 %r550,%r310; mov.u32 %r507,0; add.u64 %r1534,%frame,216; add.u64 %r1536,%frame,240; add.u64 %r1541,%frame,292; add.u64 %r1540,%frame,270; add.u64 %r1552,%r1539,24; add.u64 %r1535,%frame,218; .loc 1 805 0 mov.u32 %r1568,%r507; $L543: mov.u32 %r467,%r1568; .loc 1 804 0 mov.u64 %r468,%r1541; $L532: .loc 1 809 0 ld.u16 %r462,[%r468]; cvt.u16.u32 %r1289,%r462; setp.ge.s16 %r1290,%r1289,0; @ %r1290 bra $L529; .loc 1 810 0 cvt.u16.u32 %r1292,%r467; or.b16 %r1291,%r1292,1; cvt.u32.u16 %r467,%r1291; $L529: .loc 1 811 0 cvt.u16.u32 %r1293,%r462; add.u16 %r1294,%r1293,%r1293; .loc 1 812 0 cvt.u16.u32 %r1296,%r467; and.b16 %r1295,%r1296,2; setp.ne.u16 %r1297,%r1295,0; @ %r1297 bra $L530; .loc 1 811 0 st.u16 [%r468],%r1294; bra $L531; $L530: .loc 1 813 0 or.b16 %r1299,%r1294,1; st.u16 [%r468],%r1299; $L531: .loc 1 814 0 cvt.u16.u32 %r1301,%r467; add.u16 %r1302,%r1301,%r1301; cvt.u32.u16 %r467,%r1302; .loc 1 815 0 add.u64 %r468,%r468,-2; .loc 1 807 0 setp.ne.u64 %r1305,%r468,%r1540; @ %r1305 bra $L532; mov.u64 %r579,%r1534; mov.u64 %r581,%r1539; $L533: .loc 1 696 0 ld.u16 %r1306,[%r581]; st.u16 [%r579],%r1306; add.u64 %r581,%r581,2; add.u64 %r579,%r579,2; .loc 1 695 0 setp.ne.u64 %r1307,%r1552,%r581; @ %r1307 bra $L533; .loc 1 698 0 mov.u16 %r1308,0; st.u16 [%frame+240],%r1308; .loc 1 805 0 mov.u32 %r479,%r1568; .loc 1 804 0 mov.u64 %r480,%r1536; $L537: .loc 1 809 0 ld.u16 %r473,[%r480]; cvt.u16.u32 %r1309,%r473; setp.ge.s16 %r1310,%r1309,0; @ %r1310 bra $L534; .loc 1 810 0 cvt.u16.u32 %r1312,%r479; or.b16 %r1311,%r1312,1; cvt.u32.u16 %r479,%r1311; $L534: .loc 1 811 0 cvt.u16.u32 %r1313,%r473; add.u16 %r1314,%r1313,%r1313; .loc 1 812 0 cvt.u16.u32 %r1316,%r479; and.b16 %r1315,%r1316,2; setp.ne.u16 %r1317,%r1315,0; @ %r1317 bra $L535; .loc 1 811 0 st.u16 [%r480],%r1314; bra $L536; $L535: .loc 1 813 0 or.b16 %r1319,%r1314,1; st.u16 [%r480],%r1319; $L536: .loc 1 814 0 cvt.u16.u32 %r1321,%r479; add.u16 %r1322,%r1321,%r1321; cvt.u32.u16 %r479,%r1322; .loc 1 815 0 add.u64 %r480,%r480,-2; .loc 1 807 0 setp.ne.u64 %r1325,%r480,%r1535; @ %r1325 bra $L537; .loc 1 805 0 mov.u32 %r488,%r1568; .loc 1 804 0 mov.u64 %r489,%r1536; $L541: .loc 1 809 0 ld.u16 %r482,[%r489]; cvt.u16.u32 %r1326,%r482; setp.ge.s16 %r1327,%r1326,0; @ %r1327 bra $L538; .loc 1 810 0 cvt.u16.u32 %r1329,%r488; or.b16 %r1328,%r1329,1; cvt.u32.u16 %r488,%r1328; $L538: .loc 1 811 0 cvt.u16.u32 %r1330,%r482; add.u16 %r1331,%r1330,%r1330; .loc 1 812 0 cvt.u16.u32 %r1333,%r488; and.b16 %r1332,%r1333,2; setp.ne.u16 %r1334,%r1332,0; @ %r1334 bra $L539; .loc 1 811 0 st.u16 [%r489],%r1331; bra $L540; $L539: .loc 1 813 0 or.b16 %r1336,%r1331,1; st.u16 [%r489],%r1336; $L540: .loc 1 814 0 cvt.u16.u32 %r1338,%r488; add.u16 %r1339,%r1338,%r1338; cvt.u32.u16 %r488,%r1339; .loc 1 815 0 add.u64 %r489,%r489,-2; .loc 1 807 0 setp.ne.u64 %r1342,%r489,%r1535; @ %r1342 bra $L541; .loc 1 913 0 mov.u32 %r591,%r1568; .loc 1 912 0 mov.u64 %r501,%r1541; .loc 1 911 0 mov.u64 %r500,%r1536; $L542: .loc 1 916 0 ld.u16 %r1343,[%r500]; ld.u16 %r1344,[%r501]; add.u64 %r1345,%r1343,%r1344; cvt.u64.u32 %r1346,%r591; add.u64 %r497,%r1345,%r1346; .loc 1 921 0 st.u16 [%r501],%r497; .loc 1 922 0 add.u64 %r500,%r500,-2; .loc 1 923 0 add.u64 %r501,%r501,-2; .loc 1 917 0 shr.u64 %r1347,%r497,16; cvt.u32.u64 %r1349,%r1347; and.b32 %r591,%r1349,1; .loc 1 914 0 setp.ne.u64 %r1352,%r500,%r1535; @ %r1352 bra $L542; .loc 1 3141 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call eiremain,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 3142 0 ld.u16 %r502,[%frame+76]; cvt.u16.u32 %r1360,%r502; add.u16 %r1359,%r1360,48; cvt.u32.u16 %r1361,%r1359; st.u8 [%r550],%r1361; .loc 1 3133 0 add.u32 %r507,%r507,1; add.u64 %r550,%r550,1; setp.ge.s32 %r1362,%r305,%r507; @ %r1362 bra $L543; cvt.s64.s32 %r1363,%r305; add.u64 %r1364,%r1363,1; add.u64 %r706,%r310,%r1364; bra $L544; $L528: ld.u16 %r502,[%frame+76]; .loc 1 3130 0 add.u64 %r706,%frame,83; $L544: .loc 1 3144 0 cvt.u16.u32 %r1365,%r502; cvt.u64.u16 %r508,%r1365; .loc 1 3145 0 add.u64 %r510,%r706,-1; .loc 1 3148 0 setp.le.s64 %r1366,%r508,4; @ %r1366 bra $L527; .loc 1 3151 0 setp.ne.u64 %r1367,%r508,5; @ %r1367 bra $L545; .loc 1 3153 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1537; call emovo$isra$7,(%out_arg1,%out_arg2); } .loc 1 3154 0 cvta.const.u64 %r1373,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1373; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1375,[%value_in]; } setp.ne.u32 %r1376,%r1375,0; @ %r1376 bra $L545; .loc 1 3156 0 setp.lt.s32 %r1377,%r305,0; @ %r1377 bra $L527; ld.s8 %r512,[%r706+-2]; cvt.u16.u32 %r1379,%r512; set.u32.eq.u16 %r1380,%r1379,46; cvt.s64.s32 %r1378,%r1380; add.u64 %r1383,%r510,%r1378; ld.u8 %r1596,[%r1383+-1]; mov.u16 %r1386,%r1596; and.b16 %r1385,%r1386,1; cvt.u32.u16 %r1387,%r1385; cvt.s32.s8 %r1389,%r1387; cvt.u16.u32 %r1388,%r1389; setp.eq.u16 %r1390,%r1388,0; @ %r1390 bra $L527; bra $L687; $L545: .loc 1 3161 0 add.u64 %r490,%r706,-2; ld.u8 %r1596,[%r706+-2]; mov.u16 %r1393,%r1596; and.b16 %r1392,%r1393,127; cvt.u32.u16 %r1394,%r1392; cvt.s32.s8 %r484,%r1394; .loc 1 3164 0 setp.lt.s32 %r1395,%r305,0; @ %r1395 bra $L547; $L581: .loc 1 3171 0 cvt.u16.u32 %r1396,%r484; setp.eq.u16 %r1397,%r1396,46; @ %r1397 bra $L548; .loc 1 3186 0 add.u32 %r713,%r484,1; .loc 1 3187 0 st.u8 [%r490],%r713; .loc 1 3188 0 setp.gt.s32 %r1398,%r713,57; @ ! %r1398 bra $L527; .loc 1 3190 0 mov.u32 %r1403,48; bra $L549; $L547: .loc 1 3167 0 mov.u32 %r1399,49; st.u8 [%r706+-2],%r1399; .loc 1 3168 0 add.u32 %r529,%r529,1; bra $L527; $L548: .loc 1 3174 0 ld.s8 %r524,[%r490+-1]; .loc 1 3175 0 add.u32 %r525,%r524,1; .loc 1 3178 0 setp.gt.s32 %r1400,%r525,57; @ %r1400 bra $L550; .loc 1 3176 0 st.u8 [%r490+-1],%r525; bra $L527; $L550: .loc 1 3180 0 add.u32 %r529,%r529,1; .loc 1 3181 0 mov.u32 %r1401,49; st.u8 [%r490+-1],%r1401; bra $L527; $L688: .loc 1 3186 0 add.u32 %r527,%r520,1; .loc 1 3187 0 st.u8 [%r490],%r527; .loc 1 3188 0 setp.le.s32 %r1402,%r527,57; @ %r1402 bra $L527; $L549: .loc 1 3190 0 st.u8 [%r490],%r1403; .loc 1 3161 0 add.u64 %r490,%r490,-1; ld.u8 %r1596,[%r490]; mov.u16 %r1406,%r1596; and.b16 %r1405,%r1406,127; cvt.u32.u16 %r1407,%r1405; cvt.s32.s8 %r520,%r1407; .loc 1 3171 0 cvt.u16.u32 %r1408,%r520; setp.eq.u16 %r1409,%r1408,46; @ ! %r1409 bra $L688; bra $L548; $L594: .loc 1 3114 0 add.u64 %r510,%frame,83; $L527: .loc 1 3201 0 st.u32 [%stack],%r529; cvta.const.u64 %r1411,$LC4; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r510; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1411; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1412,[%value_in]; } $L422: .loc 1 3204 0 st.u32 [%frame+4],%r323; .loc 1 3205 0 st.u32 [%frame+16],%r529; .loc 1 501 0 ld.u16 %r1415,[%frame+312]; and.b16 %r1414,%r1415,32767; setp.ne.u16 %r1416,%r1414,32767; @ %r1416 bra $L552; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r1419,[%value_in]; } .loc 1 2768 0 setp.ne.u32 %r1420,%r1419,0; @ %r1420 bra $L553; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r1423,[%value_in]; } setp.eq.u32 %r1424,%r1423,0; @ %r1424 bra $L552; $L553: .loc 1 2770 0 mov.u32 %r1425,9999; st.u32 [%r744],%r1425; .loc 1 2771 0 bra $L554; $L552: .loc 1 2773 0 add.u32 %r1426,%r529,1; st.u32 [%r744],%r1426; .loc 1 2779 0 ld.s8 %r722,[%frame+80]; setp.eq.u32 %r1427,%r722,0; @ %r1427 bra $L595; .loc 1 2781 0 cvt.u16.u32 %r1428,%r722; setp.eq.u16 %r1429,%r1428,46; @ %r1429 bra $L596; .loc 1 2778 0 mov.u64 %r316,%r1550; bra $L557; $L558: .loc 1 2781 0 cvt.u16.u32 %r1430,%r278; setp.eq.u16 %r1431,%r1430,46; @ %r1431 bra $L556; $L557: .loc 1 2783 0 add.u64 %r316,%r316,1; .loc 1 2779 0 ld.s8 %r278,[%r316]; setp.ne.u32 %r1432,%r278,0; @ %r1432 bra $L558; bra $L559; $L560: .loc 1 2792 0 ld.s8 %r279,[%r604]; cvt.u32.u32 %r1433,%r279; st.u8 [%r316],%r1433; .loc 1 2793 0 mov.u64 %r316,%r1543; add.u64 %r604,%r604,1; .loc 1 2790 0 setp.ne.u32 %r1434,%r279,0; @ ! %r1434 bra $L559; add.u64 %r1543,%r1543,1; bra $L560; $L561: .loc 1 2800 0 add.u64 %r316,%r316,-1; .loc 1 2799 0 ld.s8 %r1437,[%r316]; cvt.u16.u32 %r1436,%r1437; set.u32.ne.u16 %r1438,%r1436,69; neg.s32 %r1439,%r1438; set.u32.gt.u64 %r1442,%r316,%r1550; neg.s32 %r1443,%r1442; cvt.u16.u32 %r1445,%r1439; cvt.u16.u32 %r1446,%r1443; and.b16 %r1444,%r1445,%r1446; cvt.u32.u16 %r1447,%r1444; cvt.u16.u8 %r1448,%r1447; setp.ne.u16 %r1449,%r1448,0; @ %r1449 bra $L561; bra $L555; $L559: setp.gt.u64 %r1451,%r316,%r1550; @ %r1451 bra $L561; bra $L555; $L595: .loc 1 2778 0 mov.u64 %r316,%r1550; $L555: .loc 1 2801 0 mov.u32 %r1452,0; st.u8 [%r316],%r1452; $L554: .loc 1 2807 0 ld.s8 %r664,[%frame+80]; cvt.u16.u32 %r1454,%r664; set.u32.eq.u16 %r1455,%r1454,32; neg.s32 %r1456,%r1455; set.u32.eq.u16 %r1459,%r1454,45; neg.s32 %r1460,%r1459; cvt.u16.u32 %r1462,%r1456; cvt.u16.u32 %r1463,%r1460; or.b16 %r1461,%r1462,%r1463; cvt.u32.u16 %r1464,%r1461; cvt.u16.u8 %r1465,%r1464; setp.eq.u16 %r1466,%r1465,0; @ %r1466 bra $L597; .loc 1 2806 0 mov.u64 %r320,%r1550; $L563: .loc 1 2808 0 add.u64 %r320,%r320,1; .loc 1 2807 0 ld.s8 %r664,[%r320]; cvt.u16.u32 %r1468,%r664; set.u32.eq.u16 %r1469,%r1468,32; neg.s32 %r1470,%r1469; set.u32.eq.u16 %r1473,%r1468,45; neg.s32 %r1474,%r1473; cvt.u16.u32 %r1476,%r1470; cvt.u16.u32 %r1477,%r1474; or.b16 %r1475,%r1476,%r1477; cvt.u32.u16 %r1478,%r1475; cvt.u16.u8 %r1479,%r1478; setp.ne.u16 %r1480,%r1479,0; @ %r1480 bra $L563; bra $L562; $L597: .loc 1 2806 0 mov.u64 %r320,%r1550; $L562: mov.u64 %r610,%r1550; $L565: mov.u64 %r317,%r610; .loc 1 2812 0 add.u64 %r320,%r320,1; cvt.u32.u32 %r1481,%r664; st.u8 [%r610],%r1481; add.u64 %r609,%r610,1; setp.eq.u32 %r1482,%r664,0; @ %r1482 bra $L564; ld.s8 %r664,[%r320]; mov.u64 %r610,%r609; bra $L565; $L564: ld.s8 %r663,[%r610+-1]; .loc 1 2817 0 setp.eq.u32 %r1483,%r742,2; @ %r1483 bra $L566; ld.u32 %r1484,[%frame+16]; max.s32 %r734,%r304,%r1484; .loc 1 2824 0 cvt.u16.u32 %r1485,%r663; setp.eq.u16 %r1486,%r1485,48; @ %r1486 bra $L567; bra $L568; $L599: mov.u64 %r656,1; $L570: add.u64 %r615,%r610,-2; .loc 1 2825 0 mov.u32 %r1487,0; $L571: add.u64 %r317,%r317,-1; st.u8 [%r317],%r1487; .loc 1 2824 0 ld.s8 %r1489,[%r615]; cvt.u16.u32 %r1488,%r1489; setp.eq.u16 %r1490,%r1488,48; @ %r1490 bra $L569; bra $L568; $L567: cvt.s64.s32 %r656,%r734; sub.u64 %r1491,%r610,%r1550; setp.lt.s64 %r1492,%r656,%r1491; @ %r1492 bra $L570; bra $L568; $L569: add.u64 %r615,%r615,-1; sub.u64 %r1493,%r317,%r1550; setp.gt.s64 %r1494,%r1493,%r656; @ %r1494 bra $L571; $L568: .loc 1 2829 0 setp.ne.u32 %r1495,%r742,3; @ %r1495 bra $L572; ld.u32 %r1497,[%frame+16]; add.u32 %r1496,%r304,%r1497; setp.ge.s32 %r1498,%r1496,0; @ %r1498 bra $L573; .loc 1 2832 0 mov.u32 %r1499,0; st.u8 [%frame+80],%r1499; .loc 1 2833 0 mov.u32 %r1500,0; st.u32 [%r744],%r1500; .loc 1 2831 0 mov.u64 %r317,%r1550; bra $L574; $L580: .loc 1 2845 0 mov.u32 %r1501,0; st.u32 [%r740+104],%r1501; cvt.s64.s32 %r645,%r308; setp.le.u64 %r1502,%r645,31; @ %r1502 bra $L598; mov.u32 %r620,1; .loc 1 2844 0 mov.u32 %r319,4; $L576: .loc 1 2846 0 mov.u32 %r294,%r620; .loc 1 2845 0 add.u32 %r319,%r319,%r319; add.u32 %r620,%r294,1; cvt.s64.s32 %r1504,%r319; add.u64 %r1505,%r1504,28; setp.le.u64 %r1506,%r1505,%r645; @ %r1506 bra $L576; st.u32 [%r740+104],%r294; bra $L575; $L598: mov.u32 %r294,%r1501; $L575: .loc 1 2847 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r740; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r294; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r1509,[%value_in]; } st.u64 [%r740+96],%r1509; .loc 1 2851 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1509; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1550; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r1513,[%value_in]; } .loc 1 2853 0 setp.eq.u64 %r1514,%r746,0; @ %r1514 bra $L415; .loc 1 2854 0 sub.u64 %r1516,%r317,%r1550; add.u64 %r1517,%r1509,%r1516; st.u64 [%r746],%r1517; .loc 1 2856 0 bra $L415; $L427: .loc 1 2947 0 cvt.u16.u32 %r1519,%r329; setp.eq.u16 %r1520,%r1519,32767; @ ! %r1520 bra $L689; bra $L578; $L573: ld.u32 %r1521,[%r744]; add.u32 %r743,%r743,%r1521; $L574: .loc 1 2840 0 add.u32 %r308,%r743,3; bra $L580; $L572: .loc 1 2842 0 add.u32 %r308,%r743,9; bra $L580; $L687: .loc 1 3161 0 add.u64 %r490,%r706,-2; and.b16 %r1522,%r1379,127; cvt.u32.u16 %r1524,%r1522; cvt.s32.s8 %r484,%r1524; bra $L581; $L596: .loc 1 2778 0 mov.u64 %r316,%r1550; $L556: add.u64 %r1543,%r316,1; mov.u64 %r604,%r1543; bra $L560; $L566: .loc 1 2824 0 cvt.u16.u32 %r1525,%r663; setp.ne.u16 %r1526,%r1525,48; @ %r1526 bra $L572; sub.u64 %r1527,%r610,%r1550; setp.gt.s64 %r1528,%r1527,1; @ %r1528 bra $L599; bra $L572; $L415: .loc 1 2857 0 mov.u64 %value,%r1509; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _ldcheck .visible .func (.param .u32 %value_out) _ldcheck (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[40]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r26; .reg .u64 %r27; .reg .f64 %r28; .reg .u64 %r31; .reg .u16 %r32; .reg .u16 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .pred %r37; mov.u64 %r27,%ar0; .loc 1 2875 0 ld.f64 %r28,[%r27]; st.f64 [%frame+32],%r28; .loc 1 2879 0 add.u64 %r31,%frame,32; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call e53toe$isra$9,(%out_arg1,%out_arg2); } .loc 1 2886 0 ld.u16 %r33,[%frame+18]; and.b16 %r32,%r33,32767; setp.ne.u16 %r34,%r32,32767; @ %r34 bra $L692; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r36,[%value_in]; } .loc 1 2889 0 setp.ne.u32 %r37,%r36,0; .loc 1 2892 0 selp.u32 %r26,1,2,%r37; bra $L690; $L692: .loc 1 2895 0 mov.u32 %r26,0; $L690: .loc 1 2896 0 mov.u32 %value,%r26; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _strtold .visible .func (.param .f64 %value_out) _strtold (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[360]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r156; .reg .u32 %r158; .reg .u64 %r160; .reg .u64 %r161; .reg .u32 %r162; .reg .u32 %r164; .reg .u64 %r165; .reg .u32 %r166; .reg .u64 %r167; .reg .u32 %r169; .reg .u32 %r171; .reg .u32 %r172; .reg .u32 %r175; .reg .u64 %r179; .reg .u32 %r180; .reg .u32 %r183; .reg .u64 %r184; .reg .u32 %r186; .reg .u32 %r187; .reg .u32 %r192; .reg .u64 %r193; .reg .u32 %r195; .reg .u32 %r200; .reg .u64 %r201; .reg .u32 %r203; .reg .u32 %r208; .reg .u64 %r209; .reg .u64 %r217; .reg .u64 %r219; .reg .u64 %r222; .reg .u64 %r223; .reg .u64 %r235; .reg .u64 %r238; .reg .u64 %r239; .reg .u32 %r240; .reg .u32 %r241; .reg .u32 %r244; .reg .u32 %r248; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .u32 %r257; .reg .u32 %r262; .reg .u64 %r263; .reg .u64 %r264; .reg .u32 %r265; .reg .u32 %r271; .reg .u64 %r272; .reg .u64 %r275; .reg .u64 %r280; .reg .u64 %r283; .reg .u64 %r284; .reg .u32 %r286; .reg .u32 %r291; .reg .u64 %r292; .reg .u32 %r296; .reg .u64 %r299; .reg .u64 %r306; .reg .u64 %r307; .reg .u64 %r310; .reg .u64 %r311; .reg .u32 %r312; .reg .u64 %r314; .reg .u32 %r315; .reg .u64 %r318; .reg .u64 %r321; .reg .u32 %r327; .reg .u32 %r330; .reg .u32 %r332; .reg .u32 %r333; .reg .u32 %r339; .reg .u64 %r340; .reg .u32 %r341; .reg .u64 %r355; .reg .u64 %r360; .reg .u64 %r362; .reg .u32 %r363; .reg .u32 %r364; .reg .u32 %r366; .reg .u32 %r367; .reg .u32 %r371; .reg .u32 %r372; .reg .u32 %r376; .reg .u64 %r378; .reg .u64 %r379; .reg .u64 %r380; .reg .u64 %r382; .reg .u64 %r385; .reg .u32 %r393; .reg .u32 %r394; .reg .u64 %r395; .reg .u64 %r399; .reg .f64 %r400; .reg .u64 %r401; .reg .u64 %r402; .reg .u32 %r415; .reg .u32 %r416; .reg .u64 %r418; .reg .pred %r419; .reg .u64 %r421; .reg .u64 %r422; .reg .u64 %r423; .reg .u16 %r424; .reg .u32 %r425; .reg .pred %r426; .reg .u16 %r427; .reg .u32 %r428; .reg .pred %r429; .reg .pred %r430; .reg .u32 %r431; .reg .pred %r432; .reg .u32 %r433; .reg .u64 %r434; .reg .u64 %r435; .reg .u32 %r436; .reg .pred %r437; .reg .pred %r438; .reg .u32 %r439; .reg .u32 %r440; .reg .u16 %r441; .reg .pred %r442; .reg .pred %r443; .reg .u32 %r444; .reg .u32 %r445; .reg .pred %r446; .reg .u32 %r448; .reg .u32 %r449; .reg .u16 %r452; .reg .u16 %r454; .reg .u16 %r455; .reg .u32 %r457; .reg .u16 %r458; .reg .pred %r459; .reg .u16 %r461; .reg .u16 %r462; .reg .u16 %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u16 %r467; .reg .u16 %r468; .reg .u16 %r469; .reg .u32 %r470; .reg .pred %r471; .reg .u16 %r472; .reg .u16 %r473; .reg .u16 %r474; .reg .u32 %r475; .reg .u32 %r476; .reg .pred %r477; .reg .u16 %r478; .reg .u32 %r480; .reg .u16 %r482; .reg .pred %r483; .reg .u64 %r484; .reg .u64 %r485; .reg .u64 %r486; .reg .u16 %r488; .reg .u16 %r489; .reg .u32 %r490; .reg .u16 %r491; .reg .pred %r492; .reg .u16 %r493; .reg .u32 %r494; .reg .pred %r495; .reg .u32 %r496; .reg .u16 %r497; .reg .u32 %r498; .reg .pred %r499; .reg .u16 %r500; .reg .pred %r501; .reg .pred %r502; .reg .pred %r503; .reg .u16 %r504; .reg .pred %r505; .reg .u16 %r506; .reg .u16 %r507; .reg .u16 %r508; .reg .u16 %r509; .reg .u16 %r510; .reg .u16 %r511; .reg .pred %r512; .reg .u16 %r514; .reg .u16 %r516; .reg .u16 %r517; .reg .pred %r520; .reg .u16 %r521; .reg .pred %r522; .reg .u16 %r523; .reg .u16 %r524; .reg .pred %r525; .reg .u16 %r526; .reg .u16 %r527; .reg .u16 %r528; .reg .u16 %r529; .reg .u16 %r530; .reg .u16 %r531; .reg .pred %r532; .reg .u16 %r534; .reg .u16 %r536; .reg .u16 %r537; .reg .pred %r540; .reg .u16 %r541; .reg .pred %r542; .reg .u16 %r543; .reg .u16 %r544; .reg .u16 %r545; .reg .u16 %r546; .reg .u16 %r547; .reg .u16 %r548; .reg .pred %r549; .reg .u16 %r551; .reg .u16 %r553; .reg .u16 %r554; .reg .pred %r557; .reg .u64 %r558; .reg .u64 %r559; .reg .u64 %r560; .reg .u64 %r561; .reg .u64 %r562; .reg .u32 %r564; .reg .pred %r567; .reg .u16 %r568; .reg .pred %r569; .reg .u64 %r570; .reg .u64 %r571; .reg .u64 %r572; .reg .u64 %r573; .reg .u64 %r574; .reg .u32 %r576; .reg .pred %r579; .reg .pred %r580; .reg .u16 %r581; .reg .pred %r582; .reg .pred %r584; .reg .pred %r586; .reg .pred %r588; .reg .pred %r590; .reg .pred %r592; .reg .pred %r594; .reg .pred %r596; .reg .pred %r598; .reg .pred %r600; .reg .pred %r602; .reg .pred %r604; .reg .pred %r606; .reg .pred %r608; .reg .pred %r610; .reg .pred %r612; .reg .pred %r613; .reg .pred %r614; .reg .pred %r615; .reg .u16 %r616; .reg .u16 %r617; .reg .u16 %r618; .reg .u16 %r628; .reg .u16 %r629; .reg .pred %r630; .reg .u16 %r631; .reg .pred %r632; .reg .u32 %r634; .reg .u32 %r635; .reg .u32 %r636; .reg .u32 %r637; .reg .pred %r638; .reg .pred %r639; .reg .u16 %r641; .reg .u16 %r642; .reg .u16 %r643; .reg .u32 %r644; .reg .pred %r645; .reg .pred %r646; .reg .pred %r647; .reg .u16 %r648; .reg .pred %r649; .reg .u16 %r650; .reg .u16 %r651; .reg .u16 %r652; .reg .pred %r653; .reg .u16 %r654; .reg .u16 %r655; .reg .pred %r656; .reg .pred %r657; .reg .u16 %r658; .reg .pred %r659; .reg .u16 %r660; .reg .u16 %r661; .reg .pred %r662; .reg .u16 %r663; .reg .u16 %r664; .reg .u16 %r665; .reg .u16 %r666; .reg .u16 %r667; .reg .u16 %r668; .reg .pred %r669; .reg .u16 %r671; .reg .u16 %r673; .reg .u16 %r674; .reg .pred %r677; .reg .u16 %r678; .reg .pred %r679; .reg .u16 %r680; .reg .u16 %r681; .reg .u16 %r682; .reg .u16 %r683; .reg .u16 %r684; .reg .u16 %r685; .reg .pred %r686; .reg .u16 %r688; .reg .u16 %r690; .reg .u16 %r691; .reg .pred %r694; .reg .u64 %r695; .reg .u64 %r696; .reg .u64 %r697; .reg .u64 %r698; .reg .u64 %r699; .reg .u32 %r701; .reg .pred %r704; .reg .u16 %r705; .reg .pred %r706; .reg .u16 %r707; .reg .u16 %r708; .reg .u16 %r709; .reg .u16 %r710; .reg .u16 %r711; .reg .u16 %r712; .reg .pred %r713; .reg .u16 %r715; .reg .u16 %r717; .reg .u16 %r718; .reg .pred %r721; .reg .u16 %r722; .reg .pred %r723; .reg .u16 %r724; .reg .pred %r725; .reg .pred %r727; .reg .u16 %r728; .reg .pred %r729; .reg .u32 %r732; .reg .pred %r733; .reg .u16 %r734; .reg .pred %r735; .reg .u16 %r736; .reg .u16 %r737; .reg .u32 %r740; .reg .u32 %r742; .reg .u32 %r745; .reg .u32 %r746; .reg .u64 %r747; .reg .pred %r749; .reg .pred %r750; .reg .pred %r751; .reg .u64 %r752; .reg .u64 %r755; .reg .u32 %r762; .reg .u32 %r763; .reg .u16 %r764; .reg .pred %r765; .reg .u32 %r766; .reg .pred %r767; .reg .pred %r777; .reg .pred %r782; .reg .u64 %r783; .reg .u32 %r790; .reg .u64 %r791; .reg .u32 %r798; .reg .u32 %r799; .reg .u32 %r802; .reg .u32 %r804; .reg .u64 %r807; .reg .u16 %r809; .reg .u16 %r810; .reg .u16 %r811; .reg .u16 %r812; .reg .pred %r813; .reg .u16 %r815; .reg .pred %r816; .reg .pred %r817; .reg .pred %r818; .reg .u16 %r822; .reg .pred %r823; .reg .u16 %r824; .reg .u16 %r825; .reg .u64 %r826; .reg .pred %r832; .reg .u32 %r834; .reg .u32 %r836; .reg .u32 %r838; .reg .u32 %r840; .reg .u32 %r841; .reg .u16 %r842; .reg .u16 %r843; .reg .u16 %r844; .reg .u16 %r845; .reg .u16 %r846; .reg .u16 %r847; .reg .u16 %r848; .reg .u64 %r849; .reg .u64 %r850; .reg .u64 %r851; .reg .u64 %r853; .reg .u64 %r854; .reg .u64 %r855; .reg .u64 %r857; .reg .u64 %r858; .reg .u64 %r859; .reg .u64 %r861; .reg .u64 %r862; .reg .pred %r864; .reg .pred %r866; .reg .u64 %r867; .reg .u32 %r868; .reg .u32 %r869; .reg .u64 %r870; .reg .u64 %r871; .reg .pred %r873; .reg .u32 %r878; .reg .u32 %r881; .reg .u32 %r882; .reg .u64 %r883; .reg .u32 %r887; .reg .pred %r888; .reg .u32 %r891; .reg .u32 %r893; .reg .u32 %r896; .reg .u32 %r897; .reg .u64 %r898; .reg .u32 %r902; .reg .pred %r903; .reg .u32 %r906; .reg .u32 %r908; .reg .u32 %r911; .reg .u32 %r912; .reg .u64 %r913; .reg .u32 %r917; .reg .pred %r918; .reg .u64 %r919; .reg .u64 %r920; .reg .u64 %r921; .reg .u64 %r922; .reg .u64 %r923; .reg .u64 %r924; .reg .u64 %r925; .reg .u64 %r926; .reg .u64 %r927; .reg .u64 %r928; .reg .u32 %r937; .reg .u64 %r938; .reg .u64 %r939; .reg .u64 %r940; .reg .u64 %r941; .reg .u64 %r942; .reg .u64 %r943; .reg .u64 %r944; .reg .u64 %r945; mov.u64 %r401,%ar0; mov.u64 %r402,%ar1; .loc 1 3237 0 mov.u32 %r415,-1; st.u32 [%frame+200],%r415; .loc 1 3238 0 mov.u32 %r416,144; st.u32 [%frame+204],%r416; .loc 1 3263 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r401; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r418,[%value_in]; } cvt.u32.u64 %r156,%r418; add.u32 %r158,%r156,2; .loc 1 3264 0 setp.le.s32 %r419,%r158,200; @ %r419 bra $L797; .loc 1 3268 0 cvt.s64.s32 %r422,%r158; mov.u64 %r421,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r422; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r421; call (%value_in),calloc,(%out_arg1,%out_arg2); ld.param.u64 %r423,[%value_in]; } mov.u64 %r160,%r423; .loc 1 3269 0 cvt.u32.u64 %r330,%r421; bra $L695; $L797: .loc 1 3259 0 mov.u32 %r330,0; .loc 1 3265 0 mov.u64 %r160,%frame; $L695: .loc 1 3273 0 ld.s8 %r425,[%r401]; cvt.u16.u32 %r424,%r425; setp.ne.u16 %r426,%r424,32; @ %r426 bra $L798; mov.u64 %r161,%r401; .loc 1 3272 0 mov.u32 %r162,0; $L697: .loc 1 3275 0 add.u64 %r161,%r161,1; .loc 1 3276 0 add.u32 %r162,%r162,1; .loc 1 3273 0 ld.s8 %r428,[%r161]; cvt.u16.u32 %r427,%r428; setp.eq.u16 %r429,%r427,32; @ %r429 bra $L697; mov.u32 %r341,%r162; bra $L696; $L798: mov.u64 %r161,%r401; mov.u32 %r341,0; $L696: .loc 1 3279 0 setp.le.s32 %r430,%r158,0; @ %r430 bra $L799; .loc 1 3281 0 add.u64 %r395,%r161,1; add.u64 %r165,%r160,1; ld.s8 %r393,[%r161]; cvt.u32.u32 %r431,%r393; st.u8 [%r160],%r431; setp.eq.u32 %r432,%r393,0; @ %r432 bra $L698; mov.u64 %r252,%r165; mov.u64 %r251,%r395; add.u32 %r433,%r156,1; cvt.u64.u32 %r434,%r433; add.u64 %r435,%r434,1; add.u64 %r217,%r160,%r435; bra $L699; $L700: add.u64 %r252,%r165,1; ld.s8 %r164,[%r251]; cvt.u32.u32 %r436,%r164; st.u8 [%r165],%r436; add.u64 %r251,%r251,1; setp.eq.u32 %r437,%r164,0; @ %r437 bra $L800; $L699: mov.u64 %r165,%r252; .loc 1 3279 0 setp.ne.u64 %r438,%r217,%r165; @ %r438 bra $L700; bra $L698; $L799: mov.u64 %r165,%r160; bra $L698; $L800: .loc 1 3281 0 mov.u64 %r165,%r252; $L698: .loc 1 3284 0 mov.u32 %r439,0; st.u8 [%r165],%r439; .loc 1 3287 0 ld.u32 %r166,[%frame+204]; .loc 1 3288 0 mov.u32 %r440,144; st.u32 [%frame+204],%r440; add.u64 %r920,%frame,332; mov.u64 %r355,%r920; add.u64 %r253,%frame,358; mov.u64 %r264,%r920; .loc 1 672 0 mov.u16 %r441,0; $L701: st.u16 [%r264],%r441; add.u64 %r264,%r264,2; .loc 1 671 0 setp.ne.u64 %r442,%r253,%r264; @ %r442 bra $L701; mov.u64 %r167,%r160; .loc 1 3290 0 mov.u32 %r332,0; .loc 1 3297 0 mov.u32 %r175,%r332; .loc 1 3289 0 mov.u32 %r240,%r332; .loc 1 3295 0 mov.u32 %r172,%r332; .loc 1 3293 0 mov.u32 %r186,%r332; .loc 1 3292 0 mov.u32 %r241,%r332; .loc 1 3291 0 mov.u32 %r171,%r332; .loc 1 804 0 add.u64 %r939,%frame,356; add.u64 %r940,%frame,334; add.u64 %r941,%frame,306; add.u64 %r942,%r920,24; add.u64 %r943,%frame,330; add.u64 %r944,%frame,308; add.u64 %r945,%frame,332; $L702: .loc 1 3300 0 ld.s8 %r366,[%r167]; add.u32 %r169,%r366,-48; .loc 1 3301 0 setp.gt.u32 %r443,%r169,9; @ %r443 bra $L703; .loc 1 3304 0 or.b32 %r444,%r171,%r172; or.b32 %r445,%r444,%r169; setp.eq.u32 %r446,%r445,0; @ %r446 bra $L704; .loc 1 3307 0 set.u32.eq.u32 %r448,%r175,0; neg.s32 %r449,%r448; cvt.u16.u32 %r452,%r171; cvt.u16.u32 %r455,%r449; and.b16 %r454,%r455,%r452; cvt.u32.u16 %r457,%r454; cvt.u16.u8 %r458,%r457; setp.eq.u16 %r459,%r458,0; @ %r459 bra $L705; .loc 1 3310 0 cvt.u16.u32 %r462,%r366; add.u16 %r461,%r462,-48; cvt.u32.u16 %r464,%r461; cvt.u16.u8 %r463,%r464; setp.gt.u16 %r465,%r463,9; @ %r465 bra $L801; mov.u64 %r179,%r167; $L707: .loc 1 3311 0 add.u64 %r179,%r179,1; .loc 1 3310 0 ld.s8 %r180,[%r179]; cvt.u16.u32 %r468,%r180; add.u16 %r467,%r468,-48; cvt.u32.u16 %r470,%r467; cvt.u16.u8 %r469,%r470; setp.le.u16 %r471,%r469,9; @ %r471 bra $L707; bra $L706; $L801: mov.u32 %r180,%r366; mov.u64 %r179,%r167; $L706: .loc 1 3314 0 cvt.u16.u32 %r473,%r180; and.b16 %r472,%r473,95; cvt.u32.u16 %r476,%r472; cvt.s32.s8 %r475,%r476; cvt.u16.u32 %r474,%r475; setp.eq.u16 %r477,%r474,69; @ %r477 bra $L708; and.b16 %r478,%r473,127; cvt.u32.u16 %r480,%r478; cvt.s32.s8 %r183,%r480; cvt.u32.u8 %r394,%r480; cvt.u16.u32 %r482,%r183; setp.gt.s16 %r483,%r482,44; @ %r483 bra $L709; mov.u64 %r485,17596481020929; shr.u64 %r484,%r485,%r394; not.b64 %r486,%r484; cvt.u16.u64 %r489,%r486; and.b16 %r488,%r489,1; .loc 1 3315 0 cvt.u32.u16 %r490,%r488; cvt.u16.u8 %r491,%r490; setp.ne.u16 %r492,%r491,0; @ %r492 bra $L709; $L708: .loc 1 3318 0 add.u64 %r184,%r179,-1; .loc 1 3319 0 ld.s8 %r494,[%r179+-1]; cvt.u16.u32 %r493,%r494; setp.ne.u16 %r495,%r493,48; @ %r495 bra $L710; mov.u64 %r275,%r184; .loc 1 3320 0 mov.u32 %r496,122; $L711: add.u64 %r184,%r184,-1; st.u8 [%r275],%r496; add.u64 %r275,%r275,-1; .loc 1 3319 0 ld.s8 %r498,[%r184]; cvt.u16.u32 %r497,%r498; setp.eq.u16 %r499,%r497,48; @ %r499 bra $L711; ld.s8 %r366,[%r167]; $L710: .loc 1 3322 0 cvt.u16.u32 %r500,%r366; setp.eq.u16 %r501,%r500,122; @ %r501 bra $L802; .loc 1 3321 0 mov.u32 %r175,1; $L705: .loc 1 3330 0 ld.u16 %r208,[%frame+336]; setp.ne.u32 %r502,%r208,0; @ %r502 bra $L712; .loc 1 3332 0 setp.eq.u32 %r503,%r171,0; @ %r503 bra $L713; .loc 1 3333 0 add.u32 %r186,%r186,1; $L713: .loc 1 805 0 mov.u32 %r192,%r208; .loc 1 804 0 mov.u64 %r193,%r939; $L717: .loc 1 809 0 ld.u16 %r187,[%r193]; cvt.u16.u32 %r504,%r187; setp.ge.s16 %r505,%r504,0; @ %r505 bra $L714; .loc 1 810 0 cvt.u16.u32 %r507,%r192; or.b16 %r506,%r507,1; cvt.u32.u16 %r192,%r506; $L714: .loc 1 811 0 cvt.u16.u32 %r508,%r187; add.u16 %r509,%r508,%r508; .loc 1 812 0 cvt.u16.u32 %r511,%r192; and.b16 %r510,%r511,2; setp.ne.u16 %r512,%r510,0; @ %r512 bra $L715; .loc 1 811 0 st.u16 [%r193],%r509; bra $L716; $L715: .loc 1 813 0 or.b16 %r514,%r509,1; st.u16 [%r193],%r514; $L716: .loc 1 814 0 cvt.u16.u32 %r516,%r192; add.u16 %r517,%r516,%r516; cvt.u32.u16 %r192,%r517; .loc 1 815 0 add.u64 %r193,%r193,-2; .loc 1 807 0 setp.ne.u64 %r520,%r193,%r940; @ %r520 bra $L717; mov.u64 %r340,%r941; mov.u64 %r299,%r941; mov.u64 %r307,%r920; $L718: .loc 1 696 0 ld.u16 %r521,[%r307]; st.u16 [%r299],%r521; add.u64 %r307,%r307,2; add.u64 %r299,%r299,2; .loc 1 695 0 setp.ne.u64 %r522,%r942,%r307; @ %r522 bra $L718; .loc 1 698 0 mov.u16 %r523,0; st.u16 [%frame+330],%r523; .loc 1 805 0 mov.u32 %r200,%r208; .loc 1 804 0 mov.u64 %r201,%r943; $L722: .loc 1 809 0 ld.u16 %r195,[%r201]; cvt.u16.u32 %r524,%r195; setp.ge.s16 %r525,%r524,0; @ %r525 bra $L719; .loc 1 810 0 cvt.u16.u32 %r527,%r200; or.b16 %r526,%r527,1; cvt.u32.u16 %r200,%r526; $L719: .loc 1 811 0 cvt.u16.u32 %r528,%r195; add.u16 %r529,%r528,%r528; .loc 1 812 0 cvt.u16.u32 %r531,%r200; and.b16 %r530,%r531,2; setp.ne.u16 %r532,%r530,0; @ %r532 bra $L720; .loc 1 811 0 st.u16 [%r201],%r529; bra $L721; $L720: .loc 1 813 0 or.b16 %r534,%r529,1; st.u16 [%r201],%r534; $L721: .loc 1 814 0 cvt.u16.u32 %r536,%r200; add.u16 %r537,%r536,%r536; cvt.u32.u16 %r200,%r537; .loc 1 815 0 add.u64 %r201,%r201,-2; .loc 1 807 0 setp.ne.u64 %r540,%r201,%r944; @ %r540 bra $L722; .loc 1 804 0 mov.u64 %r209,%r943; $L726: .loc 1 809 0 ld.u16 %r203,[%r209]; cvt.u16.u32 %r541,%r203; setp.ge.s16 %r542,%r541,0; @ %r542 bra $L723; .loc 1 810 0 cvt.u16.u32 %r544,%r208; or.b16 %r543,%r544,1; cvt.u32.u16 %r208,%r543; $L723: .loc 1 811 0 cvt.u16.u32 %r545,%r203; add.u16 %r546,%r545,%r545; .loc 1 812 0 cvt.u16.u32 %r548,%r208; and.b16 %r547,%r548,2; setp.ne.u16 %r549,%r547,0; @ %r549 bra $L724; .loc 1 811 0 st.u16 [%r209],%r546; bra $L725; $L724: .loc 1 813 0 or.b16 %r551,%r546,1; st.u16 [%r209],%r551; $L725: .loc 1 814 0 cvt.u16.u32 %r553,%r208; add.u16 %r554,%r553,%r553; cvt.u32.u16 %r208,%r554; .loc 1 815 0 add.u64 %r209,%r209,-2; .loc 1 807 0 setp.ne.u64 %r557,%r209,%r944; @ %r557 bra $L726; .loc 1 913 0 mov.u32 %r327,0; .loc 1 912 0 mov.u64 %r223,%r939; .loc 1 911 0 mov.u64 %r222,%r943; $L727: .loc 1 916 0 ld.u16 %r558,[%r222]; ld.u16 %r559,[%r223]; add.u64 %r560,%r558,%r559; cvt.u64.u32 %r561,%r327; add.u64 %r219,%r560,%r561; .loc 1 921 0 st.u16 [%r223],%r219; .loc 1 922 0 add.u64 %r222,%r222,-2; .loc 1 923 0 add.u64 %r223,%r223,-2; .loc 1 917 0 shr.u64 %r562,%r219,16; cvt.u32.u64 %r564,%r562; and.b32 %r327,%r564,1; .loc 1 914 0 setp.ne.u64 %r567,%r222,%r944; @ %r567 bra $L727; .loc 1 672 0 mov.u16 %r568,0; $L728: st.u16 [%r340],%r568; add.u64 %r340,%r340,2; .loc 1 671 0 setp.ne.u64 %r569,%r945,%r340; @ %r569 bra $L728; .loc 1 3340 0 st.u16 [%frame+328],%r169; .loc 1 913 0 mov.u32 %r367,0; .loc 1 912 0 mov.u64 %r239,%r939; .loc 1 911 0 mov.u64 %r238,%r943; $L729: .loc 1 916 0 ld.u16 %r570,[%r238]; ld.u16 %r571,[%r239]; add.u64 %r572,%r570,%r571; cvt.u64.u32 %r573,%r367; add.u64 %r235,%r572,%r573; .loc 1 921 0 st.u16 [%r239],%r235; .loc 1 922 0 add.u64 %r238,%r238,-2; .loc 1 923 0 add.u64 %r239,%r239,-2; .loc 1 917 0 shr.u64 %r574,%r235,16; cvt.u32.u64 %r576,%r574; and.b32 %r367,%r576,1; .loc 1 914 0 setp.ne.u64 %r579,%r238,%r944; @ %r579 bra $L729; bra $L730; $L712: .loc 1 3346 0 or.b32 %r240,%r240,%r169; .loc 1 3348 0 setp.ne.u32 %r580,%r171,0; @ %r580 bra $L730; .loc 1 3349 0 add.u32 %r186,%r186,-1; $L730: .loc 1 3351 0 add.u32 %r172,%r172,1; bra $L704; $L703: .loc 1 3355 0 cvt.u16.u32 %r581,%r366; setp.eq.u16 %r582,%r581,45; @ %r582 bra $L731; setp.gt.s16 %r584,%r581,45; @ %r584 bra $L732; setp.eq.u16 %r586,%r581,13; @ %r586 bra $L803; setp.gt.s16 %r588,%r581,13; @ %r588 bra $L734; setp.eq.u16 %r590,%r581,0; @ %r590 bra $L803; setp.eq.u16 %r592,%r581,10; @ ! %r592 bra $L709; bra $L803; $L734: setp.eq.u16 %r594,%r581,43; @ %r594 bra $L735; setp.gt.s16 %r596,%r581,43; @ %r596 bra $L803; setp.eq.u16 %r598,%r581,32; @ ! %r598 bra $L709; bra $L803; $L732: setp.eq.u16 %r600,%r581,73; @ %r600 bra $L736; setp.gt.s16 %r602,%r581,73; @ %r602 bra $L737; setp.eq.u16 %r604,%r581,46; @ %r604 bra $L738; setp.eq.u16 %r606,%r581,69; @ %r606 bra $L739; bra $L709; $L737: setp.eq.u16 %r608,%r581,105; @ %r608 bra $L736; setp.eq.u16 %r610,%r581,122; @ %r610 bra $L704; setp.eq.u16 %r612,%r581,101; @ ! %r612 bra $L709; bra $L739; $L738: .loc 1 3363 0 setp.ne.u32 %r613,%r171,0; @ %r613 bra $L709; .loc 1 3365 0 mov.u32 %r171,1; bra $L704; $L731: .loc 1 3369 0 setp.ne.u32 %r614,%r241,0; @ %r614 bra $L804; .loc 1 3368 0 mov.u32 %r332,65535; .loc 1 3371 0 mov.u32 %r241,1; bra $L704; $L735: .loc 1 3374 0 setp.eq.u32 %r615,%r241,0; @ %r615 bra $L805; bra $L709; $L804: .loc 1 3368 0 mov.u32 %r332,65535; $L709: .loc 1 3762 0 mov.u16 %r616,32767; st.u16 [%frame+334],%r616; .loc 1 3763 0 mov.u16 %r617,0; st.u16 [%frame+336],%r617; .loc 1 3765 0 mov.u16 %r618,-16384; st.u16 [%frame+338],%r618; .loc 1 3767 0 st.u16 [%frame+340],%r617; st.u16 [%frame+342],%r617; st.u16 [%frame+344],%r617; st.u16 [%frame+346],%r617; st.u16 [%frame+348],%r617; st.u16 [%frame+350],%r617; st.u16 [%frame+352],%r617; st.u16 [%frame+354],%r617; .loc 1 3773 0 st.u16 [%frame+356],%r617; .loc 1 3536 0 st.u32 [%frame+204],%r166; .loc 1 3537 0 cvt.u16.u32 %r628,%r332; st.u16 [%frame+332],%r628; mov.u32 %r371,32767; bra $L740; $L802: .loc 1 3321 0 mov.u32 %r171,1; .loc 1 3322 0 mov.u32 %r175,%r171; bra $L704; $L805: .loc 1 3376 0 mov.u32 %r241,1; $L704: .loc 1 3398 0 add.u64 %r167,%r167,1; bra $L702; $L739: .loc 1 3408 0 ld.s8 %r339,[%r167+1]; cvt.u16.u32 %r629,%r339; setp.eq.u16 %r630,%r629,45; @ %r630 bra $L741; .loc 1 3406 0 add.u64 %r167,%r167,1; .loc 1 3404 0 mov.u32 %r248,1; bra $L742; $L741: ld.s8 %r339,[%r167+2]; .loc 1 3411 0 add.u64 %r167,%r167,2; .loc 1 3410 0 mov.u32 %r248,-1; $L742: .loc 1 3413 0 cvt.u16.u32 %r631,%r339; setp.ne.u16 %r632,%r631,43; @ %r632 bra $L743; ld.s8 %r339,[%r167+1]; .loc 1 3414 0 add.u64 %r167,%r167,1; bra $L743; $L747: .loc 1 3417 0 shl.b32 %r634,%r244,2; add.u32 %r635,%r634,%r244; add.u32 %r636,%r635,%r635; .loc 1 3418 0 add.u64 %r167,%r167,1; add.u32 %r637,%r339,-48; add.u32 %r244,%r637,%r636; .loc 1 3419 0 setp.gt.s32 %r638,%r244,4977; @ %r638 bra $L744; ld.s8 %r339,[%r167]; bra $L745; $L744: .loc 1 3421 0 setp.eq.u32 %r639,%r248,-1; @ ! %r639 bra $L736; bra $L746; $L743: .loc 1 3414 0 mov.u32 %r244,0; $L745: .loc 1 3415 0 cvt.u16.u32 %r642,%r339; add.u16 %r641,%r642,-48; cvt.u32.u16 %r644,%r641; cvt.u16.u8 %r643,%r644; setp.le.u16 %r645,%r643,9; @ %r645 bra $L747; .loc 1 3427 0 setp.ne.u32 %r646,%r248,-1; @ %r646 bra $L748; .loc 1 3436 0 setp.gt.s32 %r647,%r244,4977; @ %r647 bra $L746; .loc 1 3428 0 neg.s32 %r244,%r244; bra $L733; $L736: .loc 1 672 0 mov.u16 %r648,0; $L749: st.u16 [%r355],%r648; add.u64 %r355,%r355,2; .loc 1 671 0 setp.ne.u64 %r649,%r264,%r355; @ %r649 bra $L749; .loc 1 3433 0 mov.u16 %r650,32767; st.u16 [%frame+334],%r650; .loc 1 3536 0 st.u32 [%frame+204],%r166; .loc 1 3537 0 cvt.u16.u32 %r651,%r332; st.u16 [%frame+332],%r651; mov.u32 %r371,32767; bra $L740; $L746: .loc 1 672 0 mov.u16 %r652,0; $L750: st.u16 [%r355],%r652; add.u64 %r355,%r355,2; .loc 1 671 0 setp.ne.u64 %r653,%r264,%r355; @ %r653 bra $L750; ld.u16 %r371,[%frame+334]; cvt.u16.u32 %r655,%r371; and.b16 %r654,%r655,32767; cvt.u32.u16 %r372,%r654; bra $L751; $L803: .loc 1 3294 0 mov.u32 %r244,0; $L733: .loc 1 3444 0 sub.u32 %r296,%r244,%r186; .loc 1 3446 0 setp.le.s32 %r656,%r296,0; @ %r656 bra $L752; ld.u16 %r333,[%frame+336]; setp.ne.u32 %r657,%r333,0; @ %r657 bra $L753; add.u64 %r922,%frame,356; add.u64 %r921,%frame,334; add.u64 %r927,%frame,306; add.u64 %r923,%r920,24; add.u64 %r919,%frame,330; add.u64 %r928,%frame,308; .loc 1 698 0 cvt.u16.u32 %r660,%r333; .loc 1 913 0 mov.u32 %r937,%r333; add.u64 %r938,%frame,330; $L771: mov.u64 %r379,%r927; .loc 1 3294 0 mov.u64 %r360,%r927; mov.u64 %r362,%r920; $L754: .loc 1 696 0 ld.u16 %r658,[%r362]; st.u16 [%r360],%r658; add.u64 %r362,%r362,2; add.u64 %r360,%r360,2; .loc 1 695 0 setp.ne.u64 %r659,%r923,%r362; @ %r659 bra $L754; .loc 1 698 0 st.u16 [%frame+330],%r660; .loc 1 805 0 mov.u32 %r262,%r333; .loc 1 804 0 mov.u64 %r263,%r919; $L758: .loc 1 809 0 ld.u16 %r257,[%r263]; cvt.u16.u32 %r661,%r257; setp.ge.s16 %r662,%r661,0; @ %r662 bra $L755; .loc 1 810 0 cvt.u16.u32 %r664,%r262; or.b16 %r663,%r664,1; cvt.u32.u16 %r262,%r663; $L755: .loc 1 811 0 cvt.u16.u32 %r665,%r257; add.u16 %r666,%r665,%r665; .loc 1 812 0 cvt.u16.u32 %r668,%r262; and.b16 %r667,%r668,2; setp.ne.u16 %r669,%r667,0; @ %r669 bra $L756; .loc 1 811 0 st.u16 [%r263],%r666; bra $L757; $L756: .loc 1 813 0 or.b16 %r671,%r666,1; st.u16 [%r263],%r671; $L757: .loc 1 814 0 cvt.u16.u32 %r673,%r262; add.u16 %r674,%r673,%r673; cvt.u32.u16 %r262,%r674; .loc 1 815 0 add.u64 %r263,%r263,-2; .loc 1 807 0 setp.ne.u64 %r677,%r263,%r928; @ %r677 bra $L758; .loc 1 805 0 mov.u32 %r271,%r333; .loc 1 804 0 mov.u64 %r272,%r919; $L762: .loc 1 809 0 ld.u16 %r265,[%r272]; cvt.u16.u32 %r678,%r265; setp.ge.s16 %r679,%r678,0; @ %r679 bra $L759; .loc 1 810 0 cvt.u16.u32 %r681,%r271; or.b16 %r680,%r681,1; cvt.u32.u16 %r271,%r680; $L759: .loc 1 811 0 cvt.u16.u32 %r682,%r265; add.u16 %r683,%r682,%r682; .loc 1 812 0 cvt.u16.u32 %r685,%r271; and.b16 %r684,%r685,2; setp.ne.u16 %r686,%r684,0; @ %r686 bra $L760; .loc 1 811 0 st.u16 [%r272],%r683; bra $L761; $L760: .loc 1 813 0 or.b16 %r688,%r683,1; st.u16 [%r272],%r688; $L761: .loc 1 814 0 cvt.u16.u32 %r690,%r271; add.u16 %r691,%r690,%r690; cvt.u32.u16 %r271,%r691; .loc 1 815 0 add.u64 %r272,%r272,-2; .loc 1 807 0 setp.ne.u64 %r694,%r272,%r928; @ %r694 bra $L762; .loc 1 913 0 mov.u32 %r364,%r937; .loc 1 912 0 mov.u64 %r284,%r919; .loc 1 911 0 mov.u64 %r283,%r922; $L763: .loc 1 916 0 ld.u16 %r695,[%r283]; ld.u16 %r696,[%r284]; add.u64 %r697,%r695,%r696; cvt.u64.u32 %r698,%r364; add.u64 %r280,%r697,%r698; .loc 1 921 0 st.u16 [%r284],%r280; .loc 1 922 0 add.u64 %r283,%r283,-2; .loc 1 923 0 add.u64 %r284,%r284,-2; .loc 1 917 0 shr.u64 %r699,%r280,16; cvt.u32.u64 %r701,%r699; and.b32 %r364,%r701,1; .loc 1 914 0 setp.ne.u64 %r704,%r283,%r921; @ %r704 bra $L763; .loc 1 805 0 mov.u32 %r291,%r333; .loc 1 804 0 mov.u64 %r292,%r919; $L767: .loc 1 809 0 ld.u16 %r286,[%r292]; cvt.u16.u32 %r705,%r286; setp.ge.s16 %r706,%r705,0; @ %r706 bra $L764; .loc 1 810 0 cvt.u16.u32 %r708,%r291; or.b16 %r707,%r708,1; cvt.u32.u16 %r291,%r707; $L764: .loc 1 811 0 cvt.u16.u32 %r709,%r286; add.u16 %r710,%r709,%r709; .loc 1 812 0 cvt.u16.u32 %r712,%r291; and.b16 %r711,%r712,2; setp.ne.u16 %r713,%r711,0; @ %r713 bra $L765; .loc 1 811 0 st.u16 [%r292],%r710; bra $L766; $L765: .loc 1 813 0 or.b16 %r715,%r710,1; st.u16 [%r292],%r715; $L766: .loc 1 814 0 cvt.u16.u32 %r717,%r291; add.u16 %r718,%r717,%r717; cvt.u32.u16 %r291,%r718; .loc 1 815 0 add.u64 %r292,%r292,-2; .loc 1 807 0 setp.ne.u64 %r721,%r292,%r928; @ %r721 bra $L767; .loc 1 3453 0 ld.u16 %r722,[%frame+310]; setp.ne.u16 %r723,%r722,0; @ %r723 bra $L768; .loc 1 3455 0 add.u32 %r296,%r296,-1; mov.u64 %r378,%r920; $L769: .loc 1 696 0 ld.u16 %r724,[%r379]; st.u16 [%r378],%r724; add.u64 %r379,%r379,2; add.u64 %r378,%r378,2; .loc 1 695 0 setp.ne.u64 %r725,%r938,%r379; @ %r725 bra $L769; .loc 1 698 0 st.u16 [%frame+356],%r660; .loc 1 3446 0 setp.eq.u32 %r727,%r296,0; @ %r727 bra $L770; ld.u16 %r728,[%frame+336]; setp.eq.u16 %r729,%r728,0; @ %r729 bra $L771; bra $L753; $L752: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r732,[%value_in]; } setp.le.s32 %r733,%r732,144; @ %r733 bra $L772; $L792: .loc 1 672 0 mov.u16 %r734,0; $L773: st.u16 [%r355],%r734; add.u64 %r355,%r355,2; .loc 1 671 0 setp.ne.u64 %r735,%r264,%r355; @ %r735 bra $L773; ld.u16 %r371,[%frame+334]; cvt.u16.u32 %r737,%r371; and.b16 %r736,%r737,32767; cvt.u32.u16 %r372,%r736; bra $L751; $L772: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r746,16526; sub.u32 %r745,%r746,%r732; cvt.s64.s32 %r747,%r745; .loc 1 3464 0 mov.u32 %r742,64; mov.u32 %r740,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r740; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r747; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r742; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; .loc 1 3475 0 setp.eq.u32 %r749,%r296,0; @ %r749 bra $L774; add.u64 %r927,%frame,306; $L795: .loc 1 3481 0 setp.ge.s32 %r750,%r296,0; @ %r750 bra $L806; .loc 1 3485 0 setp.lt.s32 %r751,%r296,-4096; @ %r751 bra $L776; .loc 1 3483 0 neg.s32 %r296,%r296; .loc 1 3484 0 mov.u32 %r315,-1; add.u64 %r926,%frame,280; bra $L775; $L776: .loc 1 3487 0 add.u64 %r926,%frame,280; cvta.const.u64 %r752,etens; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r752; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r926; call emovi,(%out_arg1,%out_arg2); } .loc 1 3488 0 ld.u16 %r755,[%frame+282]; sub.u64 %r310,%r306,%r755; .loc 1 3489 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r926; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r920; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r925; call (%value_in),edivm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r762,[%value_in]; } .loc 1 3490 0 add.u64 %r306,%r310,16383; mov.u32 %r763,-4096; sub.u32 %r296,%r763,%r296; .loc 1 3484 0 mov.u32 %r315,-1; bra $L775; $L806: .loc 1 3480 0 mov.u32 %r315,1; add.u64 %r926,%frame,280; $L775: mov.u64 %r382,%r927; add.u64 %r380,%frame,326; mov.u32 %r363,0; cvta.const.u64 %r311,eone; $L778: .loc 1 455 0 add.u64 %r311,%r311,2; cvt.u16.u32 %r764,%r363; st.u16 [%r382],%r764; add.u64 %r382,%r382,2; .loc 1 454 0 setp.eq.u64 %r765,%r380,%r382; @ %r765 bra $L807; ld.u16 %r363,[%r311]; bra $L778; $L807: .loc 1 3494 0 cvta.const.u64 %r314,etens+240; .loc 1 3496 0 mov.u32 %r312,1; add.u64 %r924,%r314,-260; $L777: .loc 1 3499 0 and.b32 %r766,%r296,%r312; setp.eq.u32 %r767,%r766,0; @ %r767 bra $L779; .loc 1 3500 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r314; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r927; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r927; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r925; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } $L779: .loc 1 3501 0 add.u64 %r314,%r314,-20; .loc 1 3502 0 add.u32 %r312,%r312,%r312; .loc 1 3504 0 setp.ne.u64 %r777,%r314,%r924; @ %r777 bra $L777; .loc 1 3506 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r927; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r926; call emovi,(%out_arg1,%out_arg2); } .loc 1 3507 0 setp.ne.u32 %r782,%r315,-1; @ %r782 bra $L780; .loc 1 3509 0 ld.u16 %r783,[%frame+282]; sub.u64 %r318,%r306,%r783; .loc 1 3510 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r926; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r920; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r925; call (%value_in),edivm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r790,[%value_in]; } mov.u32 %r296,%r790; .loc 1 3511 0 add.u64 %r306,%r318,16383; bra $L774; $L780: .loc 1 3515 0 ld.u16 %r791,[%frame+282]; add.u64 %r321,%r791,%r306; .loc 1 3516 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r926; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r920; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r925; call (%value_in),emulm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r798,[%value_in]; } mov.u32 %r296,%r798; .loc 1 3517 0 add.u64 %r306,%r321,-16382; $L774: .loc 1 3531 0 mov.u32 %r799,53; st.u32 [%frame+204],%r799; .loc 1 3524 0 add.u64 %r807,%r306,-15360; .loc 1 3532 0 mov.u32 %r804,64; mov.u32 %r802,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r296; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r802; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r807; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r804; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } ld.u16 %r371,[%frame+334]; cvt.u16.u32 %r810,%r371; and.b16 %r809,%r810,32767; cvt.u32.u16 %r372,%r809; $L751: .loc 1 3536 0 st.u32 [%frame+204],%r166; .loc 1 3537 0 cvt.u16.u32 %r811,%r332; st.u16 [%frame+332],%r811; .loc 1 708 0 cvt.u16.u32 %r812,%r372; setp.ne.u16 %r813,%r812,32767; @ %r813 bra $L781; $L740: add.u64 %r385,%frame,338; $L783: .loc 1 712 0 ld.u16 %r815,[%r385]; setp.ne.u16 %r816,%r815,0; @ %r816 bra $L782; add.u64 %r385,%r385,2; .loc 1 710 0 setp.ne.u64 %r817,%r264,%r385; @ %r817 bra $L783; $L781: .loc 1 2116 0 setp.ne.u32 %r818,%r332,0; .loc 1 2115 0 selp.u64 %r399,-9223372036854775808,0,%r818; selp.u32 %r332,32768,%r332,%r818; .loc 1 2120 0 cvt.u16.u32 %r822,%r371; setp.le.u16 %r823,%r822,2046; @ %r823 bra $L786; .loc 1 2123 0 cvt.u16.u32 %r825,%r332; or.b16 %r824,%r825,32752; cvt.u64.u16 %r826,%r824; .loc 1 2126 0 shl.b64 %r399,%r826,48; bra $L787; $L786: .loc 1 2149 0 setp.ne.u32 %r832,%r371,0; @ %r832 bra $L788; mov.u32 %r834,4; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r834; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r836,[%value_in]; } mov.u32 %r376,%r371; bra $L789; $L788: mov.u32 %r838,5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r838; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r840,[%value_in]; } .loc 1 2155 0 shl.b32 %r841,%r371,4; cvt.u16.u32 %r842,%r841; cvt.s32.s16 %r376,%r842; $L789: .loc 1 2158 0 ld.u16 %r844,[%frame+336]; and.b16 %r843,%r844,15; cvt.u16.u32 %r846,%r376; or.b16 %r845,%r843,%r846; .loc 1 2159 0 cvt.u16.u32 %r848,%r332; or.b16 %r847,%r845,%r848; cvt.u64.u16 %r849,%r847; shl.b64 %r850,%r849,48; and.b64 %r851,%r399,281474976710655; or.b64 %r399,%r851,%r850; .loc 1 2161 0 ld.u16 %r853,[%frame+338]; shl.b64 %r854,%r853,32; and.b64 %r855,%r399,-281470681743361; or.b64 %r399,%r855,%r854; .loc 1 2162 0 ld.u16 %r857,[%frame+340]; shl.b64 %r858,%r857,16; and.b64 %r859,%r399,-4294901761; or.b64 %r399,%r859,%r858; .loc 1 2163 0 ld.u16 %r861,[%frame+342]; and.b64 %r862,%r399,-65536; or.b64 %r399,%r862,%r861; $L787: .loc 1 3568 0 setp.eq.u32 %r864,%r330,0; @ %r864 bra $L790; .loc 1 3569 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r160; call __nvptx_free,(%out_arg1); } $L790: .loc 1 3241 0 setp.eq.u64 %r866,%r402,0; @ %r866 bra $L791; .loc 1 3567 0 sub.u64 %r867,%r167,%r160; cvt.u32.u64 %r869,%r867; add.u32 %r868,%r341,%r869; .loc 1 3242 0 cvt.s64.s32 %r870,%r868; add.u64 %r871,%r401,%r870; st.u64 [%r402],%r871; $L791: .loc 1 3243 0 mov.b64 %r400,%r399; bra $L891; $L748: .loc 1 3429 0 setp.gt.s32 %r873,%r244,4932; @ %r873 bra $L736; bra $L733; $L782: .loc 1 3781 0 mov.u64 %r399,9221120237041090560; bra $L787; $L892: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r882,16526; sub.u32 %r881,%r882,%r887; cvt.s64.s32 %r883,%r881; .loc 1 3464 0 mov.u32 %r878,64; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r296; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r883; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r878; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; bra $L774; $L770: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r887,[%value_in]; } setp.gt.s32 %r888,%r887,144; @ %r888 bra $L792; bra $L892; $L893: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r897,16526; sub.u32 %r896,%r897,%r902; cvt.s64.s32 %r898,%r896; .loc 1 3464 0 mov.u32 %r893,64; mov.u32 %r891,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r891; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r898; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r893; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; .loc 1 3480 0 mov.u32 %r315,1; add.u64 %r927,%frame,306; add.u64 %r926,%frame,280; bra $L775; $L753: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r902,[%value_in]; } setp.gt.s32 %r903,%r902,144; @ %r903 bra $L792; bra $L893; $L894: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r912,16526; sub.u32 %r911,%r912,%r917; cvt.s64.s32 %r913,%r911; .loc 1 3464 0 mov.u32 %r908,64; mov.u32 %r906,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r906; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r913; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r908; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; bra $L795; $L768: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r917,[%value_in]; } setp.gt.s32 %r918,%r917,144; @ %r918 bra $L792; bra $L894; $L891: .loc 1 3244 0 mov.f64 %value,%r400; st.param.f64 [%value_out],%value; ret; } lib_a-llabs.o/ 0 0 0 644 526 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llabs .visible .func (.param .u64 %value_out) llabs (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/llabs.c" // BEGIN GLOBAL FUNCTION DEF: llabs .visible .func (.param .u64 %value_out) llabs (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; mov.u64 %r23,%ar0; .loc 1 65 0 abs.s64 %value,%r23; .loc 1 66 0 st.param.u64 [%value_out],%value; ret; } lib_a-lldiv.o/ 0 0 0 644 1250 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lldiv .visible .func lldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/stdlib/lldiv.c" // BEGIN GLOBAL FUNCTION DEF: lldiv .visible .func lldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r31; .reg .u64 %r33; .reg .u64 %r34; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u32 %r40; .reg .u16 %r41; .reg .pred %r42; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; mov.u64 %r29,%ar2; .loc 1 107 0 div.s64 %r22,%r28,%r29; .loc 1 108 0 rem.s64 %r23,%r28,%r29; .loc 1 109 0 shr.u64 %r31,%r23,63; not.b64 %r33,%r28; shr.u64 %r34,%r33,63; cvt.u16.u64 %r38,%r31; cvt.u16.u64 %r39,%r34; and.b16 %r37,%r38,%r39; cvt.u32.u16 %r40,%r37; cvt.u16.u8 %r41,%r40; setp.eq.u16 %r42,%r41,0; @ %r42 bra $L2; .loc 1 110 0 add.u64 %r22,%r22,1; .loc 1 111 0 sub.u64 %r23,%r23,%r29; $L2: .loc 1 113 0 st.u64 [%r27],%r22; st.u64 [%r27+8],%r23; .loc 1 114 0 ret; } /102 0 0 0 644 3307 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __messages_load_locale .visible .func (.param .u32 %value_out) __messages_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/locale/lmessages.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_messages_locale .visible .func (.param .u64 %value_out) __get_current_messages_locale; // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN VAR DEF: empty .global .align 1 .u8 empty[1]; // BEGIN VAR DEF: _messages_using_locale .global .align 4 .u32 _messages_using_locale[1]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[12] = {76,67,95,77,69,83,83,65,71,69,83,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {94,91,121,89,93,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[6] = {94,91,110,78,93,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {121,101,115,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[3] = {110,111,0 }; // BEGIN VAR DEF: _C_messages_locale .const .align 8 .u64 _C_messages_locale[4] = {generic($LC1),generic($LC2),generic($LC3),generic($LC4) }; // BEGIN VAR DEF: _messages_locale .global .align 8 .u64 _messages_locale[4]; // BEGIN GLOBAL FUNCTION DEF: __messages_load_locale .visible .func (.param .u32 %value_out) __messages_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r37; mov.u64 %r23,%ar0; .loc 1 91 0 cvta.global.u64 %r26,_messages_locale; cvta.global.u64 %r27,empty; st.u64 [%r26+16],%r27; .loc 1 92 0 st.u64 [%r26+24],%r27; .loc 1 94 0 mov.u32 %r35,2; mov.u32 %r34,4; cvta.const.u64 %r33,$LC0; mov.u64 %r32,0; cvta.global.u64 %r31,_messages_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r33; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r34; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r35; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r26; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r37,[%value_in]; } .loc 1 99 0 mov.u32 %value,%r37; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_messages_locale .visible .func (.param .u64 %value_out) __get_current_messages_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 106 0 ld.global.u32 %r24,[_messages_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L4; cvta.const.u64 %r23,_C_messages_locale; bra $L2; $L4: cvta.global.u64 %r23,_messages_locale; $L2: .loc 1 107 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } /121 0 0 0 644 8414 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __monetary_load_locale .visible .func (.param .u32 %value_out) __monetary_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/locale/lmonetary.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_monetary_locale .visible .func (.param .u64 %value_out) __get_current_monetary_locale; // BEGIN GLOBAL VAR DECL: __mlocale_changed .extern .global .align 4 .u32 __mlocale_changed[1]; // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: __fix_locale_grouping_str .extern .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strtol .extern .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN VAR DEF: empty .global .align 1 .u8 empty[1]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[12] = {76,67,95,77,79,78,69,84,65,82,89,0 }; // BEGIN VAR DEF: numempty .global .align 1 .u8 numempty[2] = {127,0 }; // BEGIN VAR DEF: _C_monetary_locale .const .align 8 .u64 _C_monetary_locale[15] = {generic(empty),generic(empty),generic(empty),generic(empty),generic(numempty),generic(empty),generic(empty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty) }; // BEGIN VAR DEF: _monetary_locale .global .align 8 .u64 _monetary_locale[15]; // BEGIN VAR DEF: _monetary_using_locale .global .align 4 .u32 _monetary_using_locale[1]; // BEGIN GLOBAL FUNCTION DEF: __monetary_load_locale .visible .func (.param .u32 %value_out) __monetary_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r35; .reg .u64 %r37; .reg .u64 %r39; .reg .u64 %r41; .reg .u64 %r43; .reg .u64 %r45; .reg .u64 %r47; .reg .u64 %r58; .reg .u32 %r61; .reg .u64 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r75; .reg .u64 %r76; .reg .u32 %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u64 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .u64 %r96; .reg .u32 %r97; .reg .pred %r98; .reg .u64 %r103; .reg .u32 %r104; .reg .pred %r105; .reg .u64 %r110; .reg .u32 %r111; .reg .pred %r112; .reg .u64 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .u64 %r124; .reg .u32 %r125; .reg .pred %r126; .reg .u64 %r131; .reg .u32 %r132; .reg .pred %r133; .reg .u64 %r135; mov.u64 %r58,%ar0; .loc 1 118 0 mov.u32 %r61,1; st.global.u32 [__mlocale_changed],%r61; .loc 1 119 0 cvta.global.u64 %r135,_monetary_locale; mov.u32 %r67,15; cvta.const.u64 %r65,$LC0; mov.u64 %r64,0; cvta.global.u64 %r63,_monetary_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r58; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r63; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r64; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r65; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r67; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r67; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r135; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r69,[%value_in]; } .loc 1 123 0 setp.ne.u32 %r70,%r69,0; @ %r70 bra $L1; ld.global.u32 %r71,[_monetary_using_locale]; setp.eq.u32 %r72,%r71,0; @ %r72 bra $L1; .loc 1 125 0 ld.u64 %r75,[%r135+32]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r75; call (%value_in),__fix_locale_grouping_str,(%out_arg1); ld.param.u64 %r76,[%value_in]; } .loc 1 124 0 st.u64 [%r135+32],%r76; .loc 1 130 0 ld.u64 %r25,[%r135+56]; .loc 1 85 0 mov.u32 %r81,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r82,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r83,%r82; setp.ne.u32 %r84,%r83,-1; selp.u64 %r47,%r82,127,%r84; .loc 1 130 0 st.u8 [%r25],%r47; .loc 1 131 0 ld.u64 %r26,[%r135+64]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r89,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r90,%r89; setp.ne.u32 %r91,%r90,-1; selp.u64 %r45,%r89,127,%r91; .loc 1 131 0 st.u8 [%r26],%r45; .loc 1 132 0 ld.u64 %r27,[%r135+72]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r96,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r97,%r96; setp.ne.u32 %r98,%r97,-1; selp.u64 %r43,%r96,127,%r98; .loc 1 132 0 st.u8 [%r27],%r43; .loc 1 133 0 ld.u64 %r28,[%r135+80]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r103,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r104,%r103; setp.ne.u32 %r105,%r104,-1; selp.u64 %r41,%r103,127,%r105; .loc 1 133 0 st.u8 [%r28],%r41; .loc 1 134 0 ld.u64 %r29,[%r135+88]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r110,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r111,%r110; setp.ne.u32 %r112,%r111,-1; selp.u64 %r39,%r110,127,%r112; .loc 1 134 0 st.u8 [%r29],%r39; .loc 1 135 0 ld.u64 %r30,[%r135+96]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r30; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r117,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r118,%r117; setp.ne.u32 %r119,%r118,-1; selp.u64 %r37,%r117,127,%r119; .loc 1 135 0 st.u8 [%r30],%r37; .loc 1 136 0 ld.u64 %r31,[%r135+104]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r124,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r125,%r124; setp.ne.u32 %r126,%r125,-1; selp.u64 %r35,%r124,127,%r126; .loc 1 136 0 st.u8 [%r31],%r35; .loc 1 137 0 ld.u64 %r32,[%r135+112]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r131,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r132,%r131; setp.ne.u32 %r133,%r132,-1; selp.u64 %r33,%r131,127,%r133; .loc 1 137 0 st.u8 [%r32],%r33; $L1: .loc 1 141 0 mov.u32 %value,%r69; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_monetary_locale .visible .func (.param .u64 %value_out) __get_current_monetary_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 148 0 ld.global.u32 %r24,[_monetary_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L16; cvta.const.u64 %r23,_C_monetary_locale; bra $L14; $L16: cvta.global.u64 %r23,_monetary_locale; $L14: .loc 1 149 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } /140 0 0 0 644 3764 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __numeric_load_locale .visible .func (.param .u32 %value_out) __numeric_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/locale/lnumeric.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_numeric_locale .visible .func (.param .u64 %value_out) __get_current_numeric_locale; // BEGIN GLOBAL VAR DECL: __nlocale_changed .extern .global .align 4 .u32 __nlocale_changed[1]; // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: __fix_locale_grouping_str .extern .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0); // BEGIN VAR DEF: _numeric_locale .global .align 8 .u64 _numeric_locale[3]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[11] = {76,67,95,78,85,77,69,82,73,67,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[2] = {46,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[1] = {0 }; // BEGIN VAR DEF: _numeric_using_locale .global .align 4 .u32 _numeric_using_locale[1]; // BEGIN VAR DEF: numempty .global .align 1 .u8 numempty[2] = {127,0 }; // BEGIN VAR DEF: _C_numeric_locale .const .align 8 .u64 _C_numeric_locale[3] = {generic($LC1),generic($LC2),generic(numempty) }; // BEGIN GLOBAL FUNCTION DEF: __numeric_load_locale .visible .func (.param .u32 %value_out) __numeric_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r26; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u64 %r43; .reg .u64 %r44; mov.u64 %r26,%ar0; .loc 1 78 0 mov.u32 %r29,1; st.global.u32 [__nlocale_changed],%r29; .loc 1 79 0 cvta.global.u64 %r36,_numeric_locale; mov.u32 %r35,3; cvta.const.u64 %r33,$LC0; mov.u64 %r32,0; cvta.global.u64 %r31,_numeric_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r33; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r35; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r35; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r36; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r37,[%value_in]; } .loc 1 83 0 setp.ne.u32 %r38,%r37,0; @ %r38 bra $L1; ld.global.u32 %r39,[_numeric_using_locale]; setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 85 0 ld.u64 %r43,[%r36+16]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r43; call (%value_in),__fix_locale_grouping_str,(%out_arg1); ld.param.u64 %r44,[%value_in]; } .loc 1 84 0 st.u64 [%r36+16],%r44; $L1: .loc 1 88 0 mov.u32 %value,%r37; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_numeric_locale .visible .func (.param .u64 %value_out) __get_current_numeric_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 95 0 ld.global.u32 %r24,[_numeric_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L8; cvta.const.u64 %r23,_C_numeric_locale; bra $L6; $L8: cvta.global.u64 %r23,_numeric_locale; $L6: .loc 1 96 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-locale.o/ 0 0 0 644 6143 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _setlocale_r .visible .func (.param .u64 %value_out) _setlocale_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/locale/locale.c" // BEGIN GLOBAL FUNCTION DECL: __locale_charset .visible .func (.param .u64 %value_out) __locale_charset; // BEGIN GLOBAL FUNCTION DECL: __locale_mb_cur_max .visible .func (.param .u32 %value_out) __locale_mb_cur_max; // BEGIN GLOBAL FUNCTION DECL: __locale_msgcharset .visible .func (.param .u64 %value_out) __locale_msgcharset; // BEGIN GLOBAL FUNCTION DECL: __locale_cjk_lang .visible .func (.param .u32 %value_out) __locale_cjk_lang; // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .visible .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: setlocale .visible .func (.param .u64 %value_out) setlocale (.param .u32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: localeconv .visible .func (.param .u64 %value_out) localeconv; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN GLOBAL VAR DEF: _PathLocale .visible .global .align 8 .u64 _PathLocale[1]; // BEGIN GLOBAL VAR DEF: __mb_cur_max .visible .global .align 4 .u32 __mb_cur_max[1] = {1 }; // BEGIN VAR DEF: lc_ctype_charset .global .align 1 .u8 lc_ctype_charset[32] = {65,83,67,73,73,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[2] = {46,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[1] = {0 }; // BEGIN VAR DEF: lconv .global .align 8 .u64 lconv[12] = {generic($LC3),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),9187201950435737471,140185576636287 }; // BEGIN GLOBAL VAR DEF: __nlocale_changed .visible .global .align 4 .u32 __nlocale_changed[1]; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {80,79,83,73,88,0 }; // BEGIN VAR DEF: lc_message_charset .global .align 1 .u8 lc_message_charset[32] = {65,83,67,73,73,0 }; // BEGIN GLOBAL VAR DEF: __mlocale_changed .visible .global .align 4 .u32 __mlocale_changed[1]; // BEGIN GLOBAL FUNCTION DEF: _setlocale_r .visible .func (.param .u64 %value_out) _setlocale_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r25; .reg .u64 %r28; .reg .pred %r29; .reg .u64 %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u32 %r36; .reg .pred %r37; .reg .u64 %r39; .reg .u32 %r40; .reg .pred %r41; .reg .u64 %r43; mov.u64 %r28,%ar2; .loc 1 282 0 setp.eq.u64 %r29,%r28,0; @ %r29 bra $L2; .loc 1 284 0 cvta.const.u64 %r31,$LC1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r32,[%value_in]; } setp.eq.u32 %r33,%r32,0; @ %r33 bra $L2; cvta.const.u64 %r43,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r36,[%value_in]; } setp.eq.u32 %r37,%r36,0; @ %r37 bra $L2; .loc 1 285 0 cvta.const.u64 %r39,$LC2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r39; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r40,[%value_in]; } setp.ne.u32 %r41,%r40,0; @ %r41 bra $L4; $L2: .loc 1 288 0 cvta.const.u64 %r25,$LC0; bra $L1; $L4: .loc 1 286 0 mov.u64 %r25,0; $L1: .loc 1 417 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_charset .visible .func (.param .u64 %value_out) __locale_charset { .reg .u64 %value; .loc 1 940 0 cvta.global.u64 %value,lc_ctype_charset; .loc 1 942 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_mb_cur_max .visible .func (.param .u32 %value_out) __locale_mb_cur_max { .reg .u32 %value; .loc 1 950 0 ld.global.u32 %value,[__mb_cur_max]; .loc 1 952 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_msgcharset .visible .func (.param .u64 %value_out) __locale_msgcharset { .reg .u64 %value; .loc 1 961 0 cvta.global.u64 %value,lc_message_charset; .loc 1 963 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_cjk_lang .visible .func (.param .u32 %value_out) __locale_cjk_lang { .reg .u32 %value; .loc 1 968 0 mov.u32 %value,0; .loc 1 969 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _localeconv_r .visible .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 1020 0 cvta.global.u64 %value,lconv; .loc 1 1021 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: setlocale .visible .func (.param .u64 %value_out) setlocale (.param .u32 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r29; .reg .u64 %r30; mov.u32 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 1033 0 ld.global.u64 %r29,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),_setlocale_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r30,[%value_in]; } .loc 1 1034 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: localeconv .visible .func (.param .u64 %value_out) localeconv { .reg .u64 %value; .loc 1 1040 0 cvta.global.u64 %value,lconv; .loc 1 1041 0 st.param.u64 [%value_out],%value; ret; } lib_a-lrand48.o/0 0 0 644 2013 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _lrand48_r .visible .func (.param .u64 %value_out) _lrand48_r (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/lrand48.c" // BEGIN GLOBAL FUNCTION DECL: lrand48 .visible .func (.param .u64 %value_out) lrand48; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _lrand48_r .visible .func (.param .u64 %value_out) _lrand48_r (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r31; .reg .u64 %r34; .reg .u64 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u16 %r41; mov.u64 %r31,%ar0; .loc 1 21 0 add.u64 %r34,%r31,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r36,[%r31+244]; shl.b64 %r37,%r36,15; .loc 1 23 0 ld.u16 %r38,[%r31+242]; shr.u32 %r39,%r38,1; cvt.u16.u32 %r41,%r39; cvt.u64.u16 %r40,%r41; .loc 1 22 0 add.u64 %value,%r37,%r40; .loc 1 24 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: lrand48 .visible .func (.param .u64 %value_out) lrand48 { .reg .u64 %value; .reg .u64 %r22; .reg .u64 %r34; .reg .u64 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u16 %r41; .loc 1 30 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 21 0 add.u64 %r34,%r22,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r22; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r36,[%r22+244]; shl.b64 %r37,%r36,15; .loc 1 23 0 ld.u16 %r38,[%r22+242]; shr.u32 %r39,%r38,1; cvt.u16.u32 %r41,%r39; cvt.u64.u16 %r40,%r41; .loc 1 22 0 add.u64 %value,%r37,%r40; .loc 1 31 0 st.param.u64 [%value_out],%value; ret; } lib_a-malloc.o/ 0 0 0 644 1059 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .visible .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/machine/nvptx/malloc.c" // BEGIN GLOBAL FUNCTION DECL: malloc .extern .func (.param .u64 %value_out) malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __nvptx_malloc .visible .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r27; .reg .u64 %r28; .reg .pred %r29; mov.u64 %r25,%ar0; .loc 1 33 0 add.u64 %r27,%r25,8; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),malloc,(%out_arg1); ld.param.u64 %r28,[%value_in]; } .loc 1 34 0 setp.eq.u64 %r29,%r28,0; @ %r29 bra $L3; .loc 1 35 0 add.u64 %r24,%r28,8; st.u64 [%r28],%r25; bra $L1; $L3: mov.u64 %r24,%r28; $L1: .loc 1 38 0 mov.u64 %value,%r24; st.param.u64 [%value_out],%value; ret; } lib_a-mallocr.o/0 0 0 644 1488 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _malloc_r .visible .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/machine/nvptx/mallocr.c" // BEGIN GLOBAL FUNCTION DECL: _free_r .visible .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: _malloc_r .visible .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r26; mov.u64 %r24,%ar1; .loc 1 20 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r26,[%value_in]; } .loc 1 21 0 mov.u64 %value,%r26; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _free_r .visible .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; mov.u64 %r23,%ar1; .loc 1 25 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; call __nvptx_free,(%out_arg1); } .loc 1 26 0 ret; } lib_a-memccpy.o/0 0 0 644 2742 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memccpy .visible .func (.param .u64 %value_out) memccpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/string/memccpy.c" // BEGIN GLOBAL FUNCTION DEF: memccpy .visible .func (.param .u64 %value_out) memccpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r81; .reg .u64 %r82; .reg .u32 %r87; .reg .u32 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u32 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .pred %r110; .reg .pred %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u16 %r120; .reg .pred %r122; .reg .pred %r123; .reg .u16 %r125; mov.u64 %r103,%ar0; mov.u64 %r104,%ar1; mov.u32 %r105,%ar2; mov.u64 %r106,%ar3; .loc 1 95 0 cvt.u32.u32 %r107,%r105; cvt.s32.s8 %r88,%r107; .loc 1 99 0 setp.le.u64 %r108,%r106,7; @ %r108 bra $L2; mov.u64 %r93,%r103; or.b64 %r109,%r104,%r93; and.b64 %r91,%r109,7; setp.ne.u64 %r110,%r91,0; @ %r110 bra $L2; cvt.s64.s8 %r101,%r107; mov.u32 %r100,8; $L3: .loc 1 114 0 shl.b64 %r81,%r91,8; add.u64 %r91,%r81,%r101; add.u32 %r100,%r100,-1; .loc 1 113 0 setp.ne.u32 %r112,%r100,0; @ %r112 bra $L3; $L4: mov.u64 %r98,%r93; .loc 1 120 0 ld.u64 %r82,[%r104]; .loc 1 121 0 xor.b64 %r90,%r82,%r91; .loc 1 122 0 add.u64 %r113,%r90,-72340172838076673; not.b64 %r114,%r90; and.b64 %r115,%r113,%r114; and.b64 %r116,%r115,-9187201950435737472; setp.ne.u64 %r117,%r116,0; @ %r117 bra $L8; .loc 1 124 0 add.u64 %r104,%r104,8; add.u64 %r93,%r93,8; mov.u64 %r103,%r93; st.u64 [%r98],%r82; .loc 1 125 0 add.u64 %r106,%r106,-8; .loc 1 118 0 setp.gt.u64 %r118,%r106,7; @ %r118 bra $L4; bra $L2; $L7: add.u64 %r102,%r92,1; .loc 1 135 0 ld.s8 %r87,[%r99]; cvt.u32.u32 %r119,%r87; st.u8 [%r92],%r119; add.u64 %r99,%r99,1; mov.u64 %r92,%r102; cvt.u16.u32 %r120,%r87; setp.eq.u16 %r122,%r120,%r125; @ ! %r122 bra $L6; bra $L1; $L8: mov.u64 %r103,%r93; $L2: mov.u64 %r92,%r103; mov.u64 %r99,%r104; add.u64 %r97,%r92,%r106; cvt.u16.u32 %r125,%r88; $L6: .loc 1 133 0 setp.ne.u64 %r123,%r97,%r92; @ %r123 bra $L7; .loc 1 90 0 mov.u64 %r102,0; $L1: .loc 1 144 0 mov.u64 %value,%r102; st.param.u64 [%value_out],%value; ret; } lib_a-memchr.o/ 0 0 0 644 3628 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memchr .visible .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/memchr.c" // BEGIN GLOBAL FUNCTION DEF: memchr .visible .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r81; .reg .u64 %r83; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r92; .reg .u32 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r98; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u64 %r105; .reg .u32 %r106; .reg .u64 %r107; .reg .pred %r108; .reg .pred %r109; .reg .u16 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r114; .reg .pred %r116; .reg .u64 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .pred %r131; .reg .u16 %r132; .reg .u16 %r133; .reg .pred %r134; .reg .u16 %r135; .reg .pred %r137; .reg .pred %r138; .reg .u16 %r140; .reg .u16 %r141; mov.u64 %r103,%ar0; mov.u32 %r104,%ar1; mov.u64 %r105,%ar2; .loc 1 78 0 cvt.u32.u32 %r106,%r104; cvt.u32.u8 %r94,%r106; .loc 1 85 0 and.b64 %r107,%r103,7; setp.eq.u64 %r108,%r107,0; @ %r108 bra $L11; .loc 1 87 0 add.u64 %r98,%r105,-1; setp.eq.u64 %r109,%r105,0; @ %r109 bra $L12; .loc 1 89 0 ld.u8 %r110,[%r103]; cvt.u16.u32 %r111,%r94; setp.eq.u16 %r112,%r110,%r111; @ %r112 bra $L13; cvt.u16.u32 %r141,%r94; bra $L4; $L5: .loc 1 87 0 add.u64 %r98,%r98,-1; setp.eq.u64 %r113,%r98,-1; @ %r113 bra $L14; .loc 1 89 0 ld.u8 %r114,[%r103]; setp.eq.u16 %r116,%r114,%r141; @ %r116 bra $L15; $L4: .loc 1 91 0 add.u64 %r103,%r103,1; .loc 1 85 0 and.b64 %r117,%r103,7; setp.ne.u64 %r118,%r117,0; @ %r118 bra $L5; bra $L2; $L11: mov.u64 %r98,%r105; $L2: .loc 1 94 0 setp.le.u64 %r119,%r98,7; @ %r119 bra $L6; .loc 1 105 0 shl.b32 %r120,%r104,8; and.b32 %r121,%r120,65535; and.b32 %r122,%r104,255; or.b32 %r123,%r121,%r122; cvt.s64.s32 %r95,%r123; .loc 1 106 0 shl.b64 %r81,%r95,16; or.b64 %r96,%r81,%r95; .loc 1 108 0 shl.b64 %r90,%r96,32; or.b64 %r89,%r90,%r96; $L8: .loc 1 112 0 ld.u64 %r124,[%r103]; xor.b64 %r83,%r89,%r124; add.u64 %r125,%r83,-72340172838076673; not.b64 %r126,%r83; and.b64 %r127,%r125,%r126; and.b64 %r128,%r127,-9187201950435737472; setp.ne.u64 %r129,%r128,0; @ %r129 bra $L7; .loc 1 114 0 add.u64 %r98,%r98,-8; .loc 1 115 0 add.u64 %r103,%r103,8; .loc 1 110 0 setp.gt.u64 %r130,%r98,7; @ %r130 bra $L8; $L6: .loc 1 126 0 setp.eq.u64 %r131,%r98,0; @ %r131 bra $L16; $L7: .loc 1 128 0 ld.u8 %r132,[%r103]; cvt.u16.u32 %r133,%r94; setp.eq.u16 %r134,%r132,%r133; @ %r134 bra $L17; add.u64 %r92,%r103,%r98; cvt.u16.u32 %r140,%r94; bra $L9; $L10: ld.u8 %r135,[%r103]; setp.eq.u16 %r137,%r135,%r140; @ %r137 bra $L18; $L9: .loc 1 130 0 add.u64 %r103,%r103,1; .loc 1 126 0 setp.ne.u64 %r138,%r92,%r103; @ %r138 bra $L10; .loc 1 88 0 mov.u64 %r102,0; bra $L1; $L12: mov.u64 %r102,%r105; bra $L1; $L13: .loc 1 89 0 mov.u64 %r102,%r103; bra $L1; $L14: .loc 1 88 0 mov.u64 %r102,0; bra $L1; $L15: .loc 1 91 0 mov.u64 %r102,%r103; bra $L1; $L16: .loc 1 88 0 mov.u64 %r102,%r98; bra $L1; $L17: .loc 1 128 0 mov.u64 %r102,%r103; bra $L1; $L18: .loc 1 130 0 mov.u64 %r102,%r103; $L1: .loc 1 134 0 mov.u64 %value,%r102; st.param.u64 [%value_out],%value; ret; } lib_a-memcmp.o/ 0 0 0 644 2173 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memcmp .visible .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/memcmp.c" // BEGIN GLOBAL FUNCTION DEF: memcmp .visible .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r82; .reg .u32 %r83; .reg .u64 %r86; .reg .u32 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .pred %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .pred %r94; .reg .pred %r95; .reg .u16 %r96; .reg .u16 %r97; .reg .pred %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .pred %r101; .reg .pred %r102; .reg .u16 %r103; .reg .u16 %r104; .reg .pred %r105; .reg .pred %r106; mov.u64 %r88,%ar0; mov.u64 %r89,%ar1; mov.u64 %r90,%ar2; .loc 1 81 0 setp.le.u64 %r91,%r90,7; @ %r91 bra $L2; or.b64 %r92,%r88,%r89; and.b64 %r93,%r92,7; setp.eq.u64 %r94,%r93,0; @ %r94 bra $L3; bra $L10; $L2: .loc 1 102 0 setp.eq.u64 %r95,%r90,0; @ %r95 bra $L11; $L10: .loc 1 104 0 ld.u8 %r82,[%r88]; ld.u8 %r83,[%r89]; cvt.u16.u32 %r96,%r82; cvt.u16.u32 %r97,%r83; setp.ne.u16 %r98,%r96,%r97; @ ! %r98 bra $L16; bra $L6; $L3: .loc 1 89 0 ld.u64 %r99,[%r88]; ld.u64 %r100,[%r89]; setp.ne.u64 %r101,%r99,%r100; @ %r101 bra $L10; .loc 1 91 0 add.u64 %r88,%r88,8; .loc 1 92 0 add.u64 %r89,%r89,8; .loc 1 93 0 add.u64 %r90,%r90,-8; .loc 1 87 0 setp.gt.u64 %r102,%r90,7; @ %r102 bra $L3; bra $L2; $L9: .loc 1 104 0 ld.u8 %r82,[%r88]; ld.u8 %r83,[%r89]; cvt.u16.u32 %r103,%r82; cvt.u16.u32 %r104,%r83; setp.eq.u16 %r105,%r103,%r104; @ %r105 bra $L8; $L6: .loc 1 105 0 sub.u32 %r87,%r82,%r83; bra $L1; $L16: add.u64 %r86,%r88,%r90; $L8: .loc 1 106 0 add.u64 %r88,%r88,1; .loc 1 107 0 add.u64 %r89,%r89,1; .loc 1 102 0 setp.ne.u64 %r106,%r88,%r86; @ %r106 bra $L9; .loc 1 110 0 mov.u32 %r87,0; bra $L1; $L11: cvt.u32.u64 %r87,%r90; $L1: .loc 1 112 0 mov.u32 %value,%r87; st.param.u32 [%value_out],%value; ret; } lib_a-memcpy.o/ 0 0 0 644 2972 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memcpy .visible .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/memcpy.c" // BEGIN GLOBAL FUNCTION DEF: memcpy .visible .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r103; .reg .u64 %r105; .reg .u64 %r109; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .pred %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .pred %r121; .reg .pred %r122; .reg .u64 %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .pred %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .pred %r136; .reg .u64 %r137; .reg .u32 %r138; .reg .pred %r139; mov.u64 %r115,%ar0; mov.u64 %r116,%ar1; mov.u64 %r117,%ar2; .loc 1 79 0 setp.le.u64 %r118,%r117,31; @ %r118 bra $L9; or.b64 %r119,%r116,%r115; and.b64 %r120,%r119,7; setp.eq.u64 %r121,%r120,0; @ %r121 bra $L3; .loc 1 72 0 mov.u64 %r89,%r115; bra $L4; $L9: mov.u64 %r89,%r115; bra $L2; $L10: .loc 1 95 0 mov.u64 %r117,%r86; $L2: .loc 1 106 0 setp.ne.u64 %r122,%r117,0; @ %r122 bra $L4; bra $L5; $L3: add.u64 %r123,%r117,-32; and.b64 %r125,%r123,-32; add.u64 %r109,%r125,32; add.u64 %r89,%r115,%r109; .loc 1 82 0 mov.u64 %r90,%r116; .loc 1 81 0 mov.u64 %r93,%r115; $L6: .loc 1 87 0 ld.u64 %r126,[%r90]; st.u64 [%r93],%r126; .loc 1 88 0 ld.u64 %r127,[%r90+8]; st.u64 [%r93+8],%r127; .loc 1 89 0 ld.u64 %r128,[%r90+16]; st.u64 [%r93+16],%r128; add.u64 %r90,%r90,32; add.u64 %r93,%r93,32; .loc 1 90 0 ld.u64 %r129,[%r90+-8]; st.u64 [%r93+-8],%r129; .loc 1 85 0 setp.ne.u64 %r130,%r89,%r93; @ %r130 bra $L6; add.u64 %r116,%r116,%r109; and.b64 %r86,%r117,31; .loc 1 95 0 setp.le.u64 %r131,%r86,7; @ %r131 bra $L10; mov.u64 %r98,%r116; mov.u64 %r99,%r89; add.u64 %r132,%r86,-8; shr.u64 %r103,%r132,3; shl.b64 %r133,%r103,3; add.u64 %r134,%r133,8; add.u64 %r105,%r134,%r116; $L7: .loc 1 97 0 ld.u64 %r135,[%r98]; st.u64 [%r99],%r135; add.u64 %r98,%r98,8; add.u64 %r99,%r99,8; .loc 1 95 0 setp.ne.u64 %r136,%r98,%r105; @ %r136 bra $L7; and.b64 %r117,%r117,7; add.u64 %r137,%r103,1; shl.b64 %r87,%r137,3; add.u64 %r89,%r89,%r87; add.u64 %r116,%r116,%r87; bra $L2; $L4: mov.u64 %r91,%r89; mov.u64 %r94,%r116; add.u64 %r97,%r91,%r117; $L8: .loc 1 107 0 ld.u8 %r138,[%r94]; st.u8 [%r91],%r138; add.u64 %r91,%r91,1; add.u64 %r94,%r94,1; .loc 1 106 0 setp.ne.u64 %r139,%r91,%r97; @ %r139 bra $L8; $L5: .loc 1 111 0 mov.u64 %value,%r115; st.param.u64 [%value_out],%value; ret; } lib_a-memmem.o/ 0 0 0 644 22368 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/str-two-way.h" // BEGIN FUNCTION DECL: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: memmem .visible .func (.param .u64 %value_out) memmem (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 2 "../../../../../newlib/libc/string/memmem.c" // BEGIN GLOBAL FUNCTION DECL: memcmp .extern .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DEF: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .pred %r54; .reg .pred %r57; .reg .pred %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .u16 %r63; .reg .u16 %r64; .reg .pred %r65; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .u64 %r73; .reg .u64 %r74; mov.u64 %r46,%ar0; mov.u64 %r47,%ar1; mov.u64 %r48,%ar2; .loc 1 113 0 mov.u64 %r37,1; mov.u64 %r35,%r37; .loc 1 112 0 mov.u64 %r28,0; .loc 1 111 0 mov.u64 %r32,-1; .loc 1 140 0 mov.u64 %r74,%r37; .loc 1 114 0 bra $L2; $L7: .loc 1 116 0 add.u64 %r49,%r46,%r27; .loc 1 117 0 add.u64 %r50,%r46,%r32; add.u64 %r51,%r50,%r35; .loc 1 118 0 ld.u8 %r52,[%r49]; ld.u8 %r53,[%r51]; setp.ge.u16 %r54,%r52,%r53; @ %r54 bra $L3; .loc 1 123 0 sub.u64 %r37,%r27,%r32; mov.u64 %r28,%r27; .loc 1 122 0 mov.u64 %r35,1; bra $L2; $L3: .loc 1 125 0 setp.ne.u16 %r57,%r52,%r53; @ %r57 bra $L5; .loc 1 128 0 setp.eq.u64 %r58,%r35,%r37; @ %r58 bra $L6; .loc 1 129 0 add.u64 %r35,%r35,1; bra $L2; $L6: .loc 1 132 0 mov.u64 %r28,%r27; .loc 1 133 0 mov.u64 %r35,1; bra $L2; $L5: .loc 1 139 0 mov.u64 %r32,%r28; add.u64 %r28,%r28,1; .loc 1 140 0 mov.u64 %r37,%r74; mov.u64 %r35,1; $L2: .loc 1 114 0 add.u64 %r27,%r28,%r35; setp.lt.u64 %r59,%r27,%r47; @ %r59 bra $L7; .loc 1 143 0 st.u64 [%r48],%r37; .loc 1 148 0 mov.u64 %r38,1; mov.u64 %r36,%r38; .loc 1 147 0 mov.u64 %r22,0; .loc 1 146 0 mov.u64 %r26,-1; .loc 1 175 0 mov.u64 %r73,%r38; .loc 1 149 0 bra $L8; $L13: .loc 1 151 0 add.u64 %r60,%r46,%r33; .loc 1 152 0 add.u64 %r61,%r46,%r26; add.u64 %r62,%r61,%r36; .loc 1 153 0 ld.u8 %r63,[%r60]; ld.u8 %r64,[%r62]; setp.le.u16 %r65,%r63,%r64; @ %r65 bra $L9; .loc 1 158 0 sub.u64 %r38,%r33,%r26; mov.u64 %r22,%r33; .loc 1 157 0 mov.u64 %r36,1; bra $L8; $L9: .loc 1 160 0 setp.ne.u16 %r68,%r63,%r64; @ %r68 bra $L11; .loc 1 163 0 setp.eq.u64 %r69,%r36,%r38; @ %r69 bra $L12; .loc 1 164 0 add.u64 %r36,%r36,1; bra $L8; $L12: .loc 1 167 0 mov.u64 %r22,%r33; .loc 1 168 0 mov.u64 %r36,1; bra $L8; $L11: .loc 1 174 0 mov.u64 %r26,%r22; add.u64 %r22,%r22,1; .loc 1 175 0 mov.u64 %r38,%r73; mov.u64 %r36,1; $L8: .loc 1 149 0 add.u64 %r33,%r22,%r36; setp.lt.u64 %r70,%r33,%r47; @ %r70 bra $L13; .loc 1 181 0 add.u64 %r34,%r26,1; add.u64 %r45,%r32,1; setp.lt.u64 %r71,%r34,%r45; @ %r71 bra $L1; .loc 1 183 0 st.u64 [%r48],%r38; .loc 1 184 0 mov.u64 %r45,%r34; $L1: .loc 1 185 0 mov.u64 %value,%r45; st.param.u64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[2056]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r100; .reg .u32 %r105; .reg .u32 %r106; .reg .u64 %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .u64 %r110; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r124; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r153; .reg .u64 %r154; .reg .u64 %r159; .reg .u64 %r162; .reg .u64 %r169; .reg .u64 %r172; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r180; .reg .u64 %r183; .reg .u64 %r184; .reg .u64 %r185; .reg .u64 %r186; .reg .u64 %r187; .reg .u64 %r191; .reg .u64 %r192; .reg .pred %r193; .reg .pred %r194; .reg .u64 %r196; .reg .u64 %r197; .reg .u64 %r198; .reg .pred %r199; .reg .u64 %r203; .reg .u64 %r204; .reg .u32 %r205; .reg .pred %r206; .reg .u64 %r208; .reg .u64 %r210; .reg .u64 %r211; .reg .u64 %r212; .reg .pred %r213; .reg .pred %r214; .reg .pred %r215; .reg .pred %r216; .reg .u64 %r218; .reg .u64 %r219; .reg .u16 %r220; .reg .u16 %r221; .reg .pred %r222; .reg .u64 %r224; .reg .u64 %r225; .reg .pred %r226; .reg .u16 %r227; .reg .u16 %r228; .reg .pred %r229; .reg .pred %r230; .reg .u64 %r232; .reg .u16 %r234; .reg .u16 %r235; .reg .pred %r236; .reg .u64 %r237; .reg .pred %r238; .reg .u16 %r239; .reg .u16 %r240; .reg .pred %r241; .reg .u64 %r242; .reg .pred %r243; .reg .pred %r245; .reg .u64 %r246; .reg .u64 %r247; .reg .u64 %r249; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .pred %r254; .reg .pred %r255; .reg .u64 %r256; .reg .u64 %r258; .reg .u16 %r259; .reg .u16 %r260; .reg .pred %r261; .reg .u64 %r262; .reg .pred %r263; .reg .u16 %r264; .reg .u16 %r265; .reg .pred %r266; .reg .u64 %r268; .reg .u64 %r270; .reg .u16 %r271; .reg .u16 %r272; .reg .pred %r273; .reg .u64 %r274; .reg .pred %r275; .reg .u16 %r276; .reg .u16 %r277; .reg .pred %r278; .reg .u64 %r279; .reg .pred %r280; .reg .u64 %r286; .reg .u64 %r287; .reg .u64 %r288; .reg .u64 %r289; .reg .u64 %r290; .reg .u64 %r291; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u64 %r295; .reg .u64 %r296; .reg .pred %r297; .reg .u64 %r298; .reg .u64 %r299; .reg .u64 %r300; .reg .u64 %r301; .reg .u64 %r302; mov.u64 %r184,%ar0; mov.u64 %r185,%ar1; mov.u64 %r186,%ar2; mov.u64 %r187,%ar3; .loc 1 304 0 add.u64 %r191,%frame,2048; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r186; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r187; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r191; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r192,[%value_in]; } mov.u64 %r180,%frame; $L16: .loc 1 311 0 st.u64 [%r180],%r187; add.u64 %r180,%r180,8; .loc 1 310 0 setp.ne.u64 %r193,%r191,%r180; @ %r193 bra $L16; add.u64 %r154,%r187,-1; .loc 1 312 0 setp.eq.u64 %r194,%r187,0; @ %r194 bra $L17; mov.u64 %r177,%r186; mov.u64 %r178,%r154; $L18: .loc 1 313 0 ld.u8 %r196,[%r177]; shl.b64 %r197,%r196,3; add.u64 %r198,%frame,%r197; st.u64 [%r198],%r178; add.u64 %r177,%r177,1; add.u64 %r178,%r178,-1; .loc 1 312 0 setp.ne.u64 %r199,%r178,-1; @ %r199 bra $L18; $L17: .loc 1 317 0 ld.u64 %r204,[%frame+2048]; add.u64 %r203,%r186,%r204; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r186; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r203; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r192; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r205,[%value_in]; } setp.ne.u32 %r206,%r205,0; @ %r206 bra $L19; .loc 1 360 0 ld.u64 %r95,[%frame+2048]; .loc 1 361 0 sub.u64 %r133,%r187,%r95; .loc 1 322 0 mov.u64 %r110,0; .loc 1 324 0 mov.u64 %r124,%r110; .loc 1 352 0 add.u64 %r289,%r192,-1; .loc 1 353 0 add.u64 %r290,%r186,%r289; add.u64 %r291,%r192,-2; mov.u64 %r292,1; sub.u64 %r293,%r292,%r192; .loc 1 339 0 mov.u64 %r294,%r110; .loc 1 325 0 sub.u64 %r295,%r185,%r187; $L30: .loc 1 329 0 add.u64 %r286,%r184,%r124; add.u64 %r208,%r286,%r154; ld.u8 %r210,[%r208]; shl.b64 %r211,%r210,3; add.u64 %r212,%frame,%r211; ld.u64 %r118,[%r212]; .loc 1 330 0 setp.eq.u64 %r213,%r118,0; @ %r213 bra $L20; .loc 1 332 0 setp.eq.u64 %r214,%r110,0; @ %r214 bra $L21; setp.le.u64 %r215,%r95,%r118; .loc 1 337 0 selp.u64 %r118,%r118,%r133,%r215; $L21: .loc 1 340 0 add.u64 %r124,%r124,%r118; .loc 1 339 0 mov.u64 %r110,%r294; .loc 1 341 0 bra $L22; $L20: .loc 1 345 0 max.u64 %r131,%r192,%r110; .loc 1 346 0 setp.ge.u64 %r216,%r131,%r154; @ %r216 bra $L23; .loc 1 347 0 add.u64 %r218,%r286,%r131; .loc 1 346 0 add.u64 %r219,%r186,%r131; ld.u8 %r220,[%r218]; ld.u8 %r221,[%r219]; setp.ne.u16 %r222,%r220,%r221; @ %r222 bra $L24; add.u64 %r287,%r131,1; add.u64 %r117,%r186,%r287; add.u64 %r224,%r124,1; add.u64 %r225,%r224,%r131; add.u64 %r130,%r184,%r225; $L25: .loc 1 348 0 mov.u64 %r131,%r287; .loc 1 346 0 setp.ge.u64 %r226,%r287,%r154; @ %r226 bra $L23; ld.u8 %r89,[%r117]; .loc 1 347 0 ld.u8 %r90,[%r130]; add.u64 %r117,%r117,1; add.u64 %r130,%r130,1; .loc 1 346 0 cvt.u16.u32 %r227,%r89; cvt.u16.u32 %r228,%r90; setp.eq.u16 %r229,%r227,%r228; @ ! %r229 bra $L24; add.u64 %r287,%r287,1; bra $L25; $L23: .loc 1 352 0 mov.u64 %r136,%r289; .loc 1 353 0 setp.le.u64 %r230,%r192,%r110; @ %r230 bra $L41; .loc 1 354 0 add.u64 %r232,%r286,%r289; .loc 1 353 0 ld.u8 %r234,[%r232]; ld.u8 %r235,[%r290]; setp.ne.u16 %r236,%r234,%r235; @ %r236 bra $L42; add.u64 %r96,%r186,%r291; add.u64 %r237,%r291,%r124; add.u64 %r153,%r184,%r237; add.u64 %r137,%r110,-1; bra $L27; $L43: mov.u64 %r136,%r132; $L27: .loc 1 355 0 add.u64 %r132,%r136,-1; .loc 1 353 0 setp.eq.u64 %r238,%r132,%r137; @ %r238 bra $L26; ld.u8 %r91,[%r96]; .loc 1 354 0 ld.u8 %r92,[%r153]; add.u64 %r96,%r96,-1; add.u64 %r153,%r153,-1; .loc 1 353 0 cvt.u16.u32 %r239,%r91; cvt.u16.u32 %r240,%r92; setp.eq.u16 %r241,%r239,%r240; @ %r241 bra $L43; bra $L26; $L41: mov.u64 %r136,%r192; bra $L26; $L42: mov.u64 %r136,%r192; $L26: .loc 1 356 0 add.u64 %r242,%r110,1; setp.le.u64 %r243,%r242,%r136; @ %r243 bra $L28; .loc 1 357 0 mov.u64 %r183,%r286; bra $L15; $L28: .loc 1 360 0 add.u64 %r124,%r124,%r95; .loc 1 361 0 mov.u64 %r110,%r133; $L22: .loc 1 325 0 setp.ge.u64 %r245,%r295,%r124; @ %r245 bra $L30; .loc 1 408 0 mov.u64 %r183,0; bra $L15; $L19: .loc 1 375 0 sub.u64 %r247,%r187,%r192; max.u64 %r246,%r247,%r192; add.u64 %r100,%r246,1; .loc 1 376 0 mov.u64 %r107,0; .loc 1 396 0 add.u64 %r296,%r192,-1; .loc 1 397 0 setp.eq.u64 %r297,%r296,-1; add.u64 %r298,%r192,-2; add.u64 %r299,%r186,-1; mov.u64 %r300,1; sub.u64 %r301,%r300,%r192; add.u64 %r302,%r192,1; $L40: .loc 1 381 0 add.u64 %r288,%r184,%r107; add.u64 %r249,%r288,%r154; ld.u8 %r251,[%r249]; shl.b64 %r252,%r251,3; add.u64 %r253,%frame,%r252; ld.u64 %r126,[%r253]; .loc 1 382 0 setp.ne.u64 %r254,%r126,0; @ %r254 bra $L31; .loc 1 390 0 setp.ge.u64 %r255,%r192,%r154; @ %r255 bra $L32; add.u64 %r256,%r186,%r192; .loc 1 391 0 add.u64 %r258,%r288,%r192; .loc 1 390 0 ld.u8 %r259,[%r256]; ld.u8 %r260,[%r258]; setp.eq.u16 %r261,%r259,%r260; @ %r261 bra $L33; mov.u64 %r128,%r192; bra $L34; $L31: .loc 1 384 0 add.u64 %r107,%r107,%r126; .loc 1 385 0 bra $L35; $L33: add.u64 %r169,%r186,%r302; add.u64 %r262,%r107,%r302; add.u64 %r172,%r184,%r262; .loc 1 390 0 mov.u64 %r128,%r192; $L36: .loc 1 392 0 add.u64 %r128,%r128,1; .loc 1 390 0 setp.ge.u64 %r263,%r128,%r154; @ %r263 bra $L32; ld.u8 %r105,[%r169]; .loc 1 391 0 ld.u8 %r106,[%r172]; add.u64 %r169,%r169,1; add.u64 %r172,%r172,1; .loc 1 390 0 cvt.u16.u32 %r264,%r105; cvt.u16.u32 %r265,%r106; setp.eq.u16 %r266,%r264,%r265; @ %r266 bra $L36; bra $L34; $L32: .loc 1 397 0 @ %r297 bra $L37; add.u64 %r268,%r186,%r296; .loc 1 398 0 add.u64 %r270,%r288,%r296; .loc 1 397 0 ld.u8 %r271,[%r268]; ld.u8 %r272,[%r270]; setp.ne.u16 %r273,%r271,%r272; @ %r273 bra $L38; add.u64 %r159,%r186,%r298; add.u64 %r274,%r107,%r298; add.u64 %r162,%r184,%r274; $L39: setp.eq.u64 %r275,%r159,%r299; @ %r275 bra $L37; ld.u8 %r108,[%r159]; .loc 1 398 0 ld.u8 %r109,[%r162]; add.u64 %r159,%r159,-1; add.u64 %r162,%r162,-1; .loc 1 397 0 cvt.u16.u32 %r276,%r108; cvt.u16.u32 %r277,%r109; setp.eq.u16 %r278,%r276,%r277; @ %r278 bra $L39; bra $L38; $L35: .loc 1 377 0 sub.u64 %r279,%r185,%r187; setp.le.u64 %r280,%r107,%r279; @ %r280 bra $L40; .loc 1 408 0 mov.u64 %r183,0; bra $L15; $L37: .loc 1 401 0 mov.u64 %r183,%r288; bra $L15; $L38: .loc 1 402 0 add.u64 %r107,%r107,%r100; bra $L35; $L24: add.u64 %r114,%r293,%r124; .loc 1 365 0 add.u64 %r124,%r114,%r131; .loc 1 366 0 mov.u64 %r110,%r118; bra $L22; $L34: add.u64 %r115,%r301,%r107; .loc 1 405 0 add.u64 %r107,%r128,%r115; bra $L35; $L15: .loc 1 409 0 mov.u64 %value,%r183; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: memmem .visible .func (.param .u64 %value_out) memmem (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u64 %r41; .reg .u32 %r42; .reg .u64 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u64 %r50; .reg .u64 %r51; .reg .u64 %r55; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r61; .reg .u32 %r63; .reg .u64 %r67; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r78; .reg .u64 %r91; .reg .u64 %r94; .reg .u64 %r97; .reg .u64 %r102; .reg .u64 %r105; .reg .u64 %r112; .reg .u64 %r115; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .pred %r125; .reg .pred %r126; .reg .pred %r127; .reg .u32 %r131; .reg .u64 %r132; .reg .u32 %r134; .reg .u32 %r135; .reg .u32 %r137; .reg .u32 %r138; .reg .u16 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .u32 %r142; .reg .u16 %r143; .reg .pred %r144; .reg .u64 %r145; .reg .pred %r146; .reg .u64 %r150; .reg .u64 %r154; .reg .u64 %r155; .reg .u32 %r156; .reg .pred %r157; .reg .pred %r158; .reg .u64 %r159; .reg .u64 %r160; .reg .u64 %r161; .reg .u16 %r162; .reg .u16 %r163; .reg .pred %r164; .reg .u64 %r166; .reg .u64 %r167; .reg .pred %r168; .reg .u16 %r169; .reg .u16 %r170; .reg .pred %r171; .reg .pred %r172; .reg .u64 %r174; .reg .u64 %r175; .reg .u16 %r176; .reg .u16 %r177; .reg .pred %r178; .reg .u64 %r179; .reg .pred %r180; .reg .u16 %r181; .reg .u16 %r182; .reg .pred %r183; .reg .u64 %r184; .reg .pred %r185; .reg .pred %r187; .reg .u64 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .pred %r191; .reg .u16 %r192; .reg .u16 %r193; .reg .pred %r194; .reg .u64 %r195; .reg .u64 %r197; .reg .u16 %r198; .reg .u16 %r199; .reg .pred %r200; .reg .u64 %r201; .reg .pred %r202; .reg .u16 %r203; .reg .u16 %r204; .reg .pred %r205; .reg .u64 %r206; .reg .pred %r207; .reg .u64 %r210; .reg .u64 %r211; .reg .u16 %r212; .reg .u16 %r213; .reg .pred %r214; .reg .u64 %r219; .reg .pred %r226; .reg .u64 %r227; .reg .u64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .pred %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; mov.u64 %r121,%ar0; mov.u64 %r122,%ar1; mov.u64 %r123,%ar2; mov.u64 %r124,%ar3; .loc 2 60 0 setp.eq.u64 %r125,%r124,0; @ %r125 bra $L84; .loc 2 83 0 setp.le.u64 %r126,%r124,%r122; @ %r126 bra $L61; $L63: .loc 2 84 0 mov.u64 %r120,0; bra $L59; $L61: .loc 2 90 0 setp.gt.u64 %r127,%r124,31; @ %r127 bra $L62; .loc 2 92 0 ld.u8 %r131,[%r123]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r121; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r131; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r122; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r132,[%value_in]; } mov.u64 %r120,%r132; .loc 2 93 0 set.u32.eq.u64 %r134,%r132,0; neg.s32 %r135,%r134; set.u32.eq.u64 %r137,%r124,1; neg.s32 %r138,%r137; cvt.u16.u32 %r140,%r135; cvt.u16.u32 %r141,%r138; or.b16 %r139,%r140,%r141; cvt.u32.u16 %r142,%r139; cvt.u16.u8 %r143,%r142; setp.ne.u16 %r144,%r143,0; @ %r144 bra $L59; .loc 2 95 0 sub.u64 %r145,%r132,%r121; sub.u64 %r31,%r122,%r145; .loc 2 96 0 setp.gt.u64 %r146,%r124,%r31; @ %r146 bra $L63; .loc 1 209 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r123; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r124; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r150,[%value_in]; } .loc 1 213 0 ld.u64 %r155,[%frame]; add.u64 %r154,%r123,%r155; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r123; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r154; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r150; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r156,[%value_in]; } setp.ne.u32 %r157,%r156,0; @ %r157 bra $L64; .loc 1 238 0 ld.u64 %r50,[%frame]; .loc 1 239 0 sub.u64 %r51,%r124,%r50; .loc 1 219 0 mov.u64 %r67,0; .loc 1 218 0 mov.u64 %r68,%r67; .loc 1 230 0 add.u64 %r229,%r150,-1; .loc 1 231 0 add.u64 %r230,%r123,%r229; add.u64 %r231,%r150,-2; mov.u64 %r232,1; sub.u64 %r233,%r232,%r150; .loc 1 244 0 mov.u64 %r234,%r67; .loc 1 220 0 sub.u64 %r235,%r31,%r124; $L72: .loc 1 223 0 max.u64 %r39,%r150,%r68; .loc 1 224 0 setp.le.u64 %r158,%r124,%r39; @ %r158 bra $L65; add.u64 %r159,%r123,%r39; .loc 1 225 0 add.u64 %r160,%r132,%r39; add.u64 %r161,%r160,%r67; .loc 1 224 0 ld.u8 %r162,[%r159]; ld.u8 %r163,[%r161]; setp.ne.u16 %r164,%r162,%r163; @ %r164 bra $L66; add.u64 %r227,%r39,1; add.u64 %r94,%r123,%r227; add.u64 %r166,%r67,1; add.u64 %r167,%r166,%r39; add.u64 %r97,%r132,%r167; $L67: .loc 1 226 0 mov.u64 %r39,%r227; .loc 1 224 0 setp.eq.u64 %r168,%r124,%r227; @ %r168 bra $L65; ld.u8 %r40,[%r94]; .loc 1 225 0 ld.u8 %r42,[%r97]; add.u64 %r94,%r94,1; add.u64 %r97,%r97,1; .loc 1 224 0 cvt.u16.u32 %r169,%r40; cvt.u16.u32 %r170,%r42; setp.eq.u16 %r171,%r169,%r170; @ ! %r171 bra $L66; add.u64 %r227,%r227,1; bra $L67; $L65: .loc 1 230 0 mov.u64 %r69,%r229; .loc 1 231 0 setp.le.u64 %r172,%r150,%r68; @ %r172 bra $L85; .loc 1 232 0 add.u64 %r174,%r132,%r67; add.u64 %r175,%r174,%r229; .loc 1 231 0 ld.u8 %r176,[%r230]; ld.u8 %r177,[%r175]; setp.ne.u16 %r178,%r176,%r177; @ %r178 bra $L86; add.u64 %r41,%r123,%r231; add.u64 %r179,%r231,%r67; add.u64 %r33,%r132,%r179; add.u64 %r91,%r68,-1; bra $L69; $L87: mov.u64 %r69,%r45; $L69: .loc 1 233 0 add.u64 %r45,%r69,-1; .loc 1 231 0 setp.eq.u64 %r180,%r45,%r91; @ %r180 bra $L68; ld.u8 %r46,[%r41]; .loc 1 232 0 ld.u8 %r47,[%r33]; add.u64 %r41,%r41,-1; add.u64 %r33,%r33,-1; .loc 1 231 0 cvt.u16.u32 %r181,%r46; cvt.u16.u32 %r182,%r47; setp.eq.u16 %r183,%r181,%r182; @ %r183 bra $L87; bra $L68; $L85: mov.u64 %r69,%r150; bra $L68; $L86: mov.u64 %r69,%r150; $L68: .loc 1 234 0 add.u64 %r184,%r68,1; setp.le.u64 %r185,%r184,%r69; @ %r185 bra $L70; .loc 1 235 0 add.u64 %r120,%r132,%r67; bra $L59; $L70: .loc 1 238 0 add.u64 %r67,%r67,%r50; .loc 1 239 0 mov.u64 %r68,%r51; $L82: .loc 1 220 0 setp.ge.u64 %r187,%r235,%r67; @ %r187 bra $L72; .loc 1 276 0 mov.u64 %r120,0; bra $L59; $L64: .loc 1 252 0 sub.u64 %r189,%r124,%r150; max.u64 %r188,%r189,%r150; add.u64 %r55,%r188,1; .loc 1 253 0 mov.u64 %r32,0; setp.le.u64 %r226,%r124,%r150; .loc 1 264 0 add.u64 %r236,%r150,-1; .loc 1 265 0 setp.ne.u64 %r237,%r236,-1; add.u64 %r238,%r150,-2; add.u64 %r239,%r123,-1; mov.u64 %r240,1; sub.u64 %r241,%r240,%r150; add.u64 %r242,%r150,1; bra $L73; $L80: add.u64 %r112,%r123,%r242; add.u64 %r190,%r32,%r242; add.u64 %r115,%r132,%r190; .loc 1 258 0 mov.u64 %r57,%r150; $L75: .loc 1 260 0 add.u64 %r57,%r57,1; .loc 1 258 0 setp.eq.u64 %r191,%r124,%r57; @ %r191 bra $L74; ld.u8 %r58,[%r112]; .loc 1 259 0 ld.u8 %r59,[%r115]; add.u64 %r112,%r112,1; add.u64 %r115,%r115,1; .loc 1 258 0 cvt.u16.u32 %r192,%r58; cvt.u16.u32 %r193,%r59; setp.eq.u16 %r194,%r192,%r193; @ %r194 bra $L75; bra $L76; $L83: .loc 1 265 0 add.u64 %r195,%r123,%r236; .loc 1 266 0 add.u64 %r197,%r228,%r236; .loc 1 265 0 ld.u8 %r198,[%r195]; ld.u8 %r199,[%r197]; setp.ne.u16 %r200,%r198,%r199; @ %r200 bra $L77; add.u64 %r102,%r123,%r238; add.u64 %r201,%r32,%r238; add.u64 %r105,%r132,%r201; $L79: setp.eq.u64 %r202,%r102,%r239; @ %r202 bra $L78; ld.u8 %r61,[%r102]; .loc 1 266 0 ld.u8 %r63,[%r105]; add.u64 %r102,%r102,-1; add.u64 %r105,%r105,-1; .loc 1 265 0 cvt.u16.u32 %r203,%r61; cvt.u16.u32 %r204,%r63; setp.eq.u16 %r205,%r203,%r204; @ %r205 bra $L79; bra $L77; $L81: .loc 1 254 0 sub.u64 %r206,%r31,%r124; setp.lt.u64 %r207,%r206,%r32; @ %r207 bra $L88; $L73: .loc 1 258 0 @ ! %r226 bra $L94; add.u64 %r228,%r132,%r32; bra $L74; $L94: .loc 1 259 0 add.u64 %r228,%r132,%r32; add.u64 %r210,%r228,%r150; .loc 1 258 0 add.u64 %r211,%r123,%r150; ld.u8 %r212,[%r210]; ld.u8 %r213,[%r211]; setp.eq.u16 %r214,%r212,%r213; @ %r214 bra $L80; mov.u64 %r57,%r150; bra $L76; $L88: .loc 1 276 0 mov.u64 %r120,0; .loc 2 98 0 bra $L59; $L62: .loc 2 100 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r121; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r122; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r123; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r124; call (%value_in),two_way_long_needle,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r219,[%value_in]; } mov.u64 %r120,%r219; bra $L59; $L84: .loc 2 63 0 mov.u64 %r120,%r121; bra $L59; $L78: .loc 1 269 0 mov.u64 %r120,%r228; bra $L59; $L77: .loc 1 270 0 add.u64 %r32,%r32,%r55; bra $L81; $L66: add.u64 %r38,%r233,%r67; .loc 1 243 0 add.u64 %r67,%r38,%r39; .loc 1 244 0 mov.u64 %r68,%r234; bra $L82; $L76: add.u64 %r78,%r241,%r32; .loc 1 273 0 add.u64 %r32,%r78,%r57; bra $L81; $L74: .loc 1 265 0 @ %r237 bra $L83; bra $L78; $L59: .loc 2 102 0 mov.u64 %value,%r120; st.param.u64 [%value_out],%value; ret; } lib_a-memmove.o/0 0 0 644 3490 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memmove .visible .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/memmove.c" // BEGIN GLOBAL FUNCTION DEF: memmove .visible .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r77; .reg .u64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u64 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r106; .reg .u64 %r108; .reg .u64 %r112; .reg .u64 %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .pred %r121; .reg .pred %r122; .reg .pred %r123; .reg .u32 %r124; .reg .pred %r125; .reg .pred %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .pred %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .pred %r142; mov.u64 %r118,%ar0; mov.u64 %r119,%ar1; mov.u64 %r120,%ar2; .loc 1 94 0 setp.le.u64 %r121,%r118,%r119; @ %r121 bra $L2; add.u64 %r93,%r119,%r120; setp.le.u64 %r122,%r93,%r118; @ %r122 bra $L2; .loc 1 98 0 add.u64 %r94,%r118,%r120; .loc 1 99 0 setp.eq.u64 %r123,%r120,0; @ %r123 bra $L3; $L4: .loc 1 101 0 add.u64 %r93,%r93,-1; add.u64 %r94,%r94,-1; ld.u8 %r124,[%r93]; st.u8 [%r94],%r124; .loc 1 99 0 setp.ne.u64 %r125,%r119,%r93; @ %r125 bra $L4; bra $L3; $L2: .loc 1 109 0 setp.le.u64 %r126,%r120,31; @ %r126 bra $L11; or.b64 %r127,%r119,%r118; and.b64 %r128,%r127,7; setp.eq.u64 %r129,%r128,0; @ %r129 bra $L6; mov.u64 %r77,%r118; bra $L7; $L11: mov.u64 %r77,%r118; bra $L5; $L12: .loc 1 125 0 mov.u64 %r120,%r95; $L5: .loc 1 136 0 setp.ne.u64 %r130,%r120,0; @ %r130 bra $L7; bra $L3; $L6: add.u64 %r131,%r120,-32; and.b64 %r133,%r131,-32; add.u64 %r112,%r133,32; add.u64 %r77,%r118,%r112; .loc 1 109 0 mov.u64 %r88,%r119; mov.u64 %r90,%r118; $L8: .loc 1 117 0 ld.u64 %r82,[%r88]; st.u64 [%r90],%r82; .loc 1 118 0 ld.u64 %r83,[%r88+8]; st.u64 [%r90+8],%r83; .loc 1 119 0 ld.u64 %r84,[%r88+16]; st.u64 [%r90+16],%r84; add.u64 %r88,%r88,32; add.u64 %r90,%r90,32; .loc 1 120 0 ld.u64 %r85,[%r88+-8]; st.u64 [%r90+-8],%r85; .loc 1 115 0 setp.ne.u64 %r134,%r77,%r90; @ %r134 bra $L8; add.u64 %r119,%r119,%r112; and.b64 %r95,%r120,31; .loc 1 125 0 setp.le.u64 %r135,%r95,7; @ %r135 bra $L12; mov.u64 %r101,%r119; mov.u64 %r102,%r77; add.u64 %r136,%r95,-8; shr.u64 %r106,%r136,3; shl.b64 %r137,%r106,3; add.u64 %r138,%r137,8; add.u64 %r108,%r138,%r119; $L9: .loc 1 127 0 ld.u64 %r86,[%r101]; st.u64 [%r102],%r86; add.u64 %r101,%r101,8; add.u64 %r102,%r102,8; .loc 1 125 0 setp.ne.u64 %r139,%r101,%r108; @ %r139 bra $L9; and.b64 %r120,%r120,7; add.u64 %r140,%r106,1; shl.b64 %r91,%r140,3; add.u64 %r77,%r77,%r91; add.u64 %r119,%r119,%r91; bra $L5; $L7: mov.u64 %r92,%r77; mov.u64 %r96,%r119; add.u64 %r100,%r92,%r120; $L10: .loc 1 138 0 ld.u8 %r141,[%r96]; st.u8 [%r92],%r141; add.u64 %r92,%r92,1; add.u64 %r96,%r96,1; .loc 1 136 0 setp.ne.u64 %r142,%r92,%r100; @ %r142 bra $L10; $L3: .loc 1 144 0 mov.u64 %value,%r118; st.param.u64 [%value_out],%value; ret; } lib_a-mempcpy.o/0 0 0 644 2925 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: mempcpy .visible .func (.param .u64 %value_out) mempcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/mempcpy.c" // BEGIN GLOBAL FUNCTION DEF: mempcpy .visible .func (.param .u64 %value_out) mempcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r80; .reg .u64 %r81; .reg .u64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r86; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r101; .reg .u64 %r103; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .pred %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .pred %r120; .reg .pred %r121; .reg .u64 %r122; .reg .u64 %r124; .reg .pred %r125; .reg .pred %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .pred %r133; mov.u64 %r114,%ar0; mov.u64 %r115,%ar1; mov.u64 %r116,%ar2; .loc 1 75 0 setp.le.u64 %r117,%r116,31; @ %r117 bra $L2; or.b64 %r118,%r115,%r114; and.b64 %r119,%r118,7; setp.eq.u64 %r120,%r119,0; @ %r120 bra $L3; bra $L4; $L9: .loc 1 91 0 mov.u64 %r116,%r89; $L2: .loc 1 102 0 setp.ne.u64 %r121,%r116,0; @ %r121 bra $L4; mov.u64 %r113,%r114; bra $L1; $L3: add.u64 %r122,%r116,-32; and.b64 %r124,%r122,-32; add.u64 %r107,%r124,32; add.u64 %r108,%r114,%r107; .loc 1 78 0 mov.u64 %r88,%r115; $L6: .loc 1 83 0 ld.u64 %r80,[%r88]; st.u64 [%r114],%r80; .loc 1 84 0 ld.u64 %r81,[%r88+8]; st.u64 [%r114+8],%r81; .loc 1 85 0 ld.u64 %r82,[%r88+16]; st.u64 [%r114+16],%r82; add.u64 %r88,%r88,32; add.u64 %r114,%r114,32; .loc 1 86 0 ld.u64 %r83,[%r88+-8]; st.u64 [%r114+-8],%r83; .loc 1 81 0 setp.ne.u64 %r125,%r108,%r114; @ %r125 bra $L6; add.u64 %r115,%r115,%r107; and.b64 %r89,%r116,31; .loc 1 91 0 setp.le.u64 %r126,%r89,7; @ %r126 bra $L9; mov.u64 %r96,%r115; mov.u64 %r97,%r108; add.u64 %r127,%r89,-8; shr.u64 %r101,%r127,3; shl.b64 %r128,%r101,3; add.u64 %r129,%r128,8; add.u64 %r103,%r129,%r115; $L7: .loc 1 93 0 ld.u64 %r84,[%r96]; st.u64 [%r97],%r84; add.u64 %r96,%r96,8; add.u64 %r97,%r97,8; .loc 1 91 0 setp.ne.u64 %r130,%r96,%r103; @ %r130 bra $L7; add.u64 %r131,%r101,1; shl.b64 %r86,%r131,3; add.u64 %r115,%r115,%r86; add.u64 %r114,%r108,%r86; and.b64 %r116,%r116,7; bra $L2; $L4: mov.u64 %r91,%r115; mov.u64 %r92,%r114; add.u64 %r95,%r91,%r116; $L8: .loc 1 103 0 ld.u8 %r132,[%r91]; st.u8 [%r92],%r132; add.u64 %r91,%r91,1; add.u64 %r92,%r92,1; .loc 1 102 0 setp.ne.u64 %r133,%r91,%r95; @ %r133 bra $L8; add.u64 %r113,%r114,%r116; $L1: .loc 1 107 0 mov.u64 %value,%r113; st.param.u64 [%value_out],%value; ret; } lib_a-memrchr.o/0 0 0 644 3614 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memrchr .visible .func (.param .u64 %value_out) memrchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/memrchr.c" // BEGIN GLOBAL FUNCTION DEF: memrchr .visible .func (.param .u64 %value_out) memrchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r81; .reg .u64 %r84; .reg .u64 %r86; .reg .u64 %r91; .reg .u64 %r92; .reg .u32 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r99; .reg .u64 %r101; .reg .u64 %r106; .reg .u64 %r107; .reg .u32 %r108; .reg .u64 %r109; .reg .u32 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .pred %r113; .reg .pred %r114; .reg .u16 %r115; .reg .u16 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u16 %r119; .reg .pred %r121; .reg .u64 %r123; .reg .pred %r124; .reg .pred %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u64 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .pred %r135; .reg .pred %r136; .reg .pred %r137; .reg .u16 %r138; .reg .u16 %r139; .reg .pred %r140; .reg .u16 %r141; .reg .pred %r143; .reg .pred %r144; .reg .u16 %r146; .reg .u16 %r147; mov.u64 %r107,%ar0; mov.u32 %r108,%ar1; mov.u64 %r109,%ar2; .loc 1 77 0 add.u64 %r101,%r109,-1; add.u64 %r106,%r107,%r101; .loc 1 78 0 cvt.u32.u32 %r110,%r108; cvt.u32.u8 %r95,%r110; .loc 1 85 0 add.u64 %r111,%r107,%r109; and.b64 %r112,%r111,7; setp.eq.u64 %r113,%r112,0; @ %r113 bra $L11; .loc 1 87 0 setp.eq.u64 %r114,%r109,0; @ %r114 bra $L12; .loc 1 89 0 ld.u8 %r115,[%r106]; cvt.u16.u32 %r116,%r95; setp.eq.u16 %r117,%r115,%r116; @ %r117 bra $L1; cvt.u16.u32 %r147,%r95; bra $L4; $L5: .loc 1 87 0 add.u64 %r101,%r101,-1; setp.eq.u64 %r118,%r101,-1; @ %r118 bra $L13; .loc 1 89 0 ld.u8 %r119,[%r106]; setp.eq.u16 %r121,%r119,%r147; @ %r121 bra $L1; $L4: .loc 1 91 0 add.u64 %r106,%r106,-1; .loc 1 85 0 shl.b64 %r123,%r106,61; setp.ne.u64 %r124,%r123,-2305843009213693952; @ %r124 bra $L5; bra $L2; $L11: mov.u64 %r101,%r109; $L2: .loc 1 94 0 setp.le.u64 %r125,%r101,7; @ %r125 bra $L6; .loc 1 104 0 add.u64 %r99,%r106,-7; .loc 1 105 0 shl.b32 %r126,%r108,8; and.b32 %r127,%r126,65535; and.b32 %r128,%r108,255; or.b32 %r129,%r127,%r128; cvt.s64.s32 %r96,%r129; .loc 1 106 0 shl.b64 %r81,%r96,16; or.b64 %r97,%r81,%r96; .loc 1 108 0 shl.b64 %r92,%r97,32; or.b64 %r91,%r92,%r97; $L8: .loc 1 112 0 ld.u64 %r130,[%r99]; xor.b64 %r84,%r91,%r130; add.u64 %r131,%r84,-72340172838076673; not.b64 %r132,%r84; and.b64 %r133,%r131,%r132; and.b64 %r134,%r133,-9187201950435737472; setp.ne.u64 %r135,%r134,0; @ %r135 bra $L7; .loc 1 114 0 add.u64 %r101,%r101,-8; .loc 1 115 0 add.u64 %r99,%r99,-8; .loc 1 110 0 setp.gt.u64 %r136,%r101,7; @ %r136 bra $L8; $L7: .loc 1 121 0 add.u64 %r106,%r99,7; $L6: .loc 1 126 0 setp.eq.u64 %r137,%r101,0; @ %r137 bra $L14; .loc 1 128 0 ld.u8 %r138,[%r106]; cvt.u16.u32 %r139,%r95; setp.eq.u16 %r140,%r138,%r139; @ %r140 bra $L1; sub.u64 %r86,%r106,%r101; cvt.u16.u32 %r146,%r95; bra $L9; $L10: ld.u8 %r141,[%r106]; setp.eq.u16 %r143,%r141,%r146; @ %r143 bra $L1; $L9: .loc 1 130 0 add.u64 %r106,%r106,-1; .loc 1 126 0 setp.ne.u64 %r144,%r86,%r106; @ %r144 bra $L10; .loc 1 88 0 mov.u64 %r106,0; bra $L1; $L12: mov.u64 %r106,%r109; bra $L1; $L13: mov.u64 %r106,0; bra $L1; $L14: mov.u64 %r106,%r101; $L1: .loc 1 134 0 mov.u64 %value,%r106; st.param.u64 [%value_out],%value; ret; } lib_a-memset.o/ 0 0 0 644 3545 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memset .visible .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/memset.c" // BEGIN GLOBAL FUNCTION DEF: memset .visible .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r82; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r89; .reg .u64 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r98; .reg .u64 %r100; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r111; .reg .u64 %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r120; .reg .pred %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .pred %r124; .reg .pred %r125; .reg .pred %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .pred %r129; .reg .u64 %r130; .reg .u64 %r132; .reg .u64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .pred %r139; .reg .u64 %r140; .reg .u64 %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .pred %r144; mov.u64 %r114,%ar0; mov.u32 %r115,%ar1; mov.u64 %r116,%ar2; .loc 1 59 0 mov.u64 %r111,%r114; and.b64 %r117,%r114,7; setp.eq.u64 %r118,%r117,0; @ %r118 bra $L13; .loc 1 61 0 add.u64 %r94,%r116,-1; setp.eq.u64 %r119,%r116,0; @ %r119 bra $L3; cvt.u32.u32 %r120,%r115; .loc 1 50 0 mov.u64 %r95,%r114; .loc 1 62 0 mov.u32 %r122,%r120; bra $L4; $L5: .loc 1 61 0 add.u64 %r94,%r94,-1; add.u64 %r111,%r111,1; setp.eq.u64 %r121,%r94,-1; @ %r121 bra $L3; $L4: .loc 1 62 0 add.u64 %r95,%r95,1; st.u8 [%r111],%r122; .loc 1 59 0 and.b64 %r123,%r95,7; setp.ne.u64 %r124,%r123,0; @ %r124 bra $L5; bra $L2; $L13: .loc 1 50 0 mov.u64 %r95,%r114; .loc 1 59 0 mov.u64 %r94,%r116; $L2: .loc 1 67 0 setp.gt.u64 %r125,%r94,7; @ %r125 bra $L6; $L10: .loc 1 100 0 setp.ne.u64 %r126,%r94,0; @ %r126 bra $L7; bra $L3; $L6: .loc 1 56 0 and.b32 %r91,%r115,255; .loc 1 74 0 shl.b32 %r127,%r91,8; or.b32 %r128,%r127,%r91; cvt.u64.u32 %r92,%r128; .loc 1 75 0 shl.b64 %r82,%r92,16; or.b64 %r93,%r82,%r92; .loc 1 77 0 shl.b64 %r98,%r93,32; or.b64 %r103,%r93,%r98; .loc 1 80 0 setp.le.u64 %r129,%r94,31; @ %r129 bra $L14; add.u64 %r130,%r94,-32; and.b64 %r132,%r130,-32; add.u64 %r133,%r132,32; add.u64 %r90,%r95,%r133; $L9: .loc 1 82 0 st.u64 [%r95],%r103; .loc 1 83 0 st.u64 [%r95+8],%r103; .loc 1 84 0 st.u64 [%r95+16],%r103; add.u64 %r95,%r95,32; .loc 1 85 0 st.u64 [%r95+-8],%r103; .loc 1 80 0 setp.ne.u64 %r134,%r90,%r95; @ %r134 bra $L9; and.b64 %r94,%r94,31; .loc 1 89 0 setp.le.u64 %r135,%r94,7; @ ! %r135 bra $L8; bra $L10; $L14: .loc 1 80 0 mov.u64 %r90,%r95; $L8: mov.u64 %r84,%r90; add.u64 %r136,%r94,-8; shr.u64 %r100,%r136,3; shl.b64 %r137,%r100,3; add.u64 %r138,%r90,8; add.u64 %r102,%r137,%r138; $L11: .loc 1 91 0 st.u64 [%r84],%r103; add.u64 %r84,%r84,8; .loc 1 89 0 setp.ne.u64 %r139,%r84,%r102; @ %r139 bra $L11; add.u64 %r140,%r100,1; shl.b64 %r141,%r140,3; add.u64 %r95,%r90,%r141; and.b64 %r94,%r94,7; bra $L10; $L7: cvt.u32.u32 %r142,%r115; mov.u64 %r85,%r95; add.u64 %r89,%r85,%r94; .loc 1 101 0 mov.u32 %r143,%r142; $L12: st.u8 [%r85],%r143; add.u64 %r85,%r85,1; .loc 1 100 0 setp.ne.u64 %r144,%r85,%r89; @ %r144 bra $L12; $L3: .loc 1 104 0 mov.u64 %value,%r114; st.param.u64 [%value_out],%value; ret; } lib_a-mprec.o/ 0 0 0 644 51709 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _Balloc .visible .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/mprec.c" // BEGIN GLOBAL FUNCTION DECL: _Bfree .visible .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __multadd .visible .func (.param .u64 %value_out) __multadd (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __s2b .visible .func (.param .u64 %value_out) __s2b (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: __hi0bits .visible .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __lo0bits .visible .func (.param .u32 %value_out) __lo0bits (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __i2b .visible .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __multiply .visible .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __pow5mult .visible .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __lshift .visible .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mcmp .visible .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __mdiff .visible .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ulp .visible .func (.param .f64 %value_out) __ulp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __b2d .visible .func (.param .f64 %value_out) __b2d (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __d2b .visible .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ratio .visible .func (.param .f64 %value_out) __ratio (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _mprec_log10 .visible .func (.param .f64 %value_out) _mprec_log10 (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __copybits .visible .func __copybits (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __any_on .visible .func (.param .u32 %value_out) __any_on (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _calloc_r .extern .func (.param .u64 %value_out) _calloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DEF: __mprec_tens .visible .const .align 8 .u64 __mprec_tens[25] = {4607182418800017408,4621819117588971520,4636737291354636288,4652007308841189376,4666723172467343360,4681608360884174848,4696837146684686336,4711630319722168320,4726483295884279808,4741671816366391296,4756540486875873280,4771362005757984768,4786511204640096256,4801453603149578240,4816244402031689728,4831355200913801216,4846369599423283200,4861130398305394688,4876203697187506176,4891288408196988160,4906019910204099648,4921056587992461136,4936209963552724370,4950912855330343670,4965913770331839924 }; // BEGIN GLOBAL VAR DEF: __mprec_tinytens .visible .const .align 8 .u64 __mprec_tinytens[5] = {4367597403136100796,4128101167230658355,3649340653511681853,2691949749288605597,776877706278891331 }; // BEGIN VAR DEF: p05$2582 .const .align 4 .u32 p05$2582[3] = {5,25,125 }; // BEGIN GLOBAL VAR DEF: __mprec_bigtens .visible .const .align 8 .u64 __mprec_bigtens[5] = {4846369599423283200,5085611494797045271,5564284217833028085,6521906365687930162,8436737289693151036 }; // BEGIN GLOBAL FUNCTION DEF: _Balloc .visible .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r22; .reg .u64 %r25; .reg .u64 %r26; .reg .u32 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r34; .reg .pred %r35; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .pred %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r46; .reg .u32 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .pred %r53; .reg .u64 %r54; mov.u64 %r33,%ar0; mov.u32 %r34,%ar1; .loc 1 103 0 ld.u64 %r22,[%r33+120]; setp.ne.u64 %r35,%r22,0; @ %r35 bra $L2; .loc 1 106 0 mov.u64 %r38,65; mov.u64 %r37,8; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r37; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r38; call (%value_in),_calloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r39,[%value_in]; } mov.u64 %r22,%r39; st.u64 [%r33+120],%r22; .loc 1 109 0 setp.ne.u64 %r40,%r22,0; @ %r40 bra $L2; $L6: .loc 1 111 0 mov.u64 %r32,0; bra $L1; $L2: .loc 1 115 0 cvt.s64.s32 %r41,%r34; shl.b64 %r42,%r41,3; add.u64 %r25,%r22,%r42; ld.u64 %r32,[%r25]; setp.eq.u64 %r43,%r32,0; @ %r43 bra $L4; .loc 1 117 0 ld.u64 %r26,[%r32]; st.u64 [%r25],%r26; bra $L5; $L4: .loc 1 121 0 mov.u32 %r44,1; shl.b32 %r31,%r44,%r34; .loc 1 126 0 add.u32 %r48,%r31,-1; cvt.s64.s32 %r49,%r48; .loc 1 123 0 add.u64 %r50,%r49,8; shl.b64 %r51,%r50,2; mov.u64 %r46,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r46; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r51; call (%value_in),_calloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r52,[%value_in]; } mov.u64 %r32,%r52; .loc 1 127 0 setp.eq.u64 %r53,%r32,0; @ %r53 bra $L6; .loc 1 128 0 st.u32 [%r32+8],%r34; .loc 1 129 0 st.u32 [%r32+12],%r31; $L5: .loc 1 131 0 mov.u64 %r54,0; st.u64 [%r32+16],%r54; $L1: .loc 1 133 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _Bfree .visible .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .pred %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; mov.u64 %r28,%ar0; mov.u64 %r29,%ar1; .loc 1 139 0 setp.eq.u64 %r30,%r29,0; @ %r30 bra $L10; .loc 1 141 0 ld.s32 %r31,[%r29+8]; shl.b64 %r32,%r31,3; ld.u64 %r33,[%r28+120]; add.u64 %r26,%r33,%r32; ld.u64 %r27,[%r26]; st.u64 [%r29],%r27; .loc 1 142 0 st.u64 [%r26],%r29; $L10: .loc 1 144 0 ret; } // BEGIN GLOBAL FUNCTION DEF: __multadd .visible .func (.param .u64 %value_out) __multadd (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u64 %r80; .reg .u64 %r81; .reg .u64 %r83; .reg .u64 %r86; .reg .u64 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r100; .reg .pred %r101; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u32 %r123; mov.u64 %r86,%ar0; mov.u64 %r87,%ar1; mov.u32 %r88,%ar2; mov.u32 %r89,%ar3; .loc 1 160 0 ld.u32 %r69,[%r87+20]; .loc 1 161 0 add.u64 %r83,%r87,24; .loc 1 162 0 mov.u32 %r68,0; $L16: .loc 1 166 0 ld.u32 %r71,[%r83]; .loc 1 167 0 and.b32 %r90,%r71,65535; mad.lo.u32 %r72,%r90,%r88,%r89; .loc 1 168 0 shr.u32 %r92,%r71,16; shr.u32 %r94,%r72,16; mad.lo.u32 %r73,%r92,%r88,%r94; .loc 1 169 0 shr.u32 %r89,%r73,16; .loc 1 170 0 shl.b32 %r95,%r73,16; and.b32 %r96,%r72,65535; add.u32 %r97,%r95,%r96; st.u32 [%r83],%r97; .loc 1 177 0 add.u32 %r68,%r68,1; add.u64 %r83,%r83,4; setp.gt.s32 %r98,%r69,%r68; @ %r98 bra $L16; .loc 1 178 0 setp.eq.u32 %r99,%r89,0; @ %r99 bra $L15; .loc 1 180 0 ld.u32 %r100,[%r87+12]; setp.gt.s32 %r101,%r100,%r69; @ %r101 bra $L18; .loc 1 182 0 ld.u32 %r105,[%r87+8]; add.u32 %r104,%r105,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r86; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r104; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r106,[%value_in]; } .loc 1 183 0 ld.s32 %r110,[%r87+20]; add.u64 %r111,%r110,2; shl.b64 %r112,%r111,2; add.u64 %r113,%r87,16; add.u64 %r114,%r106,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r114; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r113; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r112; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r115,[%value_in]; } .loc 1 141 0 ld.s32 %r116,[%r87+8]; shl.b64 %r117,%r116,3; ld.u64 %r118,[%r86+120]; add.u64 %r80,%r118,%r117; ld.u64 %r81,[%r80]; st.u64 [%r87],%r81; .loc 1 142 0 st.u64 [%r80],%r87; .loc 1 185 0 mov.u64 %r87,%r106; $L18: .loc 1 187 0 cvt.s64.s32 %r119,%r69; add.u64 %r120,%r119,6; shl.b64 %r121,%r120,2; add.u64 %r122,%r87,%r121; st.u32 [%r122],%r89; add.u32 %r123,%r69,1; .loc 1 188 0 st.u32 [%r87+20],%r123; $L15: .loc 1 191 0 mov.u64 %value,%r87; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __s2b .visible .func (.param .u64 %value_out) __s2b (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r114; .reg .u64 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .pred %r124; .reg .pred %r126; .reg .u64 %r129; .reg .u32 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .u64 %r133; .reg .u32 %r136; .reg .u32 %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .pred %r141; .reg .pred %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .u64 %r145; .reg .u64 %r146; .reg .u32 %r149; .reg .u32 %r151; .reg .u32 %r152; .reg .u64 %r153; .reg .pred %r154; mov.u64 %r118,%ar0; mov.u64 %r119,%ar1; mov.u32 %r120,%ar2; mov.u32 %r121,%ar3; mov.u32 %r122,%ar4; .loc 1 205 0 add.u32 %r123,%r121,8; div.s32 %r97,%r123,9; .loc 1 206 0 setp.le.s32 %r124,%r97,1; @ %r124 bra $L30; mov.u32 %r104,1; mov.u32 %r105,0; $L24: add.u32 %r104,%r104,%r104; add.u32 %r105,%r105,1; setp.gt.s32 %r126,%r97,%r104; @ %r126 bra $L24; bra $L23; $L30: mov.u32 %r105,0; $L23: .loc 1 208 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r105; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r129,[%value_in]; } mov.u64 %r117,%r129; .loc 1 209 0 st.u32 [%r117+24],%r122; .loc 1 210 0 mov.u32 %r130,1; st.u32 [%r117+20],%r130; .loc 1 218 0 setp.le.s32 %r131,%r120,9; @ %r131 bra $L25; .loc 1 220 0 add.u64 %r99,%r119,9; mov.u64 %r110,%r99; add.u32 %r132,%r120,-10; cvt.u64.u32 %r114,%r132; add.u64 %r133,%r119,10; add.u64 %r116,%r133,%r114; $L26: .loc 1 222 0 ld.s8 %r138,[%r110]; add.u32 %r139,%r138,-48; mov.u32 %r136,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r117; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r136; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r139; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r140,[%value_in]; } mov.u64 %r117,%r140; add.u64 %r110,%r110,1; .loc 1 223 0 setp.ne.u64 %r141,%r110,%r116; @ %r141 bra $L26; add.u64 %r103,%r99,%r114; .loc 1 224 0 add.u64 %r102,%r103,2; bra $L27; $L25: .loc 1 227 0 add.u64 %r102,%r119,10; .loc 1 217 0 mov.u32 %r120,9; $L27: .loc 1 228 0 setp.le.s32 %r142,%r121,%r120; @ %r142 bra $L22; mov.u64 %r98,%r102; add.u32 %r143,%r121,-1; sub.u32 %r144,%r143,%r120; cvt.u64.u32 %r145,%r144; add.u64 %r146,%r98,1; add.u64 %r109,%r145,%r146; $L29: .loc 1 229 0 ld.s8 %r151,[%r98]; add.u32 %r152,%r151,-48; mov.u32 %r149,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r117; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r149; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r152; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r153,[%value_in]; } mov.u64 %r117,%r153; add.u64 %r98,%r98,1; .loc 1 228 0 setp.ne.u64 %r154,%r98,%r109; @ %r154 bra $L29; $L22: .loc 1 231 0 mov.u64 %value,%r117; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __hi0bits .visible .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r28; .reg .u32 %r29; .reg .u32 %r30; .reg .pred %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .pred %r35; .reg .u32 %r36; .reg .pred %r37; .reg .pred %r38; .reg .u32 %r39; .reg .pred %r40; mov.u32 %r29,%ar0; .loc 1 239 0 and.b32 %r30,%r29,-65536; setp.ne.u32 %r31,%r30,0; @ %r31 bra $L40; .loc 1 242 0 shl.b32 %r29,%r29,16; .loc 1 241 0 mov.u32 %r28,16; bra $L35; $L40: .loc 1 237 0 mov.u32 %r28,0; $L35: .loc 1 244 0 and.b32 %r32,%r29,-16777216; setp.ne.u32 %r33,%r32,0; @ %r33 bra $L36; .loc 1 246 0 add.u32 %r28,%r28,8; .loc 1 247 0 shl.b32 %r29,%r29,8; $L36: .loc 1 249 0 and.b32 %r34,%r29,-268435456; setp.ne.u32 %r35,%r34,0; @ %r35 bra $L37; .loc 1 251 0 add.u32 %r28,%r28,4; .loc 1 252 0 shl.b32 %r29,%r29,4; $L37: .loc 1 254 0 and.b32 %r36,%r29,-1073741824; setp.ne.u32 %r37,%r36,0; @ %r37 bra $L38; .loc 1 256 0 add.u32 %r28,%r28,2; .loc 1 257 0 shl.b32 %r29,%r29,2; $L38: .loc 1 259 0 setp.lt.s32 %r38,%r29,0; @ %r38 bra $L34; .loc 1 262 0 and.b32 %r39,%r29,1073741824; setp.eq.u32 %r40,%r39,0; @ %r40 bra $L41; .loc 1 261 0 add.u32 %r28,%r28,1; bra $L34; $L41: .loc 1 263 0 mov.u32 %r28,32; $L34: .loc 1 266 0 mov.u32 %value,%r28; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __lo0bits .visible .func (.param .u32 %value_out) __lo0bits (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r32; .reg .u32 %r33; .reg .u64 %r34; .reg .u32 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .pred %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; mov.u64 %r34,%ar0; .loc 1 272 0 ld.u32 %r32,[%r34]; .loc 1 274 0 and.b32 %r35,%r32,7; setp.eq.u32 %r36,%r35,0; @ %r36 bra $L43; .loc 1 276 0 and.b32 %r37,%r32,1; setp.ne.u32 %r38,%r37,0; @ %r38 bra $L51; .loc 1 278 0 and.b32 %r39,%r32,2; setp.eq.u32 %r40,%r39,0; @ %r40 bra $L45; .loc 1 280 0 shr.u32 %r41,%r32,1; st.u32 [%r34],%r41; .loc 1 281 0 mov.u32 %r33,1; bra $L42; $L45: .loc 1 283 0 shr.u32 %r42,%r32,2; st.u32 [%r34],%r42; .loc 1 284 0 mov.u32 %r33,2; bra $L42; $L43: .loc 1 287 0 and.b32 %r43,%r32,65535; setp.ne.u32 %r44,%r43,0; @ %r44 bra $L52; .loc 1 290 0 shr.u32 %r32,%r32,16; .loc 1 289 0 mov.u32 %r33,16; bra $L46; $L52: .loc 1 286 0 mov.u32 %r33,%r35; $L46: .loc 1 292 0 and.b32 %r45,%r32,255; setp.ne.u32 %r46,%r45,0; @ %r46 bra $L47; .loc 1 294 0 add.u32 %r33,%r33,8; .loc 1 295 0 shr.u32 %r32,%r32,8; $L47: .loc 1 297 0 and.b32 %r47,%r32,15; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L48; .loc 1 299 0 add.u32 %r33,%r33,4; .loc 1 300 0 shr.u32 %r32,%r32,4; $L48: .loc 1 302 0 and.b32 %r49,%r32,3; setp.ne.u32 %r50,%r49,0; @ %r50 bra $L49; .loc 1 304 0 add.u32 %r33,%r33,2; .loc 1 305 0 shr.u32 %r32,%r32,2; $L49: .loc 1 307 0 and.b32 %r51,%r32,1; setp.ne.u32 %r52,%r51,0; @ %r52 bra $L50; .loc 1 310 0 shr.u32 %r32,%r32,1; .loc 1 311 0 setp.eq.u32 %r53,%r32,0; @ %r53 bra $L53; .loc 1 309 0 add.u32 %r33,%r33,1; $L50: .loc 1 314 0 st.u32 [%r34],%r32; .loc 1 315 0 bra $L42; $L51: .loc 1 277 0 mov.u32 %r33,0; bra $L42; $L53: .loc 1 312 0 mov.u32 %r33,32; $L42: .loc 1 316 0 mov.u32 %value,%r33; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __i2b .visible .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r27; .reg .u64 %r28; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; .loc 1 323 0 mov.u32 %r27,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r27; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } .loc 1 324 0 st.u32 [%r28+24],%r25; .loc 1 325 0 st.u32 [%r28+20],%r27; .loc 1 327 0 mov.u64 %value,%r28; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __multiply .visible .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r28; .reg .u32 %r29; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r41; .reg .u32 %r62; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u64 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r94; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .pred %r101; .reg .u32 %r102; .reg .pred %r103; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .pred %r109; .reg .u32 %r110; .reg .pred %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .pred %r116; .reg .pred %r117; .reg .u32 %r118; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .pred %r130; .reg .pred %r131; .reg .u32 %r132; .reg .u32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .pred %r146; .reg .pred %r147; .reg .pred %r148; .reg .u32 %r149; .reg .pred %r150; .reg .pred %r151; .reg .u32 %r152; .reg .pred %r153; .reg .u32 %r155; mov.u64 %r96,%ar0; mov.u64 %r97,%ar1; mov.u64 %r98,%ar2; .loc 1 340 0 ld.u32 %r28,[%r97+20]; ld.u32 %r29,[%r98+20]; setp.ge.s32 %r101,%r28,%r29; @ %r101 bra $L56; mov.u32 %r99,%r28; mov.u32 %r28,%r29; mov.u32 %r29,%r99; mov.u64 %r100,%r97; mov.u64 %r97,%r98; mov.u64 %r98,%r100; $L56: .loc 1 346 0 ld.u32 %r67,[%r97+8]; .loc 1 349 0 add.u32 %r79,%r28,%r29; .loc 1 350 0 ld.u32 %r102,[%r97+12]; setp.ge.s32 %r103,%r102,%r79; @ %r103 bra $L57; .loc 1 351 0 add.u32 %r67,%r67,1; $L57: .loc 1 352 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r96; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r67; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r106,[%value_in]; } .loc 1 353 0 add.u64 %r89,%r106,24; cvt.s64.s32 %r107,%r79; shl.b64 %r108,%r107,2; add.u64 %r74,%r89,%r108; setp.ge.u64 %r109,%r89,%r74; @ %r109 bra $L58; mov.u64 %r90,%r89; .loc 1 354 0 mov.u32 %r110,0; $L59: st.u32 [%r90],%r110; .loc 1 353 0 add.u64 %r90,%r90,4; setp.gt.u64 %r111,%r74,%r90; @ %r111 bra $L59; $L58: .loc 1 355 0 add.u64 %r75,%r97,24; .loc 1 356 0 cvt.s64.s32 %r112,%r28; shl.b64 %r113,%r112,2; add.u64 %r76,%r75,%r113; .loc 1 357 0 add.u64 %r88,%r98,24; .loc 1 358 0 cvt.s64.s32 %r114,%r29; shl.b64 %r115,%r114,2; add.u64 %r77,%r88,%r115; .loc 1 361 0 setp.ge.u64 %r116,%r88,%r77; @ %r116 bra $L60; .loc 1 367 0 mov.u32 %r155,0; $L65: .loc 1 363 0 ld.u32 %r37,[%r88]; and.b32 %r80,%r37,65535; setp.eq.u32 %r117,%r80,0; @ %r117 bra $L61; mov.u64 %r91,%r89; .loc 1 365 0 mov.u64 %r70,%r75; .loc 1 367 0 mov.u32 %r68,%r155; $L62: mov.u64 %r71,%r91; .loc 1 370 0 ld.u32 %r38,[%r70]; ld.u32 %r41,[%r91]; and.b32 %r118,%r38,65535; and.b32 %r120,%r41,65535; mad.lo.u32 %r121,%r118,%r80,%r120; add.u32 %r81,%r121,%r68; .loc 1 372 0 add.u64 %r70,%r70,4; shr.u32 %r122,%r38,16; shr.u32 %r124,%r41,16; mad.lo.u32 %r125,%r122,%r80,%r124; .loc 1 371 0 shr.u32 %r126,%r81,16; .loc 1 372 0 add.u32 %r83,%r125,%r126; .loc 1 373 0 shr.u32 %r68,%r83,16; .loc 1 374 0 shl.b32 %r127,%r83,16; and.b32 %r128,%r81,65535; or.b32 %r129,%r127,%r128; st.u32 [%r91],%r129; add.u64 %r91,%r91,4; .loc 1 376 0 setp.gt.u64 %r130,%r76,%r70; @ %r130 bra $L62; .loc 1 377 0 st.u32 [%r71+4],%r68; ld.u32 %r37,[%r88]; $L61: .loc 1 379 0 shr.u32 %r84,%r37,16; setp.eq.u32 %r131,%r84,0; @ %r131 bra $L63; .loc 1 384 0 ld.u32 %r73,[%r89]; mov.u64 %r94,%r75; mov.u32 %r62,%r73; mov.u64 %r72,%r89; .loc 1 383 0 mov.u32 %r69,%r155; bra $L64; $L68: mov.u64 %r72,%r87; $L64: .loc 1 387 0 ld.u16 %r132,[%r94]; shr.u32 %r135,%r62,16; mad.lo.u32 %r136,%r132,%r84,%r135; add.u32 %r85,%r136,%r69; .loc 1 389 0 add.u64 %r87,%r72,4; shl.b32 %r137,%r85,16; and.b32 %r138,%r73,65535; or.b32 %r139,%r137,%r138; st.u32 [%r72],%r139; .loc 1 390 0 ld.u32 %r62,[%r87]; ld.u32 %r141,[%r94]; shr.u32 %r140,%r141,16; and.b32 %r143,%r62,65535; mad.lo.u32 %r144,%r140,%r84,%r143; .loc 1 388 0 shr.u32 %r145,%r85,16; .loc 1 390 0 add.u32 %r73,%r144,%r145; .loc 1 391 0 shr.u32 %r69,%r73,16; add.u64 %r94,%r94,4; .loc 1 393 0 setp.gt.u64 %r146,%r76,%r94; @ %r146 bra $L68; .loc 1 394 0 st.u32 [%r72+4],%r73; $L63: .loc 1 361 0 add.u64 %r88,%r88,4; add.u64 %r89,%r89,4; setp.gt.u64 %r147,%r77,%r88; @ %r147 bra $L65; $L60: .loc 1 416 0 setp.le.s32 %r148,%r79,0; @ %r148 bra $L66; add.u64 %r78,%r74,-4; ld.u32 %r149,[%r74+-4]; setp.ne.u32 %r150,%r149,0; @ %r150 bra $L66; $L67: add.u32 %r79,%r79,-1; setp.eq.u32 %r151,%r79,0; @ %r151 bra $L66; add.u64 %r78,%r78,-4; ld.u32 %r152,[%r78]; setp.eq.u32 %r153,%r152,0; @ %r153 bra $L67; $L66: .loc 1 417 0 st.u32 [%r106+20],%r79; .loc 1 419 0 mov.u64 %value,%r106; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __pow5mult .visible .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r25; .reg .u32 %r26; .reg .u64 %r27; .reg .u64 %r29; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .pred %r51; .reg .pred %r52; .reg .u32 %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u64 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .pred %r70; .reg .u64 %r74; .reg .u64 %r75; mov.u64 %r37,%ar0; mov.u64 %r38,%ar1; mov.u32 %r39,%ar2; .loc 1 429 0 and.b32 %r26,%r39,3; setp.eq.u32 %r40,%r26,0; @ %r40 bra $L84; .loc 1 430 0 cvta.const.u64 %r45,p05$2582; add.u32 %r46,%r26,-1; cvt.s64.s32 %r47,%r46; shl.b64 %r48,%r47,2; add.u64 %r49,%r45,%r48; mov.u32 %r44,0; ld.u32 %r43,[%r49]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r38; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r43; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r44; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r50,[%value_in]; } mov.u64 %r38,%r50; $L84: .loc 1 432 0 shr.s32 %r25,%r39,2; setp.eq.u32 %r51,%r25,0; @ %r51 bra $L90; .loc 1 435 0 ld.u64 %r27,[%r37+112]; setp.ne.u64 %r52,%r27,0; @ %r52 bra $L86; .loc 1 323 0 mov.u32 %r54,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r54; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r55,[%value_in]; } mov.u64 %r27,%r55; .loc 1 324 0 mov.u32 %r56,625; st.u32 [%r27+24],%r56; .loc 1 325 0 st.u32 [%r27+20],%r54; .loc 1 438 0 st.u64 [%r37+112],%r27; .loc 1 439 0 mov.u64 %r58,0; st.u64 [%r27],%r58; $L86: .loc 1 424 0 mov.u64 %r36,%r38; bra $L87; $L89: mov.u64 %r27,%r29; $L87: .loc 1 443 0 and.b32 %r59,%r25,1; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L88; .loc 1 445 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r36; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r64,[%value_in]; } .loc 1 139 0 setp.eq.u64 %r65,%r36,0; @ %r65 bra $L91; .loc 1 141 0 ld.s32 %r66,[%r36+8]; shl.b64 %r67,%r66,3; ld.u64 %r68,[%r37+120]; add.u64 %r34,%r68,%r67; ld.u64 %r35,[%r34]; st.u64 [%r36],%r35; .loc 1 142 0 st.u64 [%r34],%r36; .loc 1 447 0 mov.u64 %r36,%r64; bra $L88; $L91: mov.u64 %r36,%r64; $L88: .loc 1 449 0 shr.s32 %r25,%r25,1; setp.eq.u32 %r69,%r25,0; @ %r69 bra $L83; .loc 1 451 0 ld.u64 %r29,[%r27]; setp.ne.u64 %r70,%r29,0; @ %r70 bra $L89; .loc 1 453 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r74,[%value_in]; } mov.u64 %r29,%r74; st.u64 [%r27],%r29; .loc 1 454 0 mov.u64 %r75,0; st.u64 [%r74],%r75; bra $L89; $L90: .loc 1 433 0 mov.u64 %r36,%r38; $L83: .loc 1 459 0 mov.u64 %value,%r36; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __lshift .visible .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r26; .reg .u64 %r33; .reg .u32 %r36; .reg .u32 %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u64 %r42; .reg .u32 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r58; .reg .u64 %r61; .reg .u64 %r65; .reg .u64 %r69; .reg .u64 %r71; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .pred %r79; .reg .u64 %r82; .reg .pred %r83; .reg .u32 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u32 %r87; .reg .pred %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .pred %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .u32 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; mov.u64 %r73,%ar0; mov.u64 %r74,%ar1; mov.u32 %r75,%ar2; .loc 1 469 0 shr.s32 %r43,%r75,5; .loc 1 473 0 ld.u32 %r48,[%r74+8]; .loc 1 474 0 ld.u32 %r76,[%r74+20]; add.u32 %r26,%r43,%r76; add.u32 %r39,%r26,1; .loc 1 475 0 ld.u32 %r49,[%r74+12]; setp.le.s32 %r77,%r39,%r49; @ %r77 bra $L102; $L103: .loc 1 476 0 add.u32 %r48,%r48,1; .loc 1 475 0 add.u32 %r49,%r49,%r49; setp.gt.s32 %r79,%r39,%r49; @ %r79 bra $L103; $L102: .loc 1 477 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r73; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r82,[%value_in]; } .loc 1 478 0 add.u64 %r56,%r82,24; .loc 1 479 0 setp.le.s32 %r83,%r43,0; @ %r83 bra $L104; mov.u64 %r65,%r56; add.u32 %r84,%r43,-1; cvt.u64.u32 %r69,%r84; shl.b64 %r85,%r69,2; add.u64 %r86,%r85,4; add.u64 %r71,%r86,%r56; .loc 1 480 0 mov.u32 %r87,0; $L105: st.u32 [%r65],%r87; add.u64 %r65,%r65,4; .loc 1 479 0 setp.ne.u64 %r88,%r65,%r71; @ %r88 bra $L105; add.u64 %r89,%r69,1; shl.b64 %r90,%r89,2; add.u64 %r56,%r56,%r90; $L104: .loc 1 481 0 add.u64 %r44,%r74,24; .loc 1 482 0 ld.s32 %r91,[%r74+20]; shl.b64 %r92,%r91,2; add.u64 %r45,%r44,%r92; .loc 1 484 0 and.b32 %r46,%r75,31; setp.eq.u32 %r93,%r46,0; @ %r93 bra $L106; .loc 1 486 0 mov.u32 %r94,32; sub.u32 %r47,%r94,%r46; mov.u64 %r58,%r44; mov.u64 %r42,%r56; .loc 1 487 0 mov.u32 %r41,0; $L107: mov.u64 %r40,%r42; .loc 1 490 0 ld.u32 %r96,[%r58]; shl.b32 %r95,%r96,%r46; or.b32 %r97,%r95,%r41; st.u32 [%r42],%r97; .loc 1 491 0 ld.u32 %r98,[%r58]; shr.u32 %r41,%r98,%r47; add.u64 %r58,%r58,4; add.u64 %r42,%r42,4; .loc 1 493 0 setp.gt.u64 %r99,%r45,%r58; @ %r99 bra $L107; .loc 1 494 0 st.u32 [%r40+4],%r41; setp.eq.u32 %r100,%r41,0; @ %r100 bra $L108; .loc 1 495 0 add.u32 %r39,%r26,2; bra $L108; $L106: mov.u64 %r33,%r44; mov.u64 %r61,%r56; $L109: .loc 1 514 0 ld.u32 %r36,[%r33]; st.u32 [%r61],%r36; add.u64 %r33,%r33,4; add.u64 %r61,%r61,4; .loc 1 515 0 setp.gt.u64 %r101,%r45,%r33; @ %r101 bra $L109; $L108: .loc 1 516 0 add.u32 %r102,%r39,-1; st.u32 [%r82+20],%r102; .loc 1 141 0 ld.s32 %r103,[%r74+8]; shl.b64 %r104,%r103,3; ld.u64 %r105,[%r73+120]; add.u64 %r54,%r105,%r104; ld.u64 %r55,[%r54]; st.u64 [%r74],%r55; .loc 1 142 0 st.u64 [%r54],%r74; .loc 1 519 0 mov.u64 %value,%r82; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __mcmp .visible .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r29; .reg .u64 %r30; .reg .u32 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .pred %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; mov.u64 %r33,%ar0; mov.u64 %r34,%ar1; .loc 1 527 0 ld.u32 %r28,[%r33+20]; .loc 1 528 0 ld.u32 %r29,[%r34+20]; .loc 1 535 0 sub.u32 %r32,%r28,%r29; setp.ne.u32 %r35,%r32,0; @ %r35 bra $L117; .loc 1 537 0 add.u64 %r30,%r33,24; .loc 1 538 0 cvt.s64.s32 %r36,%r29; shl.b64 %r23,%r36,2; add.u64 %r26,%r30,%r23; .loc 1 539 0 add.u64 %r37,%r34,24; .loc 1 540 0 add.u64 %r27,%r37,%r23; $L120: .loc 1 543 0 add.u64 %r26,%r26,-4; ld.u32 %r24,[%r26]; add.u64 %r27,%r27,-4; ld.u32 %r25,[%r27]; setp.eq.u32 %r38,%r24,%r25; @ %r38 bra $L119; .loc 1 544 0 setp.lt.u32 %r39,%r24,%r25; selp.u32 %r32,-1,1,%r39; bra $L117; $L119: .loc 1 545 0 setp.lt.u64 %r40,%r30,%r26; @ %r40 bra $L120; $L117: .loc 1 549 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __mdiff .visible .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r30; .reg .u32 %r32; .reg .u32 %r44; .reg .u32 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u64 %r61; .reg .u64 %r63; .reg .u32 %r65; .reg .u64 %r67; .reg .u32 %r68; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .u32 %r74; .reg .u64 %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u64 %r82; .reg .u64 %r86; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .pred %r103; .reg .u64 %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .u32 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .pred %r125; .reg .pred %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r137; .reg .u64 %r138; .reg .pred %r139; .reg .u32 %r140; .reg .pred %r141; .reg .u32 %r144; .reg .u64 %r145; .reg .u32 %r146; .reg .pred %r148; mov.u64 %r96,%ar0; mov.u64 %r97,%ar1; mov.u64 %r98,%ar2; .loc 1 527 0 ld.u32 %r60,[%r97+20]; .loc 1 528 0 ld.u32 %r74,[%r98+20]; .loc 1 535 0 sub.u32 %r56,%r60,%r74; add.u64 %r94,%r97,24; add.u64 %r58,%r98,24; setp.ne.u32 %r103,%r56,0; @ %r103 bra $L124; .loc 1 538 0 cvt.s64.s32 %r104,%r74; shl.b64 %r76,%r104,2; add.u64 %r77,%r94,%r76; .loc 1 540 0 add.u64 %r79,%r58,%r76; $L128: .loc 1 543 0 add.u64 %r77,%r77,-4; ld.u32 %r78,[%r77]; add.u64 %r79,%r79,-4; ld.u32 %r80,[%r79]; setp.eq.u32 %r105,%r78,%r80; @ %r105 bra $L125; .loc 1 544 0 setp.ge.u32 %r106,%r78,%r80; @ %r106 bra $L126; mov.u64 %r101,%r94; mov.u64 %r94,%r58; mov.u64 %r58,%r101; mov.u64 %r102,%r97; mov.u64 %r97,%r98; mov.u64 %r98,%r102; .loc 1 576 0 mov.u32 %r56,1; bra $L126; $L125: .loc 1 545 0 setp.le.u64 %r107,%r77,%r94; @ ! %r107 bra $L128; bra $L127; $L136: .loc 1 579 0 mov.u32 %r56,0; $L126: .loc 1 580 0 ld.u32 %r110,[%r97+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r96; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r110; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r111,[%value_in]; } mov.u64 %r95,%r111; .loc 1 581 0 st.u32 [%r111+16],%r56; .loc 1 582 0 ld.u32 %r70,[%r97+20]; .loc 1 584 0 cvt.s64.s32 %r112,%r70; shl.b64 %r113,%r112,2; add.u64 %r61,%r94,%r113; .loc 1 587 0 ld.s32 %r114,[%r98+20]; shl.b64 %r115,%r114,2; add.u64 %r63,%r58,%r115; .loc 1 588 0 add.u64 %r59,%r111,24; .loc 1 589 0 mov.u32 %r57,0; bra $L129; $L135: .loc 1 596 0 mov.u64 %r94,%r67; $L129: .loc 1 593 0 ld.u32 %r30,[%r94]; ld.u32 %r32,[%r58]; and.b32 %r116,%r30,65535; add.u32 %r117,%r116,%r57; and.b32 %r118,%r32,65535; sub.u32 %r65,%r117,%r118; .loc 1 596 0 add.u64 %r67,%r94,4; add.u64 %r58,%r58,4; shr.u32 %r119,%r30,16; shr.u32 %r120,%r32,16; sub.u32 %r121,%r119,%r120; .loc 1 594 0 shr.s32 %r122,%r65,16; .loc 1 596 0 add.u32 %r68,%r121,%r122; .loc 1 597 0 shr.s32 %r57,%r68,16; add.u64 %r86,%r59,4; mov.u64 %r82,%r86; .loc 1 599 0 shl.b32 %r123,%r68,16; and.b32 %r124,%r65,65535; or.b32 %r54,%r123,%r124; st.u32 [%r59],%r54; mov.u64 %r59,%r86; .loc 1 601 0 setp.gt.u64 %r125,%r63,%r58; @ %r125 bra $L135; .loc 1 602 0 setp.le.u64 %r126,%r61,%r67; @ %r126 bra $L130; $L131: .loc 1 604 0 ld.u32 %r44,[%r67]; and.b32 %r127,%r44,65535; add.u32 %r71,%r127,%r57; .loc 1 607 0 add.u64 %r67,%r67,4; shr.u32 %r128,%r44,16; .loc 1 605 0 shr.s32 %r129,%r71,16; .loc 1 607 0 add.u32 %r73,%r128,%r129; .loc 1 608 0 shr.s32 %r57,%r73,16; .loc 1 610 0 shl.b32 %r130,%r73,16; and.b32 %r131,%r71,65535; or.b32 %r54,%r130,%r131; st.u32 [%r86],%r54; add.u64 %r86,%r86,4; .loc 1 602 0 setp.gt.u64 %r132,%r61,%r67; @ %r132 bra $L131; sub.u64 %r134,%r61,%r94; add.u64 %r135,%r134,-5; and.b64 %r137,%r135,-4; add.u64 %r138,%r137,4; add.u64 %r82,%r82,%r138; $L130: .loc 1 629 0 add.u64 %r69,%r82,-4; setp.ne.u32 %r139,%r54,0; @ %r139 bra $L132; $L133: .loc 1 630 0 add.u32 %r70,%r70,-1; .loc 1 629 0 add.u64 %r69,%r69,-4; ld.u32 %r140,[%r69]; setp.eq.u32 %r141,%r140,0; @ %r141 bra $L133; $L132: .loc 1 631 0 st.u32 [%r111+20],%r70; .loc 1 632 0 bra $L123; $L127: .loc 1 566 0 mov.u32 %r144,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r96; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r144; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r145,[%value_in]; } mov.u64 %r95,%r145; .loc 1 567 0 mov.u32 %r146,1; st.u32 [%r95+20],%r146; .loc 1 568 0 st.u32 [%r95+24],%r144; .loc 1 569 0 bra $L123; $L124: .loc 1 571 0 setp.ge.s32 %r148,%r56,0; @ %r148 bra $L136; mov.u64 %r99,%r94; mov.u64 %r94,%r58; mov.u64 %r58,%r99; mov.u64 %r100,%r97; mov.u64 %r97,%r98; mov.u64 %r98,%r100; .loc 1 576 0 mov.u32 %r56,1; bra $L126; $L123: .loc 1 633 0 mov.u64 %value,%r95; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ulp .visible .func (.param .f64 %value_out) __ulp (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r24; .reg .u32 %r29; .reg .u32 %r31; .reg .u32 %r32; .reg .u64 %r34; .reg .f64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .pred %r41; .reg .u64 %r42; .reg .pred %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .pred %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u64 %r60; .reg .u64 %r61; mov.f64 %r36,%ar0; .loc 1 643 0 mov.b64 %r37,%r36; shr.u64 %r38,%r37,32; cvt.u32.u64 %r40,%r38; and.b32 %r39,%r40,2146435072; add.u32 %r23,%r39,-54525952; .loc 1 645 0 setp.le.s32 %r41,%r23,0; @ %r41 bra $L141; .loc 1 651 0 cvt.u64.u32 %r42,%r23; .loc 1 653 0 shl.b64 %r34,%r42,32; bra $L142; $L141: .loc 1 660 0 neg.s32 %r24,%r23; shr.s32 %r31,%r24,20; .loc 1 661 0 setp.gt.s32 %r47,%r31,19; @ %r47 bra $L143; .loc 1 663 0 mov.u32 %r49,524288; shr.s32 %r48,%r49,%r31; cvt.u64.u32 %r50,%r48; .loc 1 665 0 shl.b64 %r34,%r50,32; bra $L142; $L143: .loc 1 670 0 mov.u64 %r34,0; .loc 1 671 0 add.u32 %r32,%r31,-20; .loc 1 673 0 setp.gt.s32 %r56,%r32,30; @ %r56 bra $L145; mov.u32 %r58,31; sub.u32 %r57,%r58,%r32; mov.u32 %r59,1; shl.b32 %r29,%r59,%r57; bra $L144; $L145: mov.u32 %r29,1; $L144: cvt.u64.u32 %r60,%r29; and.b64 %r61,%r34,-4294967296; or.b64 %r34,%r61,%r60; $L142: .loc 1 678 0 mov.b64 %value,%r34; .loc 1 679 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __b2d .visible .func (.param .f64 %value_out) __b2d (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r26; .reg .u32 %r33; .reg .u32 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u32 %r44; .reg .u32 %r47; .reg .u32 %r48; .reg .u64 %r53; .reg .f64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .pred %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .pred %r79; .reg .pred %r80; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u32 %r97; .reg .u64 %r98; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .pred %r112; mov.u64 %r55,%ar0; mov.u64 %r56,%ar1; .loc 1 695 0 add.u64 %r38,%r55,24; .loc 1 696 0 ld.s32 %r57,[%r55+20]; shl.b64 %r58,%r57,2; add.u64 %r39,%r38,%r58; .loc 1 697 0 add.u64 %r40,%r39,-4; ld.u32 %r41,[%r39+-4]; .loc 1 702 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r41; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r60,[%value_in]; } .loc 1 703 0 mov.u32 %r62,32; sub.u32 %r61,%r62,%r60; st.u32 [%r56],%r61; .loc 1 705 0 setp.gt.s32 %r63,%r60,10; @ %r63 bra $L147; .loc 1 707 0 mov.u32 %r64,11; sub.u32 %r26,%r64,%r60; shr.u32 %r65,%r41,%r26; or.b32 %r66,%r65,1072693248; cvt.u64.u32 %r67,%r66; shl.b64 %r53,%r67,32; .loc 1 708 0 setp.ge.u64 %r71,%r38,%r40; @ %r71 bra $L154; ld.u32 %r72,[%r39+-8]; shr.u32 %r48,%r72,%r26; bra $L148; $L154: mov.u32 %r48,0; $L148: .loc 1 710 0 add.u32 %r73,%r60,21; shl.b32 %r74,%r41,%r73; or.b32 %r75,%r74,%r48; cvt.u64.u32 %r76,%r75; and.b64 %r77,%r53,-4294967296; or.b64 %r53,%r77,%r76; .loc 1 712 0 bra $L149; $L147: add.u32 %r37,%r60,-11; .loc 1 714 0 setp.ge.u64 %r79,%r38,%r40; @ %r79 bra $L150; ld.u32 %r44,[%r39+-8]; .loc 1 715 0 setp.eq.u32 %r80,%r37,0; @ %r80 bra $L151; .loc 1 717 0 sub.u32 %r33,%r62,%r37; shl.b32 %r82,%r41,%r37; or.b32 %r83,%r82,1072693248; shr.u32 %r84,%r44,%r33; or.b32 %r85,%r83,%r84; cvt.u64.u32 %r86,%r85; shl.b64 %r53,%r86,32; shl.b32 %r47,%r44,%r37; .loc 1 714 0 add.u64 %r90,%r39,-8; .loc 1 718 0 setp.ge.u64 %r91,%r38,%r90; @ %r91 bra $L152; ld.u32 %r93,[%r39+-12]; shr.u32 %r92,%r93,%r33; or.b32 %r47,%r47,%r92; $L152: .loc 1 720 0 cvt.u64.u32 %r94,%r47; and.b64 %r95,%r53,-4294967296; or.b64 %r53,%r95,%r94; bra $L149; $L151: .loc 1 725 0 or.b32 %r97,%r41,1072693248; cvt.u64.u32 %r98,%r97; .loc 1 727 0 cvt.u64.u32 %r102,%r44; shl.b64 %r103,%r98,32; or.b64 %r53,%r103,%r102; $L149: .loc 1 755 0 mov.b64 %r54,%r53; bra $L158; $L153: .loc 1 717 0 shl.b32 %r106,%r41,%r37; or.b32 %r107,%r106,1072693248; cvt.u64.u32 %r108,%r107; shl.b64 %r53,%r108,32; mov.u32 %r47,0; bra $L152; $L150: .loc 1 715 0 setp.ne.u32 %r112,%r37,0; @ %r112 bra $L153; .loc 1 714 0 mov.u32 %r44,%r37; bra $L151; $L158: .loc 1 756 0 mov.f64 %value,%r54; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __d2b .visible .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r22; .reg .u32 %r23; .reg .u32 %r25; .reg .u32 %r30; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r50; .reg .u32 %r51; .reg .u64 %r54; .reg .f64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u32 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u32 %r65; .reg .u64 %r66; .reg .pred %r67; .reg .u64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; mov.u64 %r54,%ar0; mov.f64 %r55,%ar1; mov.u64 %r56,%ar2; mov.u64 %r57,%ar3; .loc 1 785 0 mov.u32 %r59,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r54; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r59; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r60,[%value_in]; } mov.b64 %r61,%r55; shr.u64 %r62,%r61,32; cvt.u32.u64 %r51,%r62; .loc 1 791 0 and.b32 %r22,%r51,1048575; .loc 1 799 0 shr.u32 %r63,%r51,20; and.b32 %r23,%r63,2047; setp.ne.u32 %r64,%r23,0; @ %r64 bra $L160; .loc 1 791 0 st.u32 [%frame],%r22; bra $L161; $L160: .loc 1 800 0 or.b32 %r65,%r22,1048576; st.u32 [%frame],%r65; $L161: mov.b64 %r66,%r55; cvt.u32.u64 %r50,%r66; .loc 1 804 0 setp.eq.u32 %r67,%r50,0; @ %r67 bra $L162; .loc 1 806 0 st.u32 [%frame+4],%r50; .loc 1 807 0 add.u64 %r69,%frame,4; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r69; call (%value_in),__lo0bits,(%out_arg1); ld.param.u32 %r70,[%value_in]; } mov.u32 %r46,%r70; .loc 1 808 0 setp.eq.u32 %r71,%r46,0; @ %r71 bra $L163; .loc 1 810 0 ld.u32 %r25,[%frame]; mov.u32 %r73,32; sub.u32 %r72,%r73,%r46; shl.b32 %r74,%r25,%r72; ld.u32 %r76,[%frame+4]; or.b32 %r75,%r74,%r76; st.u32 [%r60+24],%r75; .loc 1 811 0 shr.u32 %r30,%r25,%r46; st.u32 [%frame],%r30; bra $L164; $L163: .loc 1 814 0 ld.u32 %r77,[%frame+4]; st.u32 [%r60+24],%r77; ld.u32 %r30,[%frame]; $L164: .loc 1 815 0 st.u32 [%r60+28],%r30; setp.eq.u32 %r78,%r30,0; selp.u32 %r45,1,2,%r78; st.u32 [%r60+20],%r45; bra $L166; $L162: .loc 1 824 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),__lo0bits,(%out_arg1); ld.param.u32 %r80,[%value_in]; } .loc 1 825 0 ld.u32 %r81,[%frame]; st.u32 [%r60+24],%r81; .loc 1 826 0 mov.u32 %r82,1; st.u32 [%r60+20],%r82; .loc 1 828 0 add.u32 %r46,%r80,32; .loc 1 826 0 mov.u32 %r45,%r82; $L166: .loc 1 886 0 setp.eq.u32 %r83,%r23,0; @ %r83 bra $L167; .loc 1 893 0 add.u32 %r84,%r23,-1075; add.u32 %r85,%r84,%r46; st.u32 [%r56],%r85; .loc 1 894 0 mov.u32 %r87,53; sub.u32 %r86,%r87,%r46; st.u32 [%r57],%r86; bra $L159; $L167: .loc 1 900 0 add.u32 %r88,%r46,-1074; st.u32 [%r56],%r88; .loc 1 902 0 cvt.s64.s32 %r90,%r45; shl.b64 %r91,%r90,2; add.u64 %r92,%r60,%r91; ld.u32 %r89,[%r92+20]; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r89; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r94,[%value_in]; } shl.b32 %r95,%r45,5; sub.u32 %r96,%r95,%r94; st.u32 [%r57],%r96; $L159: .loc 1 909 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ratio .visible .func (.param .f64 %value_out) __ratio (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .f64 %r22; .reg .u32 %r35; .reg .f64 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r47; .reg .f64 %r48; .reg .f64 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .u32 %r70; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; mov.u64 %r43,%ar0; mov.u64 %r44,%ar1; .loc 1 920 0 add.u64 %r47,%frame,4; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r43; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r47; call (%value_in),__b2d,(%out_arg1,%out_arg2); ld.param.f64 %r48,[%value_in]; } mov.f64 %r39,%r48; mov.b64 %r40,%r39; .loc 1 921 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r44; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__b2d,(%out_arg1,%out_arg2); ld.param.f64 %r51,[%value_in]; } mov.f64 %r22,%r51; mov.b64 %r41,%r22; .loc 1 923 0 ld.u32 %r53,[%r43+20]; ld.u32 %r54,[%r44+20]; sub.u32 %r52,%r53,%r54; shl.b32 %r55,%r52,5; ld.u32 %r57,[%frame+4]; ld.u32 %r58,[%frame]; sub.u32 %r56,%r57,%r58; add.u32 %r35,%r55,%r56; .loc 1 942 0 setp.le.s32 %r59,%r35,0; @ %r59 bra $L171; .loc 1 943 0 shl.b32 %r60,%r35,20; shr.u64 %r62,%r40,32; cvt.u32.u64 %r64,%r62; add.u32 %r63,%r60,%r64; cvt.u64.u32 %r65,%r63; shl.b64 %r66,%r65,32; and.b64 %r67,%r40,4294967295; or.b64 %r68,%r67,%r66; mov.b64 %r39,%r68; bra $L172; $L171: .loc 1 947 0 shl.b32 %r70,%r35,20; shr.u64 %r73,%r41,32; cvt.u32.u64 %r75,%r73; sub.u32 %r74,%r75,%r70; cvt.u64.u32 %r76,%r74; shl.b64 %r77,%r76,32; and.b64 %r78,%r41,4294967295; or.b64 %r79,%r78,%r77; mov.b64 %r22,%r79; $L172: .loc 1 950 0 div.rn.f64 %value,%r39,%r22; .loc 1 951 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _mprec_log10 .visible .func (.param .f64 %value_out) _mprec_log10 (.param .u32 %in_ar0) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %r24; .reg .u32 %r25; .reg .pred %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .pred %r31; mov.u32 %r25,%ar0; .loc 1 983 0 setp.gt.s32 %r26,%r25,23; @ %r26 bra $L176; .loc 1 984 0 cvta.const.u64 %r27,__mprec_tens; cvt.s64.s32 %r28,%r25; shl.b64 %r29,%r28,3; add.u64 %r30,%r27,%r29; ld.f64 %r24,[%r30]; bra $L173; $L176: .loc 1 982 0 mov.f64 %r24,0d3ff0000000000000; $L174: .loc 1 987 0 mul.f64 %r24,%r24,0d4024000000000000; .loc 1 988 0 add.u32 %r25,%r25,-1; .loc 1 985 0 setp.ne.u32 %r31,%r25,0; @ %r31 bra $L174; $L173: .loc 1 991 0 mov.f64 %value,%r24; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __copybits .visible .func __copybits (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r30; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .pred %r60; .reg .pred %r61; .reg .u64 %r63; .reg .u64 %r65; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .u32 %r70; .reg .pred %r71; mov.u64 %r50,%ar0; mov.u32 %r51,%ar1; mov.u64 %r52,%ar2; .loc 1 1004 0 add.u32 %r53,%r51,-1; shr.s32 %r54,%r53,5; cvt.s64.s32 %r55,%r54; add.u64 %r56,%r55,1; shl.b64 %r57,%r56,2; add.u64 %r35,%r50,%r57; .loc 1 1005 0 add.u64 %r36,%r52,24; .loc 1 1007 0 ld.s32 %r58,[%r52+20]; shl.b64 %r59,%r58,2; add.u64 %r37,%r36,%r59; .loc 1 1008 0 setp.ge.u64 %r60,%r36,%r37; @ %r60 bra $L179; mov.u64 %r45,%r50; mov.u64 %r46,%r36; $L180: .loc 1 1009 0 ld.u32 %r30,[%r46]; st.u32 [%r45],%r30; add.u64 %r45,%r45,4; add.u64 %r46,%r46,4; .loc 1 1008 0 setp.gt.u64 %r61,%r37,%r46; @ %r61 bra $L180; sub.u64 %r63,%r37,%r52; add.u64 %r65,%r63,-25; and.b64 %r67,%r65,-4; add.u64 %r68,%r67,4; add.u64 %r50,%r50,%r68; $L179: .loc 1 1018 0 setp.le.u64 %r69,%r35,%r50; @ %r69 bra $L178; mov.u64 %r34,%r50; .loc 1 1019 0 mov.u32 %r70,0; $L182: st.u32 [%r34],%r70; add.u64 %r34,%r34,4; .loc 1 1018 0 setp.gt.u64 %r71,%r35,%r34; @ %r71 bra $L182; $L178: .loc 1 1020 0 ret; } // BEGIN GLOBAL FUNCTION DEF: __any_on .visible .func (.param .u32 %value_out) __any_on (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .u32 %r27; .reg .u32 %r28; .reg .u64 %r30; .reg .u64 %r33; .reg .u32 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .u32 %r50; .reg .pred %r51; .reg .pred %r52; mov.u64 %r37,%ar0; mov.u32 %r38,%ar1; .loc 1 1030 0 add.u64 %r23,%r37,24; .loc 1 1031 0 ld.u32 %r24,[%r37+20]; .loc 1 1032 0 shr.s32 %r25,%r38,5; .loc 1 1033 0 setp.ge.s32 %r39,%r24,%r25; @ %r39 bra $L186; cvt.s64.s32 %r40,%r24; shl.b64 %r41,%r40,2; add.u64 %r33,%r23,%r41; bra $L187; $L186: cvt.s64.s32 %r42,%r25; shl.b64 %r43,%r42,2; add.u64 %r33,%r23,%r43; .loc 1 1035 0 setp.le.s32 %r44,%r24,%r25; @ %r44 bra $L187; and.b32 %r26,%r38,31; setp.eq.u32 %r45,%r26,0; @ %r45 bra $L187; .loc 1 1036 0 ld.u32 %r27,[%r33]; .loc 1 1037 0 shr.u32 %r28,%r27,%r26; .loc 1 1038 0 shl.b32 %r46,%r28,%r26; .loc 1 1039 0 setp.ne.u32 %r47,%r27,%r46; @ %r47 bra $L191; $L187: .loc 1 1044 0 setp.ge.u64 %r48,%r23,%r33; @ %r48 bra $L192; .loc 1 1045 0 add.u64 %r30,%r33,-4; ld.u32 %r36,[%r33+-4]; setp.ne.u32 %r49,%r36,0; @ ! %r49 bra $L189; bra $L193; $L190: add.u64 %r30,%r30,-4; ld.u32 %r50,[%r30]; setp.ne.u32 %r51,%r50,0; @ %r51 bra $L194; $L189: .loc 1 1044 0 setp.lt.u64 %r52,%r23,%r30; @ %r52 bra $L190; bra $L185; $L191: .loc 1 1040 0 mov.u32 %r36,1; bra $L185; $L192: .loc 1 1047 0 mov.u32 %r36,0; bra $L185; $L193: .loc 1 1040 0 mov.u32 %r36,1; bra $L185; $L194: mov.u32 %r36,1; $L185: .loc 1 1048 0 mov.u32 %value,%r36; st.param.u32 [%value_out],%value; ret; } lib_a-mrand48.o/0 0 0 644 1735 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _mrand48_r .visible .func (.param .u64 %value_out) _mrand48_r (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/mrand48.c" // BEGIN GLOBAL FUNCTION DECL: mrand48 .visible .func (.param .u64 %value_out) mrand48; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _mrand48_r .visible .func (.param .u64 %value_out) _mrand48_r (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r29; .reg .u64 %r32; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; mov.u64 %r29,%ar0; .loc 1 21 0 add.u64 %r32,%r29,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r32; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r34,[%r29+244]; shl.b64 %r35,%r34,16; ld.u16 %r36,[%r29+242]; add.u64 %value,%r35,%r36; .loc 1 23 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: mrand48 .visible .func (.param .u64 %value_out) mrand48 { .reg .u64 %value; .reg .u64 %r22; .reg .u64 %r32; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .loc 1 29 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 21 0 add.u64 %r32,%r22,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r22; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r32; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r34,[%r22+244]; shl.b64 %r35,%r34,16; ld.u16 %r36,[%r22+242]; add.u64 %value,%r35,%r36; .loc 1 30 0 st.param.u64 [%value_out],%value; ret; } /158 0 0 0 644 19831 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: nl_langinfo .visible .func (.param .u64 %value_out) nl_langinfo (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/locale/nl_langinfo.c" // BEGIN GLOBAL FUNCTION DECL: setlocale .extern .func (.param .u64 %value_out) setlocale (.param .u32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strncmp .extern .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __nvptx_realloc .extern .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strstr .extern .func (.param .u64 %value_out) strstr (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __get_current_time_locale .extern .func (.param .u64 %value_out) __get_current_time_locale; // BEGIN GLOBAL FUNCTION DECL: __get_current_numeric_locale .extern .func (.param .u64 %value_out) __get_current_numeric_locale; // BEGIN GLOBAL FUNCTION DECL: __get_current_messages_locale .extern .func (.param .u64 %value_out) __get_current_messages_locale; // BEGIN GLOBAL FUNCTION DECL: __get_current_monetary_locale .extern .func (.param .u64 %value_out) __get_current_monetary_locale; // BEGIN GLOBAL FUNCTION DECL: localeconv .extern .func (.param .u64 %value_out) localeconv; // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcat .extern .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[6] = {122,104,95,67,78,0 }; // BEGIN VAR DEF: cset$2276 .global .align 8 .u64 cset$2276[1]; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN VAR DEF: csym$2275 .global .align 8 .u64 csym$2275[1]; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[6] = {65,83,67,73,73,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[2] = {67,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[6] = {80,79,83,73,88,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[4] = {73,83,79,0 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {101,117,99,75,82,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[9] = {85,83,45,65,83,67,73,73,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[6] = {101,117,99,74,80,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[6] = {101,117,99,67,78,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[5] = {73,83,79,95,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[4] = {69,85,67,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[6] = {106,97,95,74,80,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[6] = {107,111,95,75,82,0 }; // BEGIN GLOBAL FUNCTION DEF: nl_langinfo .visible .func (.param .u64 %value_out) nl_langinfo (.param .u32 %in_ar0) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %r26; .reg .u32 %r67; .reg .u64 %r75; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r86; .reg .u64 %r87; .reg .u32 %r88; .reg .pred %r89; .reg .pred %r90; .reg .pred %r91; .reg .pred %r92; .reg .pred %r93; .reg .pred %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .pred %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .pred %r113; .reg .pred %r114; .reg .pred %r115; .reg .u32 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .pred %r119; .reg .u32 %r121; .reg .u64 %r122; .reg .pred %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u32 %r127; .reg .pred %r128; .reg .u64 %r130; .reg .u64 %r133; .reg .u32 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .pred %r137; .reg .pred %r138; .reg .u64 %r141; .reg .u32 %r142; .reg .pred %r143; .reg .u64 %r145; .reg .u64 %r146; .reg .u32 %r147; .reg .pred %r148; .reg .u64 %r150; .reg .u32 %r152; .reg .pred %r153; .reg .u64 %r155; .reg .u32 %r157; .reg .pred %r158; .reg .u64 %r160; .reg .u32 %r161; .reg .pred %r162; .reg .u64 %r164; .reg .u32 %r165; .reg .pred %r166; .reg .u64 %r168; .reg .u32 %r169; .reg .pred %r170; .reg .u64 %r172; .reg .u64 %r173; .reg .pred %r174; .reg .u64 %r175; .reg .u64 %r176; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .u32 %r182; .reg .u64 %r183; .reg .u64 %r184; .reg .u64 %r185; .reg .u64 %r186; .reg .u64 %r187; .reg .u32 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .u64 %r193; .reg .u32 %r194; .reg .u64 %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u64 %r198; .reg .u64 %r199; .reg .u32 %r200; .reg .u64 %r201; .reg .u64 %r202; .reg .u64 %r203; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u64 %r211; .reg .u64 %r212; .reg .u64 %r213; .reg .u64 %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .u16 %r217; .reg .u32 %r218; .reg .pred %r219; .reg .u64 %r220; .reg .u64 %r221; .reg .u16 %r222; .reg .u16 %r223; .reg .pred %r224; .reg .pred %r226; .reg .u64 %r227; .reg .u64 %r230; .reg .u32 %r231; .reg .pred %r232; .reg .pred %r233; .reg .u64 %r235; .reg .u32 %r238; .reg .u32 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .pred %r243; .reg .pred %r244; .reg .u64 %r246; .reg .u64 %r248; .reg .u64 %r250; .reg .u64 %r251; .reg .u64 %r254; .reg .u64 %r255; .reg .u64 %r256; .reg .u32 %r257; .reg .u64 %r260; .reg .u64 %r261; .reg .u64 %r262; mov.u32 %r88,%ar0; .loc 1 195 0 setp.gt.s32 %r89,%r88,44; @ %r89 bra $L3; setp.ge.s32 %r90,%r88,33; @ %r90 bra $L4; setp.eq.u32 %r91,%r88,6; @ %r91 bra $L5; setp.gt.s32 %r92,%r88,6; @ %r92 bra $L6; setp.eq.u32 %r93,%r88,2; @ %r93 bra $L7; setp.gt.s32 %r94,%r88,2; @ %r94 bra $L8; setp.eq.u32 %r95,%r88,0; @ %r95 bra $L9; setp.eq.u32 %r96,%r88,1; @ %r96 bra $L10; bra $L46; $L8: setp.eq.u32 %r97,%r88,4; @ %r97 bra $L11; setp.gt.s32 %r98,%r88,4; @ ! %r98 bra $L66; bra $L12; $L6: setp.gt.s32 %r99,%r88,20; @ %r99 bra $L14; setp.ge.s32 %r100,%r88,14; @ ! %r100 bra $L67; bra $L15; $L3: setp.eq.u32 %r101,%r88,51; @ %r101 bra $L17; setp.gt.s32 %r102,%r88,51; @ %r102 bra $L18; setp.eq.u32 %r103,%r88,47; @ %r103 bra $L19; setp.gt.s32 %r104,%r88,47; @ %r104 bra $L20; setp.eq.u32 %r105,%r88,45; @ %r105 bra $L21; setp.eq.u32 %r106,%r88,46; @ %r106 bra $L22; bra $L46; $L20: setp.eq.u32 %r107,%r88,49; @ %r107 bra $L23; setp.gt.s32 %r108,%r88,49; @ ! %r108 bra $L68; bra $L24; $L18: setp.eq.u32 %r109,%r88,55; @ %r109 bra $L26; setp.gt.s32 %r110,%r88,55; @ %r110 bra $L27; setp.eq.u32 %r111,%r88,53; @ %r111 bra $L28; setp.gt.s32 %r112,%r88,53; @ ! %r112 bra $L69; bra $L29; $L27: setp.eq.u32 %r113,%r88,57; @ %r113 bra $L31; setp.lt.s32 %r114,%r88,57; @ %r114 bra $L32; setp.eq.u32 %r115,%r88,84; @ %r115 bra $L33; bra $L46; $L9: .loc 1 267 0 mov.u64 %r117,0; mov.u32 %r116,2; { .param .u64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r116; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r117; call (%value_in),setlocale,(%out_arg1,%out_arg2); ld.param.u64 %r118,[%value_in]; } setp.ne.u64 %r119,%r118,0; @ %r119 bra $L34; $L41: .loc 1 266 0 cvta.const.u64 %r87,$LC1; bra $L1; $L34: .loc 1 268 0 mov.u32 %r121,46; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r121; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r122,[%value_in]; } setp.eq.u64 %r123,%r122,0; @ %r123 bra $L35; .loc 1 269 0 add.u64 %r87,%r122,1; .loc 1 271 0 mov.u64 %r126,4; cvta.const.u64 %r125,$LC5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r125; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r126; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r127,[%value_in]; } setp.ne.u32 %r128,%r127,0; @ %r128 bra $L36; .loc 1 272 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r130,[%value_in]; } .loc 1 274 0 cvt.u32.u64 %r134,%r130; cvt.s64.s32 %r133,%r134; ld.global.u64 %r135,[cset$2276]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r135; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r133; call (%value_in),__nvptx_realloc,(%out_arg1,%out_arg2); ld.param.u64 %r136,[%value_in]; } .loc 1 276 0 setp.ne.u64 %r137,%r136,0; @ %r137 bra $L37; ld.global.u64 %r26,[cset$2276]; setp.eq.u64 %r138,%r26,0; @ %r138 bra $L38; .loc 1 277 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call __nvptx_free,(%out_arg1); } bra $L38; $L36: .loc 1 286 0 cvta.const.u64 %r141,$LC6; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r141; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r142,[%value_in]; } setp.ne.u32 %r143,%r142,0; @ %r143 bra $L39; .loc 1 287 0 mov.u64 %r146,5; cvta.const.u64 %r145,$LC7; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r145; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r146; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r147,[%value_in]; } setp.eq.u32 %r148,%r147,0; @ %r148 bra $L47; .loc 1 289 0 cvta.const.u64 %r150,$LC8; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r150; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r146; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r152,[%value_in]; } setp.eq.u32 %r153,%r152,0; @ %r153 bra $L48; .loc 1 291 0 cvta.const.u64 %r155,$LC9; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r155; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r146; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r157,[%value_in]; } setp.ne.u32 %r158,%r157,0; @ %r158 bra $L1; .loc 1 292 0 cvta.const.u64 %r87,$LC4; bra $L1; $L39: .loc 1 293 0 cvta.const.u64 %r160,$LC10; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r160; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r161,[%value_in]; } setp.ne.u32 %r162,%r161,0; @ %r162 bra $L1; $L40: .loc 1 294 0 cvta.const.u64 %r87,$LC2; bra $L1; $L35: .loc 1 296 0 cvta.const.u64 %r164,$LC11; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r164; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r165,[%value_in]; } setp.eq.u32 %r166,%r165,0; @ %r166 bra $L40; .loc 1 297 0 cvta.const.u64 %r168,$LC12; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r168; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r169,[%value_in]; } .loc 1 296 0 setp.eq.u32 %r170,%r169,0; @ %r170 bra $L40; .loc 1 299 0 cvta.const.u64 %r172,$LC10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r172; call (%value_in),strstr,(%out_arg1,%out_arg2); ld.param.u64 %r173,[%value_in]; } setp.ne.u64 %r174,%r173,0; @ %r174 bra $L40; bra $L41; $L10: .loc 1 307 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r175,[%value_in]; } ld.u64 %r87,[%r175+320]; .loc 1 308 0 bra $L1; $L7: .loc 1 310 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r176,[%value_in]; } ld.u64 %r87,[%r176+312]; .loc 1 311 0 bra $L1; $L66: .loc 1 313 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r177,[%value_in]; } ld.u64 %r87,[%r177+304]; .loc 1 314 0 bra $L1; $L11: .loc 1 316 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r178,[%value_in]; } ld.u64 %r87,[%r178+456]; .loc 1 317 0 bra $L1; $L12: .loc 1 319 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r179,[%value_in]; } ld.u64 %r87,[%r179+328]; .loc 1 320 0 bra $L1; $L5: .loc 1 322 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r180,[%value_in]; } ld.u64 %r87,[%r180+336]; .loc 1 323 0 bra $L1; $L67: .loc 1 326 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r181,[%value_in]; } add.u32 %r182,%r88,-7; cvt.s64.s32 %r183,%r182; add.u64 %r184,%r183,31; shl.b64 %r185,%r184,3; add.u64 %r186,%r181,%r185; ld.u64 %r87,[%r186]; .loc 1 327 0 bra $L1; $L15: .loc 1 330 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r187,[%value_in]; } add.u32 %r188,%r88,-14; cvt.s64.s32 %r189,%r188; add.u64 %r190,%r189,24; shl.b64 %r191,%r190,3; add.u64 %r192,%r187,%r191; ld.u64 %r87,[%r192]; .loc 1 331 0 bra $L1; $L14: .loc 1 335 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r193,[%value_in]; } add.u32 %r194,%r88,-21; cvt.s64.s32 %r195,%r194; add.u64 %r196,%r195,12; shl.b64 %r197,%r196,3; add.u64 %r198,%r193,%r197; ld.u64 %r87,[%r198]; .loc 1 336 0 bra $L1; $L4: .loc 1 340 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r199,[%value_in]; } add.u32 %r200,%r88,-33; cvt.s64.s32 %r201,%r200; shl.b64 %r202,%r201,3; add.u64 %r203,%r199,%r202; ld.u64 %r87,[%r203]; .loc 1 341 0 bra $L1; $L21: .loc 1 343 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r204,[%value_in]; } ld.u64 %r87,[%r204+464]; .loc 1 344 0 bra $L1; $L22: .loc 1 346 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r205,[%value_in]; } ld.u64 %r87,[%r205+472]; .loc 1 347 0 bra $L1; $L19: .loc 1 349 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r206,[%value_in]; } ld.u64 %r87,[%r206+480]; .loc 1 350 0 bra $L1; $L68: .loc 1 352 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r207,[%value_in]; } ld.u64 %r87,[%r207+488]; .loc 1 353 0 bra $L1; $L23: .loc 1 355 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r208,[%value_in]; } ld.u64 %r87,[%r208+496]; .loc 1 356 0 bra $L1; $L33: .loc 1 358 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r209,[%value_in]; } ld.u64 %r87,[%r209+344]; .loc 1 359 0 bra $L1; $L24: .loc 1 361 0 { .param .u64 %value_in; call (%value_in),__get_current_numeric_locale; ld.param.u64 %r210,[%value_in]; } ld.u64 %r87,[%r210]; .loc 1 362 0 bra $L1; $L17: .loc 1 364 0 { .param .u64 %value_in; call (%value_in),__get_current_numeric_locale; ld.param.u64 %r211,[%value_in]; } ld.u64 %r87,[%r211+8]; .loc 1 365 0 bra $L1; $L69: .loc 1 367 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r212,[%value_in]; } ld.u64 %r87,[%r212]; .loc 1 368 0 bra $L1; $L28: .loc 1 370 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r213,[%value_in]; } ld.u64 %r87,[%r213+8]; .loc 1 371 0 bra $L1; $L29: .loc 1 378 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r214,[%value_in]; } ld.u64 %r87,[%r214+16]; .loc 1 379 0 bra $L1; $L26: .loc 1 381 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r215,[%value_in]; } ld.u64 %r87,[%r215+24]; .loc 1 382 0 bra $L1; $L32: .loc 1 385 0 { .param .u64 %value_in; call (%value_in),__get_current_monetary_locale; ld.param.u64 %r216,[%value_in]; } ld.u64 %r78,[%r216+8]; .loc 1 386 0 ld.s8 %r218,[%r78]; cvt.u16.u32 %r217,%r218; setp.eq.u16 %r219,%r217,0; @ %r219 bra $L41; .loc 1 387 0 { .param .u64 %value_in; call (%value_in),localeconv; ld.param.u64 %r220,[%value_in]; } ld.s8 %r79,[%r220+82]; .loc 1 389 0 { .param .u64 %value_in; call (%value_in),localeconv; ld.param.u64 %r221,[%value_in]; } ld.s8 %r67,[%r221+84]; cvt.u16.u32 %r222,%r67; cvt.u16.u32 %r223,%r79; setp.ne.u16 %r224,%r222,%r223; @ %r224 bra $L41; .loc 1 392 0 setp.ne.u16 %r226,%r222,127; @ %r226 bra $L42; .loc 1 393 0 { .param .u64 %value_in; call (%value_in),__get_current_monetary_locale; ld.param.u64 %r227,[%value_in]; } ld.u64 %r230,[%r227+16]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r78; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r230; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r231,[%value_in]; } setp.eq.u32 %r232,%r231,0; @ %r232 bra $L49; bra $L41; $L42: .loc 1 396 0 setp.ne.u32 %r233,%r67,0; selp.u32 %r86,45,43,%r233; bra $L43; $L49: .loc 1 394 0 mov.u32 %r86,46; $L43: .loc 1 398 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r78; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r235,[%value_in]; } .loc 1 400 0 cvt.u32.u64 %r239,%r235; add.u32 %r238,%r239,2; cvt.s64.s32 %r240,%r238; ld.global.u64 %r241,[csym$2275]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r241; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r240; call (%value_in),__nvptx_realloc,(%out_arg1,%out_arg2); ld.param.u64 %r242,[%value_in]; } .loc 1 401 0 setp.ne.u64 %r243,%r242,0; @ %r243 bra $L44; ld.global.u64 %r75,[csym$2275]; setp.eq.u64 %r244,%r75,0; @ %r244 bra $L45; .loc 1 402 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r75; call __nvptx_free,(%out_arg1); } bra $L45; $L31: .loc 1 416 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r246,[%value_in]; } ld.u64 %r87,[%r246+448]; .loc 1 417 0 bra $L1; $L46: .loc 1 432 0 cvta.const.u64 %r87,$LC1; bra $L1; $L47: .loc 1 288 0 cvta.const.u64 %r87,$LC3; bra $L1; $L48: .loc 1 290 0 cvta.const.u64 %r87,$LC0; .loc 1 434 0 bra $L1; $L38: .loc 1 279 0 mov.u64 %r248,0; st.global.u64 [cset$2276],%r248; .loc 1 285 0 cvta.const.u64 %r87,$LC1; bra $L1; $L37: .loc 1 279 0 st.global.u64 [cset$2276],%r136; .loc 1 281 0 cvta.const.u64 %r250,$LC13; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r250; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r251,[%value_in]; } .loc 1 282 0 add.u64 %r254,%r122,5; ld.global.u64 %r255,[cset$2276]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r255; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r254; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r256,[%value_in]; } .loc 1 283 0 ld.global.u64 %r87,[cset$2276]; bra $L1; $L44: .loc 1 404 0 st.global.u64 [csym$2275],%r242; .loc 1 407 0 cvt.u32.u32 %r257,%r86; st.u8 [%r242],%r257; .loc 1 408 0 add.u64 %r260,%r242,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r260; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r78; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r261,[%value_in]; } .loc 1 409 0 ld.global.u64 %r87,[csym$2275]; bra $L1; $L45: .loc 1 404 0 mov.u64 %r262,0; st.global.u64 [csym$2275],%r262; .loc 1 384 0 cvta.const.u64 %r87,$LC1; $L1: .loc 1 435 0 mov.u64 %value,%r87; st.param.u64 [%value_out],%value; ret; } lib_a-nrand48.o/0 0 0 644 2161 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _nrand48_r .visible .func (.param .u64 %value_out) _nrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/nrand48.c" // BEGIN GLOBAL FUNCTION DECL: nrand48 .visible .func (.param .u64 %value_out) nrand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _nrand48_r .visible .func (.param .u64 %value_out) _nrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u64 %r39; .reg .u16 %r40; mov.u64 %r30,%ar0; mov.u64 %r31,%ar1; .loc 1 21 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r30; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r35,[%r31+4]; shl.b64 %r36,%r35,15; .loc 1 23 0 ld.u16 %r37,[%r31+2]; shr.u32 %r38,%r37,1; cvt.u16.u32 %r40,%r38; cvt.u64.u16 %r39,%r40; .loc 1 22 0 add.u64 %value,%r36,%r39; .loc 1 24 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: nrand48 .visible .func (.param .u64 %value_out) nrand48 (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r31; .reg .u64 %r34; .reg .u64 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u16 %r41; mov.u64 %r31,%ar0; .loc 1 21 0 ld.global.u64 %r34,[_impure_ptr]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r34; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r36,[%r31+4]; shl.b64 %r37,%r36,15; .loc 1 23 0 ld.u16 %r38,[%r31+2]; shr.u32 %r39,%r38,1; cvt.u16.u32 %r41,%r39; cvt.u64.u16 %r40,%r41; .loc 1 22 0 add.u64 %value,%r37,%r40; .loc 1 32 0 st.param.u64 [%value_out],%value; ret; } lib_a-printf.o/ 0 0 0 644 991 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: printf .visible .func (.param .u32 %value_out) printf (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/machine/nvptx/printf.c" // BEGIN GLOBAL FUNCTION DECL: vprintf .extern .func (.param .u32 %value_out) vprintf (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: printf .visible .func (.param .u32 %value_out) printf (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %args; ld.param.u64 %args,[%in_ar1]; .reg .u64 %r24; .reg .u32 %r28; mov.u64 %r24,%ar0; .loc 1 27 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%args; call (%value_in),vprintf,(%out_arg1,%out_arg2); ld.param.u32 %r28,[%value_in]; } .loc 1 30 0 mov.u32 %value,%r28; st.param.u32 [%value_out],%value; ret; } lib_a-putchar.o/0 0 0 644 1248 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: putchar .visible .func (.param .u32 %value_out) putchar (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/machine/nvptx/putchar.c" // BEGIN GLOBAL FUNCTION DECL: vprintf .extern .func (.param .u32 %value_out) vprintf (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {37,99,0 }; // BEGIN GLOBAL FUNCTION DEF: putchar .visible .func (.param .u32 %value_out) putchar (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u32 %r28; .reg .pred %r29; mov.u32 %r25,%ar0; and.b32 %r24,%r25,255; .loc 1 26 0 st.u32 [%frame],%r24; .loc 1 27 0 cvta.const.u64 %r26,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),vprintf,(%out_arg1,%out_arg2); ld.param.u32 %r28,[%value_in]; } .loc 1 28 0 setp.ge.s32 %r29,%r28,0; .loc 1 29 0 selp.u32 %value,%r24,-1,%r29; .loc 1 31 0 st.param.u32 [%value_out],%value; ret; } lib_a-puts.o/ 0 0 0 644 1123 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: puts .visible .func (.param .u32 %value_out) puts (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/machine/nvptx/puts.c" // BEGIN GLOBAL FUNCTION DECL: vprintf .extern .func (.param .u32 %value_out) vprintf (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {37,115,10,0 }; // BEGIN GLOBAL FUNCTION DEF: puts .visible .func (.param .u32 %value_out) puts (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r26; mov.u64 %r23,%ar0; .loc 1 25 0 st.u64 [%frame],%r23; .loc 1 26 0 cvta.const.u64 %r24,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),vprintf,(%out_arg1,%out_arg2); ld.param.u32 %r26,[%value_in]; } .loc 1 27 0 mov.u32 %value,%r26; st.param.u32 [%value_out],%value; ret; } lib_a-rand.o/ 0 0 0 644 1165 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: srand .visible .func srand (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/rand.c" // BEGIN GLOBAL FUNCTION DECL: rand .visible .func (.param .u32 %value_out) rand; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: srand .visible .func srand (.param .u32 %in_ar0) { .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r26; mov.u32 %r24,%ar0; .loc 1 78 0 ld.global.u64 %r25,[_impure_ptr]; cvt.u64.u32 %r26,%r24; st.u64 [%r25+232],%r26; .loc 1 79 0 ret; } // BEGIN GLOBAL FUNCTION DEF: rand .visible .func (.param .u32 %value_out) rand { .reg .u32 %value; .reg .u64 %r24; .reg .u64 %r27; .reg .u64 %r30; .reg .u64 %r32; .reg .u32 %r33; .loc 1 84 0 ld.global.u64 %r27,[_impure_ptr]; .loc 1 91 0 ld.u64 %r30,[%r27+232]; mad.lo.u64 %r24,%r30,6364136223846793005,1; .loc 1 90 0 st.u64 [%r27+232],%r24; .loc 1 92 0 shr.u64 %r32,%r24,32; cvt.u32.u64 %r33,%r32; and.b32 %value,%r33,2147483647; .loc 1 93 0 st.param.u32 [%value_out],%value; ret; } lib_a-rand48.o/ 0 0 0 644 1838 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __dorand48 .visible .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/rand48.c" // BEGIN GLOBAL FUNCTION DEF: __dorand48 .visible .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .u64 %r23; .reg .u32 %r24; .reg .u64 %r25; .reg .u32 %r30; .reg .u32 %r33; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u64 %r63; .reg .u64 %r64; .reg .u16 %r65; .reg .u64 %r67; .reg .u16 %r68; .reg .u64 %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .u64 %r78; mov.u64 %r58,%ar0; mov.u64 %r59,%ar1; .loc 1 167 0 ld.u16 %r22,[%r58+246]; cvt.u16.u32 %r60,%r22; cvt.u64.u16 %r23,%r60; ld.u16 %r24,[%r59]; cvt.u16.u32 %r61,%r24; cvt.u64.u16 %r25,%r61; .loc 1 168 0 ld.u16 %r63,[%r58+252]; .loc 1 167 0 mad.lo.u64 %r53,%r23,%r25,%r63; .loc 1 170 0 shr.u64 %r54,%r53,16; .loc 1 171 0 ld.u16 %r30,[%r59+2]; .loc 1 172 0 ld.u16 %r33,[%r58+248]; .loc 1 171 0 cvt.u16.u32 %r65,%r30; cvt.u64.u16 %r64,%r65; .loc 1 172 0 cvt.u16.u32 %r68,%r33; cvt.u64.u16 %r67,%r68; mul.lo.u64 %r69,%r67,%r25; .loc 1 171 0 mad.lo.u64 %r70,%r64,%r23,%r69; add.u64 %r55,%r70,%r54; .loc 1 174 0 shr.u64 %r56,%r55,16; .loc 1 175 0 ld.u16 %r71,[%r59+4]; mul.lo.u32 %r73,%r33,%r30; mad.lo.u32 %r74,%r71,%r22,%r73; ld.u16 %r75,[%r58+250]; mad.lo.u32 %r77,%r75,%r24,%r74; cvt.s64.s32 %r78,%r77; add.u64 %r57,%r78,%r56; .loc 1 169 0 st.u16 [%r59],%r53; .loc 1 173 0 st.u16 [%r59+2],%r55; .loc 1 178 0 st.u16 [%r59+4],%r57; .loc 1 179 0 ret; } lib_a-rand_r.o/ 0 0 0 644 1221 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rand_r .visible .func (.param .u32 %value_out) rand_r (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/stdlib/rand_r.c" // BEGIN GLOBAL FUNCTION DEF: rand_r .visible .func (.param .u32 %value_out) rand_r (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u32 %r32; .reg .u32 %r34; .reg .u64 %r35; .reg .pred %r36; .reg .u64 %r38; .reg .u64 %r39; .reg .pred %r40; mov.u64 %r35,%ar0; .loc 1 28 0 ld.u32 %r28,[%r35]; .loc 1 29 0 setp.eq.u64 %r36,%r28,0; @ %r36 bra $L4; .loc 1 31 0 div.s64 %r29,%r28,127773; .loc 1 32 0 mad.lo.u64 %r38,%r29,-127773,%r28; mul.lo.u64 %r39,%r29,-2836; mad.lo.u64 %r30,%r38,16807,%r39; .loc 1 33 0 setp.lt.s64 %r40,%r30,0; @ %r40 bra $L3; cvt.u32.u64 %r32,%r30; and.b32 %r34,%r32,2147483647; bra $L2; $L3: .loc 1 34 0 add.u64 %r31,%r30,2147483647; cvt.u32.u64 %r32,%r31; and.b32 %r34,%r32,2147483647; bra $L2; $L4: mov.u32 %r34,719435623; mov.u32 %r32,%r34; $L2: .loc 1 35 0 st.u32 [%r35],%r32; .loc 1 37 0 mov.u32 %value,%r34; st.param.u32 [%value_out],%value; ret; } /179 0 0 0 644 2874 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rawmemchr .visible .func (.param .u64 %value_out) rawmemchr (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/string/rawmemchr.c" // BEGIN GLOBAL FUNCTION DEF: rawmemchr .visible .func (.param .u64 %value_out) rawmemchr (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r81; .reg .u64 %r84; .reg .u64 %r90; .reg .u64 %r91; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r99; .reg .u64 %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .u64 %r110; .reg .pred %r111; .reg .u16 %r112; .reg .u16 %r113; .reg .pred %r114; .reg .u16 %r115; .reg .pred %r117; .reg .u64 %r118; .reg .pred %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .u16 %r130; .reg .u16 %r131; .reg .pred %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .pred %r138; .reg .u16 %r139; .reg .u16 %r140; .reg .pred %r141; .reg .u16 %r143; mov.u64 %r107,%ar0; mov.u32 %r108,%ar1; .loc 1 75 0 cvt.u32.u32 %r109,%r108; cvt.u32.u8 %r93,%r109; .loc 1 82 0 and.b64 %r110,%r107,7; setp.eq.u64 %r111,%r110,0; @ %r111 bra $L2; .loc 1 84 0 ld.u8 %r112,[%r107]; cvt.u16.u32 %r113,%r93; setp.eq.u16 %r114,%r112,%r113; @ %r114 bra $L1; cvt.u16.u32 %r143,%r93; bra $L4; $L5: ld.u8 %r115,[%r107]; setp.eq.u16 %r117,%r115,%r143; @ %r117 bra $L1; $L4: .loc 1 86 0 add.u64 %r107,%r107,1; .loc 1 82 0 and.b64 %r118,%r107,7; setp.ne.u64 %r119,%r118,0; @ %r119 bra $L5; $L2: .loc 1 97 0 shl.b32 %r120,%r108,8; and.b32 %r121,%r120,65535; and.b32 %r122,%r108,255; or.b32 %r123,%r121,%r122; cvt.s64.s32 %r94,%r123; .loc 1 98 0 shl.b64 %r81,%r94,16; or.b64 %r95,%r81,%r94; .loc 1 100 0 shl.b64 %r90,%r95,32; or.b64 %r91,%r90,%r95; .loc 1 104 0 ld.u64 %r124,[%r107]; xor.b64 %r99,%r91,%r124; add.u64 %r125,%r99,-72340172838076673; not.b64 %r126,%r99; and.b64 %r127,%r125,%r126; and.b64 %r128,%r127,-9187201950435737472; setp.eq.u64 %r129,%r128,0; @ %r129 bra $L6; $L8: .loc 1 117 0 ld.u8 %r130,[%r107]; cvt.u16.u32 %r131,%r93; setp.eq.u16 %r132,%r130,%r131; @ %r132 bra $L1; cvt.u16.u32 %r140,%r93; bra $L7; $L6: .loc 1 106 0 add.u64 %r107,%r107,8; .loc 1 104 0 ld.u64 %r133,[%r107]; xor.b64 %r84,%r91,%r133; add.u64 %r134,%r84,-72340172838076673; not.b64 %r135,%r84; and.b64 %r136,%r134,%r135; and.b64 %r137,%r136,-9187201950435737472; setp.ne.u64 %r138,%r137,0; @ ! %r138 bra $L6; bra $L8; $L7: .loc 1 119 0 add.u64 %r107,%r107,1; .loc 1 117 0 ld.u8 %r139,[%r107]; setp.ne.u16 %r141,%r139,%r140; @ %r141 bra $L7; $L1: .loc 1 121 0 mov.u64 %value,%r107; st.param.u64 [%value_out],%value; ret; } lib_a-realloc.o/0 0 0 644 2164 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __nvptx_realloc .visible .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/machine/nvptx/realloc.c" // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __nvptx_realloc .visible .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r31; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r36; .reg .u32 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .pred %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u64 %r52; mov.u64 %r28,%ar0; mov.u64 %r29,%ar1; .loc 1 37 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r31,[%value_in]; } .loc 1 39 0 set.u32.ne.u64 %r33,%r28,0; neg.s32 %r34,%r33; set.u32.ne.u64 %r36,%r31,0; neg.s32 %r37,%r36; cvt.u16.u32 %r39,%r34; cvt.u16.u32 %r40,%r37; and.b16 %r38,%r39,%r40; cvt.u32.u16 %r41,%r38; cvt.u16.u8 %r42,%r41; setp.eq.u16 %r43,%r42,0; @ %r43 bra $L1; .loc 1 42 0 ld.u64 %r45,[%r28+-8]; min.u64 %r44,%r29,%r45; .loc 1 43 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r28; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r44; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r52,[%value_in]; } .loc 1 44 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; call __nvptx_free,(%out_arg1); } $L1: .loc 1 48 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } /198 0 0 0 644 1864 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _realloc_os_r .visible .func (.param .u64 %value_out) _realloc_os_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/machine/nvptx/reallocr.c" // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: _realloc_os_r .visible .func (.param .u64 %value_out) _realloc_os_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .pred %r28; .reg .u64 %r30; .reg .pred %r31; .reg .u64 %r35; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 22 0 setp.ge.u64 %r28,%r27,%r26; @ %r28 bra $L2; .loc 1 24 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r30,[%value_in]; } .loc 1 25 0 setp.eq.u64 %r31,%r25,0; @ %r31 bra $L3; .loc 1 26 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r30; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r35,[%value_in]; } .loc 1 24 0 mov.u64 %r25,%r30; bra $L2; $L3: mov.u64 %r25,%r30; $L2: .loc 1 29 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-reent.o/ 0 0 0 644 4224 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cleanup_glue .visible .func cleanup_glue (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/reent/reent.c" // BEGIN GLOBAL FUNCTION DECL: _reclaim_reent .visible .func _reclaim_reent (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _free_r .extern .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DEF: errno .visible .global .align 4 .u32 errno[1]; // BEGIN GLOBAL FUNCTION DEF: cleanup_glue .visible .func cleanup_glue (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r24; .reg .pred %r25; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 38 0 ld.u64 %r22,[%r24]; setp.eq.u64 %r25,%r22,0; @ %r25 bra $L2; .loc 1 39 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r22; call cleanup_glue,(%out_arg1,%out_arg2); } $L2: .loc 1 41 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call _free_r,(%out_arg1,%out_arg2); } .loc 1 42 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _reclaim_reent .visible .func _reclaim_reent (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r26; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .pred %r42; .reg .u64 %r43; .reg .pred %r44; .reg .pred %r47; .reg .pred %r48; .reg .pred %r51; .reg .pred %r54; .reg .pred %r55; .reg .pred %r58; .reg .pred %r59; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r65; .reg .pred %r66; mov.u64 %r39,%ar0; .loc 1 48 0 ld.global.u64 %r40,[_impure_ptr]; setp.ne.u64 %r41,%r40,%r39; @ ! %r41 bra $L6; .loc 1 55 0 ld.u64 %r34,[%r39+120]; setp.eq.u64 %r42,%r34,0; @ %r42 bra $L9; mov.u64 %r38,0; $L12: .loc 1 62 0 add.u64 %r43,%r34,%r38; ld.u64 %r26,[%r43]; .loc 1 63 0 setp.eq.u64 %r44,%r26,0; @ %r44 bra $L10; $L11: .loc 1 66 0 ld.u64 %r36,[%r26]; .loc 1 67 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; call _free_r,(%out_arg1,%out_arg2); } mov.u64 %r26,%r36; .loc 1 63 0 setp.ne.u64 %r47,%r26,0; @ %r47 bra $L11; ld.u64 %r34,[%r39+120]; $L10: add.u64 %r38,%r38,8; .loc 1 58 0 setp.ne.u64 %r48,%r38,512; @ %r48 bra $L12; .loc 1 71 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call _free_r,(%out_arg1,%out_arg2); } $L9: .loc 1 73 0 ld.u64 %r28,[%r39+96]; setp.eq.u64 %r51,%r28,0; @ %r51 bra $L13; .loc 1 74 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r28; call _free_r,(%out_arg1,%out_arg2); } $L13: .loc 1 102 0 ld.u64 %r35,[%r39+504]; setp.eq.u64 %r54,%r35,0; @ %r54 bra $L14; add.u64 %r29,%r39,512; setp.eq.u64 %r55,%r35,%r29; @ %r55 bra $L14; $L15: .loc 1 108 0 ld.u64 %r37,[%r35]; .loc 1 109 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r35; call _free_r,(%out_arg1,%out_arg2); } mov.u64 %r35,%r37; .loc 1 105 0 setp.ne.u64 %r58,%r29,%r35; @ %r58 bra $L15; $L14: .loc 1 115 0 ld.u64 %r30,[%r39+136]; setp.eq.u64 %r59,%r30,0; @ %r59 bra $L16; .loc 1 116 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r30; call _free_r,(%out_arg1,%out_arg2); } $L16: .loc 1 123 0 ld.u32 %r62,[%r39+80]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L6; .loc 1 127 0 ld.u64 %r65,[%r39+88]; { $LCT0: .callprototype _ ( .param .u64 %in_ar0); .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; call %r65,(%out_arg1),$LCT0; } .loc 1 129 0 ld.u64 %r33,[%r39+1312]; setp.eq.u64 %r66,%r33,0; @ %r66 bra $L6; .loc 1 130 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r33; call cleanup_glue,(%out_arg1,%out_arg2); } $L6: .loc 1 136 0 ret; } lib_a-rindex.o/ 0 0 0 644 1013 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rindex .visible .func (.param .u64 %value_out) rindex (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/string/rindex.c" // BEGIN GLOBAL FUNCTION DECL: strrchr .extern .func (.param .u64 %value_out) strrchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: rindex .visible .func (.param .u64 %value_out) rindex (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u64 %r27; mov.u64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 44 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),strrchr,(%out_arg1,%out_arg2); ld.param.u64 %r27,[%value_in]; } .loc 1 45 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } /216 0 0 0 644 1183 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %r27; .reg .f64 %r29; .reg .f64 %r30; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .u64 %r43; mov.f64 %r29,%ar0; mov.f64 %r30,%ar1; .loc 1 78 0 mov.b64 %r27,%r29; shr.u64 %r32,%r27,32; cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; mov.b64 %r35,%r30; shr.u64 %r36,%r35,32; cvt.u32.u64 %r38,%r36; and.b32 %r37,%r38,-2147483648; or.b32 %r39,%r33,%r37; cvt.u64.u32 %r40,%r39; shl.b64 %r41,%r40,32; and.b64 %r42,%r27,4294967295; or.b64 %r43,%r42,%r41; mov.b64 %value,%r43; .loc 1 80 0 st.param.f64 [%value_out],%value; ret; } /236 0 0 0 644 753 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_finite.c" // BEGIN GLOBAL FUNCTION DEF: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; mov.f64 %r29,%ar0; .loc 1 31 0 mov.b64 %r31,%r29; shr.u64 %r32,%r31,32; .loc 1 32 0 cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; add.u32 %r35,%r33,-2146435072; shr.u32 %value,%r35,31; .loc 1 33 0 st.param.u32 [%value_out],%value; ret; } /254 0 0 0 644 1958 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r32; .reg .f64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .u16 %r45; .reg .u16 %r46; .reg .u16 %r47; .reg .u32 %r48; .reg .u16 %r49; .reg .pred %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .u32 %r55; .reg .u32 %r56; .reg .u16 %r57; .reg .u16 %r58; .reg .u32 %r60; mov.f64 %r33,%ar0; mov.b64 %r34,%r33; shr.u64 %r35,%r34,32; cvt.u32.u64 %r27,%r35; cvt.u32.u64 %r28,%r34; .loc 1 16 0 or.b32 %r37,%r27,%r28; setp.eq.u32 %r38,%r37,0; @ %r38 bra $L3; .loc 1 17 0 set.u32.eq.u32 %r40,%r28,0; neg.s32 %r41,%r40; cvt.u32.u32 %r39,%r41; set.u32.eq.u32 %r43,%r27,-2147483648; neg.s32 %r44,%r43; cvt.u16.u32 %r46,%r44; cvt.u16.u8 %r47,%r39; and.b16 %r45,%r46,%r47; .loc 1 16 0 cvt.u32.u16 %r48,%r45; cvt.u16.u8 %r49,%r48; setp.ne.u16 %r50,%r49,0; @ %r50 bra $L4; .loc 1 19 0 and.b32 %r30,%r27,2147483647; add.u32 %r51,%r30,-1048576; setp.le.u32 %r52,%r51,2145386495; @ %r52 bra $L5; .loc 1 22 0 setp.le.u32 %r53,%r30,1048575; @ %r53 bra $L6; .loc 1 26 0 set.u32.eq.u32 %r55,%r30,2146435072; neg.s32 %r56,%r55; cvt.u16.u32 %r58,%r56; and.b16 %r57,%r58,%r47; .loc 1 18 0 cvt.u32.u16 %r60,%r57; cvt.u32.u8 %r32,%r60; bra $L1; $L3: mov.u32 %r32,2; bra $L1; $L4: mov.u32 %r32,2; bra $L1; $L5: .loc 1 21 0 mov.u32 %r32,4; bra $L1; $L6: .loc 1 25 0 mov.u32 %r32,3; $L1: .loc 1 31 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-s_frexp.o/0 0 0 644 1956 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/s_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r29; .reg .u32 %r30; .reg .u32 %r35; .reg .u64 %r36; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 98 0 mov.b64 %r40,%r38; shr.u64 %r41,%r40,32; cvt.u32.u64 %r29,%r41; .loc 1 99 0 and.b32 %r30,%r29,2147483647; .loc 1 100 0 mov.u32 %r42,0; st.u32 [%r39],%r42; .loc 1 101 0 setp.gt.s32 %r43,%r30,2146435071; @ %r43 bra $L2; cvt.u32.u64 %r46,%r40; or.b32 %r45,%r30,%r46; setp.eq.u32 %r47,%r45,0; @ %r47 bra $L2; .loc 1 102 0 setp.gt.s32 %r48,%r30,1048575; @ %r48 bra $L4; .loc 1 103 0 mul.f64 %r38,%r38,0d4350000000000000; .loc 1 104 0 mov.b64 %r49,%r38; shr.u64 %r50,%r49,32; cvt.u32.u64 %r29,%r50; .loc 1 105 0 and.b32 %r30,%r29,2147483647; mov.u32 %r35,-54; bra $L3; $L4: mov.u32 %r35,%r42; $L3: .loc 1 108 0 shr.s32 %r51,%r30,20; add.u32 %r52,%r51,-1022; add.u32 %r53,%r52,%r35; st.u32 [%r39],%r53; .loc 1 110 0 mov.b64 %r36,%r38; .loc 1 109 0 and.b32 %r54,%r29,-2146435073; or.b32 %r55,%r54,1071644672; .loc 1 110 0 cvt.u64.u32 %r56,%r55; shl.b64 %r57,%r56,32; and.b64 %r58,%r36,4294967295; or.b64 %r59,%r58,%r57; mov.b64 %r38,%r59; $L2: .loc 1 112 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } /276 0 0 0 644 393 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL VAR DEF: __infinity .visible .const .align 8 .u64 __infinity[1] = {9218868437227405312 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: __infinityld .visible .const .align 8 .u64 __infinityld[2] = {9218868437227405312 }; // BEGIN GLOBAL VAR DEF: __infinityf .visible .const .align 4 .u32 __infinityf[1] = {2139095040 }; lib_a-s_isinf.o/0 0 0 644 1166 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 22 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 24 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 23 0 and.b32 %r48,%r33,2147483647; .loc 1 24 0 or.b32 %r27,%r47,%r48; .loc 1 25 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 26 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 27 0 st.param.u32 [%value_out],%value; ret; } /296 0 0 0 644 1179 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isinfd.c" // BEGIN GLOBAL FUNCTION DEF: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 16 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 18 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 17 0 and.b32 %r48,%r33,2147483647; .loc 1 18 0 or.b32 %r27,%r47,%r48; .loc 1 19 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 20 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 21 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_isnan.o/0 0 0 644 1027 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 199 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 201 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 200 0 and.b32 %r45,%r30,2147483647; .loc 1 201 0 or.b32 %r27,%r44,%r45; .loc 1 202 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 203 0 shr.u32 %value,%r47,31; .loc 1 204 0 st.param.u32 [%value_out],%value; ret; } /314 0 0 0 644 1040 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_isnand.c" // BEGIN GLOBAL FUNCTION DEF: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 115 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 117 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 116 0 and.b32 %r45,%r30,2147483647; .loc 1 117 0 or.b32 %r27,%r44,%r45; .loc 1 118 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 119 0 shr.u32 %value,%r47,31; .loc 1 120 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_ldexp.o/0 0 0 644 2584 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/math/s_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f64 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f64 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 75 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f64 %r37,%r32,0d0000000000000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } mov.f64 %r32,%r50; .loc 1 77 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f64 %r54,%r32,0d0000000000000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 79 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } lib_a-s_modf.o/ 0 0 0 644 3138 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_modf.c" // BEGIN GLOBAL FUNCTION DEF: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r23; .reg .f64 %r32; .reg .u32 %r38; .reg .f64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .f64 %r52; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u64 %r62; .reg .u64 %r66; .reg .f64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u64 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .u32 %r96; .reg .u64 %r97; .reg .u64 %r101; .reg .u64 %r102; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; mov.f64 %r53,%ar0; mov.u64 %r54,%ar1; mov.b64 %r55,%r53; shr.u64 %r56,%r55,32; cvt.u32.u64 %r38,%r56; cvt.u32.u64 %r44,%r55; .loc 1 92 0 shr.s32 %r58,%r38,20; and.b32 %r23,%r58,2047; add.u32 %r42,%r23,-1023; .loc 1 93 0 setp.gt.s32 %r59,%r42,19; @ %r59 bra $L2; .loc 1 94 0 setp.ge.s32 %r60,%r42,0; @ %r60 bra $L3; .loc 1 95 0 and.b32 %r61,%r38,-2147483648; cvt.u64.u32 %r62,%r61; shl.b64 %r66,%r62,32; mov.b64 %r67,%r66; st.f64 [%r54],%r67; .loc 1 96 0 mov.f64 %r52,%r53; bra $L1; $L3: .loc 1 98 0 mov.u32 %r68,1048575; shr.s32 %r45,%r68,%r42; .loc 1 99 0 and.b32 %r69,%r38,%r45; or.b32 %r70,%r69,%r44; setp.ne.u32 %r71,%r70,0; @ %r71 bra $L5; .loc 1 101 0 st.f64 [%r54],%r53; .loc 1 103 0 and.b32 %r72,%r38,-2147483648; cvt.u64.u32 %r73,%r72; shl.b64 %r77,%r73,32; mov.b64 %r52,%r77; .loc 1 104 0 bra $L1; $L5: .loc 1 106 0 not.b32 %r78,%r45; and.b32 %r79,%r78,%r38; cvt.u64.u32 %r80,%r79; shl.b64 %r84,%r80,32; mov.b64 %r32,%r84; st.f64 [%r54],%r32; .loc 1 107 0 sub.f64 %r52,%r53,%r32; bra $L1; $L2: .loc 1 110 0 setp.le.s32 %r85,%r42,51; @ %r85 bra $L6; .loc 1 112 0 st.f64 [%r54],%r53; .loc 1 114 0 and.b32 %r86,%r38,-2147483648; cvt.u64.u32 %r87,%r86; shl.b64 %r91,%r87,32; mov.b64 %r52,%r91; .loc 1 115 0 bra $L1; $L6: .loc 1 117 0 add.u32 %r92,%r23,-1043; mov.u32 %r93,-1; shr.u32 %r43,%r93,%r92; .loc 1 118 0 and.b32 %r94,%r43,%r44; setp.ne.u32 %r95,%r94,0; @ %r95 bra $L7; .loc 1 120 0 st.f64 [%r54],%r53; .loc 1 122 0 and.b32 %r96,%r38,-2147483648; cvt.u64.u32 %r97,%r96; shl.b64 %r101,%r97,32; mov.b64 %r52,%r101; .loc 1 123 0 bra $L1; $L7: .loc 1 125 0 cvt.u64.u32 %r102,%r38; not.b32 %r106,%r43; and.b32 %r107,%r106,%r44; cvt.u64.u32 %r108,%r107; shl.b64 %r109,%r102,32; or.b64 %r110,%r109,%r108; mov.b64 %r40,%r110; st.f64 [%r54],%r40; .loc 1 126 0 sub.f64 %r52,%r53,%r40; $L1: .loc 1 129 0 mov.f64 %value,%r52; st.param.f64 [%value_out],%value; ret; } lib_a-s_nan.o/ 0 0 0 644 497 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libm/common/s_nan.c" // BEGIN GLOBAL FUNCTION DEF: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 49 0 mov.f64 %value,0d7ff8000000000000; .loc 1 50 0 st.param.f64 [%value_out],%value; ret; } /332 0 0 0 644 4051 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/common/s_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .f64 %r46; .reg .u64 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .pred %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .pred %r81; .reg .pred %r82; .reg .f64 %r83; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; mov.f64 %r52,%ar0; mov.u32 %r53,%ar1; .loc 1 86 0 mov.b64 %r54,%r52; shr.u64 %r55,%r54,32; cvt.u32.u64 %r41,%r55; .loc 1 87 0 shr.s32 %r56,%r41,20; and.b32 %r43,%r56,2047; .loc 1 88 0 setp.ne.u32 %r57,%r43,0; @ %r57 bra $L2; .loc 1 89 0 and.b32 %r58,%r41,2147483647; cvt.u32.u64 %r61,%r54; or.b32 %r60,%r58,%r61; setp.eq.u32 %r62,%r60,0; @ %r62 bra $L10; .loc 1 90 0 mul.f64 %r52,%r52,0d4350000000000000; .loc 1 93 0 setp.ge.s32 %r63,%r53,-50000; @ %r63 bra $L4; mul.f64 %r51,%r52,0d01a56e1fc2f8f359; bra $L1; $L2: .loc 1 95 0 setp.ne.u32 %r64,%r43,2047; @ %r64 bra $L5; add.f64 %r51,%r52,%r52; bra $L1; $L4: .loc 1 91 0 mov.b64 %r65,%r52; shr.u64 %r66,%r65,32; cvt.u32.u64 %r41,%r66; .loc 1 92 0 shr.s32 %r67,%r41,20; and.b32 %r68,%r67,2047; add.u32 %r43,%r68,-54; $L5: .loc 1 96 0 add.u32 %r44,%r53,%r43; .loc 1 97 0 setp.le.s32 %r69,%r44,2046; @ %r69 bra $L6; mov.f64 %r70,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r70; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r72,[%value_in]; } mul.f64 %r51,%r72,0d7e37e43c8800759c; bra $L1; $L6: .loc 1 98 0 setp.le.s32 %r73,%r44,0; @ %r73 bra $L7; .loc 1 99 0 mov.b64 %r49,%r52; and.b32 %r74,%r41,-2146435073; shl.b32 %r75,%r44,20; or.b32 %r76,%r74,%r75; cvt.u64.u32 %r77,%r76; shl.b64 %r78,%r77,32; and.b64 %r79,%r49,4294967295; or.b64 %r80,%r79,%r78; mov.b64 %r51,%r80; bra $L1; $L7: .loc 1 100 0 setp.ge.s32 %r81,%r44,-53; @ %r81 bra $L8; .loc 1 101 0 setp.le.s32 %r82,%r53,50000; @ %r82 bra $L9; .loc 1 102 0 mov.f64 %r83,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r83; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r85,[%value_in]; } mul.f64 %r51,%r85,0d7e37e43c8800759c; bra $L1; $L9: .loc 1 103 0 mov.f64 %r86,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r88,[%value_in]; } mul.f64 %r51,%r88,0d01a56e1fc2f8f359; bra $L1; $L8: .loc 1 106 0 mov.b64 %r50,%r52; .loc 1 105 0 add.u32 %r89,%r44,54; .loc 1 106 0 shl.b32 %r90,%r89,20; and.b32 %r91,%r41,-2146435073; or.b32 %r92,%r90,%r91; cvt.u64.u32 %r93,%r92; shl.b64 %r94,%r93,32; and.b64 %r95,%r50,4294967295; or.b64 %r96,%r95,%r94; mov.b64 %r46,%r96; .loc 1 107 0 mul.f64 %r51,%r46,0d3c90000000000000; bra $L1; $L10: .loc 1 89 0 mov.f64 %r51,%r52; $L1: .loc 1 108 0 mov.f64 %value,%r51; st.param.f64 [%value_out],%value; ret; } lib_a-seed48.o/ 0 0 0 644 2793 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _seed48_r .visible .func (.param .u64 %value_out) _seed48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/seed48.c" // BEGIN GLOBAL FUNCTION DECL: seed48 .visible .func (.param .u64 %value_out) seed48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN VAR DEF: sseed$2019 .global .align 2 .u16 sseed$2019[3]; // BEGIN GLOBAL FUNCTION DEF: _seed48_r .visible .func (.param .u64 %value_out) _seed48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u16 %r32; .reg .u16 %r34; .reg .u16 %r36; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u16 %r41; .reg .u16 %r42; .reg .u16 %r43; mov.u64 %r29,%ar0; mov.u64 %r30,%ar1; .loc 1 24 0 cvta.global.u64 %r31,sseed$2019; ld.u16 %r32,[%r29+240]; st.u16 [%r31],%r32; .loc 1 25 0 ld.u16 %r34,[%r29+242]; st.u16 [%r31+2],%r34; .loc 1 26 0 ld.u16 %r36,[%r29+244]; st.u16 [%r31+4],%r36; .loc 1 27 0 ld.u16 %r37,[%r30]; st.u16 [%r29+240],%r37; .loc 1 28 0 ld.u16 %r38,[%r30+2]; st.u16 [%r29+242],%r38; .loc 1 29 0 ld.u16 %r39,[%r30+4]; st.u16 [%r29+244],%r39; .loc 1 30 0 mov.u16 %r40,-6547; st.u16 [%r29+246],%r40; .loc 1 31 0 mov.u16 %r41,-8468; st.u16 [%r29+248],%r41; .loc 1 32 0 mov.u16 %r42,5; st.u16 [%r29+250],%r42; .loc 1 33 0 mov.u16 %r43,11; st.u16 [%r29+252],%r43; .loc 1 35 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: seed48 .visible .func (.param .u64 %value_out) seed48 (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u64 %r30; .reg .u64 %r31; .reg .u16 %r32; .reg .u16 %r34; .reg .u16 %r36; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u16 %r41; .reg .u16 %r42; .reg .u16 %r43; mov.u64 %r30,%ar0; .loc 1 42 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 24 0 cvta.global.u64 %r31,sseed$2019; ld.u16 %r32,[%r22+240]; st.u16 [%r31],%r32; .loc 1 25 0 ld.u16 %r34,[%r22+242]; st.u16 [%r31+2],%r34; .loc 1 26 0 ld.u16 %r36,[%r22+244]; st.u16 [%r31+4],%r36; .loc 1 27 0 ld.u16 %r37,[%r30]; st.u16 [%r22+240],%r37; .loc 1 28 0 ld.u16 %r38,[%r30+2]; st.u16 [%r22+242],%r38; .loc 1 29 0 ld.u16 %r39,[%r30+4]; st.u16 [%r22+244],%r39; .loc 1 30 0 mov.u16 %r40,-6547; st.u16 [%r22+246],%r40; .loc 1 31 0 mov.u16 %r41,-8468; st.u16 [%r22+248],%r41; .loc 1 32 0 mov.u16 %r42,5; st.u16 [%r22+250],%r42; .loc 1 33 0 mov.u16 %r43,11; st.u16 [%r22+252],%r43; .loc 1 43 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } /350 0 0 0 644 884 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r24; .reg .f32 %r28; .reg .f32 %r29; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; mov.f32 %r28,%ar0; mov.f32 %r29,%ar1; .loc 1 34 0 mov.b32 %r31,%r28; and.b32 %r30,%r31,2147483647; mov.b32 %r33,%r29; and.b32 %r32,%r33,-2147483648; or.b32 %r24,%r30,%r32; .loc 1 35 0 mov.b32 %value,%r24; .loc 1 36 0 st.param.f32 [%value_out],%value; ret; } /371 0 0 0 644 696 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_finite.c" // BEGIN GLOBAL FUNCTION DEF: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.le.s32 %r31,%r29,2139095039; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /390 0 0 0 644 1173 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r26; .reg .u32 %r27; .reg .f32 %r28; .reg .u32 %r29; .reg .pred %r30; .reg .u32 %r31; .reg .pred %r32; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; mov.f32 %r28,%ar0; .loc 1 16 0 mov.b32 %r29,%r28; and.b32 %r26,%r29,2147483647; setp.eq.u32 %r30,%r26,0; @ %r30 bra $L3; .loc 1 18 0 add.u32 %r31,%r26,-8388608; setp.le.u32 %r32,%r31,2130706431; @ %r32 bra $L4; .loc 1 21 0 add.u32 %r33,%r26,-1; setp.le.u32 %r34,%r33,8388606; @ %r34 bra $L5; .loc 1 24 0 set.u32.eq.u32 %r36,%r26,2139095040; neg.s32 %r27,%r36; bra $L1; $L3: .loc 1 17 0 mov.u32 %r27,2; bra $L1; $L4: .loc 1 20 0 mov.u32 %r27,4; bra $L1; $L5: .loc 1 23 0 mov.u32 %r27,3; $L1: .loc 1 28 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } /413 0 0 0 644 1883 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/math/sf_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u16 %r47; .reg .u16 %r48; .reg .u16 %r49; .reg .u32 %r50; .reg .u16 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r31,%r38; .loc 1 34 0 and.b32 %r32,%r31,2147483647; .loc 1 35 0 mov.u32 %r40,0; st.u32 [%r39],%r40; .loc 1 36 0 set.u32.gt.s32 %r42,%r32,2139095039; neg.s32 %r43,%r42; set.u32.eq.u32 %r45,%r32,0; neg.s32 %r46,%r45; cvt.u16.u32 %r48,%r43; cvt.u16.u32 %r49,%r46; or.b16 %r47,%r48,%r49; cvt.u32.u16 %r50,%r47; cvt.u16.u8 %r51,%r50; setp.ne.u16 %r52,%r51,0; @ %r52 bra $L4; .loc 1 37 0 setp.gt.s32 %r53,%r32,8388607; @ %r53 bra $L5; .loc 1 38 0 mul.f32 %r54,%r38,0f4c000000; .loc 1 39 0 mov.b32 %r31,%r54; .loc 1 40 0 and.b32 %r32,%r31,2147483647; mov.u32 %r36,-25; bra $L3; $L5: mov.u32 %r36,%r40; $L3: .loc 1 43 0 shr.s32 %r55,%r32,23; add.u32 %r56,%r55,-126; add.u32 %r57,%r56,%r36; st.u32 [%r39],%r57; .loc 1 44 0 and.b32 %r58,%r31,-2139095041; or.b32 %r59,%r58,1056964608; .loc 1 45 0 mov.b32 %r37,%r59; .loc 1 46 0 bra $L1; $L4: .loc 1 36 0 mov.f32 %r37,%r38; $L1: .loc 1 47 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /431 0 0 0 644 691 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 21 0 mov.b32 %r23,%r27; .loc 1 22 0 and.b32 %r29,%r23,2147483647; .loc 1 23 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 24 0 st.param.u32 [%value_out],%value; ret; } /449 0 0 0 644 700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isinff.c" // BEGIN GLOBAL FUNCTION DEF: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 13 0 mov.b32 %r23,%r27; .loc 1 14 0 and.b32 %r29,%r23,2147483647; .loc 1 15 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 16 0 st.param.u32 [%value_out],%value; ret; } /468 0 0 0 644 691 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /486 0 0 0 644 700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_isnanf.c" // BEGIN GLOBAL FUNCTION DEF: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 23 0 mov.b32 %r23,%r27; .loc 1 24 0 and.b32 %r29,%r23,2147483647; .loc 1 25 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 26 0 st.param.u32 [%value_out],%value; ret; } /505 0 0 0 644 2580 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/math/sf_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f32 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f32 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f32 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 26 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f32 %r37,%r32,0f00000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 27 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } mov.f32 %r32,%r50; .loc 1 28 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f32 %r54,%r32,0f00000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 30 0 mov.f32 %value,%r32; st.param.f32 [%value_out],%value; ret; } lib_a-sf_modf.o/0 0 0 644 1773 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_modf.c" // BEGIN GLOBAL FUNCTION DEF: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r31; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .f32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r35,%r38; .loc 1 34 0 shr.s32 %r40,%r35,23; and.b32 %r41,%r40,255; add.u32 %r34,%r41,-127; .loc 1 35 0 setp.gt.s32 %r42,%r34,22; @ %r42 bra $L2; .loc 1 36 0 setp.ge.s32 %r43,%r34,0; @ %r43 bra $L3; .loc 1 37 0 and.b32 %r44,%r35,-2147483648; mov.b32 %r45,%r44; st.f32 [%r39],%r45; .loc 1 38 0 mov.f32 %r37,%r38; bra $L1; $L3: .loc 1 40 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r34; .loc 1 41 0 and.b32 %r47,%r35,%r36; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L5; .loc 1 43 0 st.f32 [%r39],%r38; .loc 1 45 0 and.b32 %r49,%r35,-2147483648; mov.b32 %r37,%r49; .loc 1 46 0 bra $L1; $L5: .loc 1 48 0 not.b32 %r50,%r36; and.b32 %r51,%r50,%r35; mov.b32 %r31,%r51; st.f32 [%r39],%r31; .loc 1 49 0 sub.f32 %r37,%r38,%r31; bra $L1; $L2: .loc 1 54 0 st.f32 [%r39],%r38; .loc 1 56 0 and.b32 %r52,%r35,-2147483648; mov.b32 %r37,%r52; $L1: .loc 1 59 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_nan.o/ 0 0 0 644 494 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libm/common/sf_nan.c" // BEGIN GLOBAL FUNCTION DEF: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 17 0 mov.f32 %value,0f7fc00000; .loc 1 18 0 st.param.f32 [%value_out],%value; ret; } /523 0 0 0 644 3411 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libm/common/sf_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .f32 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .f32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .pred %r64; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .f32 %r75; mov.f32 %r47,%ar0; mov.u32 %r48,%ar1; .loc 1 46 0 mov.b32 %r22,%r47; .loc 1 47 0 and.b32 %r42,%r22,2147483647; .loc 1 49 0 setp.eq.u32 %r49,%r42,0; @ %r49 bra $L11; .loc 1 51 0 setp.le.u32 %r50,%r42,2139095039; @ %r50 bra $L3; .loc 1 52 0 add.f32 %r46,%r47,%r47; bra $L1; $L3: .loc 1 53 0 setp.gt.u32 %r51,%r42,8388607; @ %r51 bra $L4; .loc 1 54 0 mul.f32 %r47,%r47,0f4c000000; .loc 1 57 0 setp.lt.s32 %r52,%r48,-50000; @ %r52 bra $L5; .loc 1 55 0 mov.b32 %r41,%r47; .loc 1 56 0 shr.s32 %r53,%r41,23; and.b32 %r54,%r53,255; add.u32 %r40,%r54,-25; bra $L6; $L5: .loc 1 57 0 mul.f32 %r46,%r47,0f0da24260; bra $L1; $L4: .loc 1 46 0 mov.u32 %r41,%r22; .loc 1 48 0 shr.u32 %r40,%r42,23; $L6: .loc 1 59 0 add.u32 %r43,%r40,%r48; .loc 1 60 0 setp.le.s32 %r55,%r43,254; @ %r55 bra $L7; mov.f32 %r56,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r56; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r58,[%value_in]; } mul.f32 %r46,%r58,0f7149f2ca; bra $L1; $L7: .loc 1 61 0 setp.le.s32 %r59,%r43,0; @ %r59 bra $L8; .loc 1 62 0 and.b32 %r60,%r41,-2139095041; shl.b32 %r61,%r43,23; or.b32 %r62,%r60,%r61; mov.b32 %r46,%r62; bra $L1; $L8: .loc 1 63 0 setp.ge.s32 %r63,%r43,-22; @ %r63 bra $L9; .loc 1 64 0 setp.le.s32 %r64,%r48,50000; @ %r64 bra $L10; .loc 1 65 0 mov.f32 %r65,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r65; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r67,[%value_in]; } mul.f32 %r46,%r67,0f7149f2ca; bra $L1; $L10: .loc 1 66 0 mov.f32 %r68,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r70,[%value_in]; } mul.f32 %r46,%r70,0f0da24260; bra $L1; $L9: .loc 1 68 0 add.u32 %r71,%r43,25; .loc 1 69 0 shl.b32 %r72,%r71,23; and.b32 %r73,%r41,-2139095041; or.b32 %r74,%r72,%r73; .loc 1 70 0 mov.b32 %r75,%r74; mul.f32 %r46,%r75,0f33000000; bra $L1; $L11: .loc 1 50 0 mov.f32 %r46,%r47; $L1: .loc 1 71 0 mov.f32 %value,%r46; st.param.f32 [%value_out],%value; ret; } /542 0 0 0 644 3390 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _siprintf_r .visible .func (.param .u32 %value_out) _siprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdio/siprintf.c" // BEGIN GLOBAL FUNCTION DECL: siprintf .visible .func (.param .u32 %value_out) siprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfiprintf_r .extern .func (.param .u32 %value_out) _svfiprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: _siprintf_r .visible .func (.param .u32 %value_out) _siprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r22; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r36; .reg .u32 %r37; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; .loc 1 124 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 125 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 132 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfiprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r36,[%value_in]; } .loc 1 134 0 ld.u64 %r22,[%frame]; mov.u32 %r37,0; st.u8 [%r22],%r37; .loc 1 136 0 mov.u32 %value,%r36; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: siprintf .visible .func (.param .u32 %value_out) siprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 157 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 158 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 165 0 ld.global.u64 %r36,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r36; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfiprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r37,[%value_in]; } .loc 1 167 0 ld.u64 %r23,[%frame]; mov.u32 %r38,0; st.u8 [%r23],%r38; .loc 1 169 0 mov.u32 %value,%r37; st.param.u32 [%value_out],%value; ret; } lib_a-siscanf.o/0 0 0 644 4328 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: siscanf .visible .func (.param .u32 %value_out) siscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/stdio/siscanf.c" // BEGIN GLOBAL FUNCTION DECL: _siscanf_r .visible .func (.param .u32 %value_out) _siscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __seofread .extern .func (.param .u32 %value_out) __seofread (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ssvfiscanf_r .extern .func (.param .u32 %value_out) __ssvfiscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: siscanf .visible .func (.param .u32 %value_out) siscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u64 %r41; .reg .u32 %r42; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; .loc 1 135 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 136 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 137 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 138 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 139 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 140 0 st.u64 [%frame+120],%r33; .loc 1 141 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 147 0 ld.global.u64 %r41,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r41; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfiscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r42,[%value_in]; } .loc 1 150 0 mov.u32 %value,%r42; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _siscanf_r .visible .func (.param .u32 %value_out) _siscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u32 %r41; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; mov.u64 %r28,%ar2; .loc 1 173 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 174 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 175 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 176 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 177 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 178 0 st.u64 [%frame+120],%r33; .loc 1 179 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 185 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfiscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r41,[%value_in]; } .loc 1 188 0 mov.u32 %value,%r41; st.param.u32 [%value_out],%value; ret; } /560 0 0 0 644 6217 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _snprintf_r .visible .func (.param .u32 %value_out) _snprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); .file 1 "../../../../../newlib/libc/stdio/snprintf.c" // BEGIN GLOBAL FUNCTION DECL: snprintf .visible .func (.param .u32 %value_out) snprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: _snprintf_r .visible .func (.param .u32 %value_out) _snprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %args; ld.param.u64 %args,[%in_ar4]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .u16 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .u16 %r38; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r48; .reg .u16 %r50; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r59; mov.u64 %r29,%ar0; mov.u64 %r30,%ar1; mov.u64 %r31,%ar2; mov.u64 %r32,%ar3; .loc 1 52 0 setp.le.u64 %r33,%r31,2147483647; @ %r33 bra $L2; .loc 1 54 0 mov.u32 %r34,139; st.u32 [%r29],%r34; .loc 1 55 0 mov.u32 %r28,-1; bra $L1; $L2: .loc 1 57 0 mov.u16 %r35,520; st.u16 [%frame+16],%r35; .loc 1 58 0 st.u64 [%frame],%r30; st.u64 [%frame+24],%r30; .loc 1 59 0 setp.eq.u64 %r36,%r31,0; @ %r36 bra $L4; cvt.u32.u64 %r37,%r31; add.u32 %r25,%r37,-1; st.u32 [%frame+12],%r25; st.u32 [%frame+32],%r25; .loc 1 60 0 mov.u16 %r38,-1; st.u16 [%frame+18],%r38; .loc 1 66 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r44,[%value_in]; } mov.u32 %r28,%r44; .loc 1 68 0 setp.lt.s32 %r45,%r28,-1; @ %r45 bra $L5; $L7: .loc 1 71 0 ld.u64 %r24,[%frame]; mov.u32 %r46,0; st.u8 [%r24],%r46; bra $L1; $L4: .loc 1 59 0 cvt.u32.u64 %r48,%r31; st.u32 [%frame+12],%r48; st.u32 [%frame+32],%r48; .loc 1 60 0 mov.u16 %r50,-1; st.u16 [%frame+18],%r50; .loc 1 66 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r56,[%value_in]; } mov.u32 %r28,%r56; .loc 1 68 0 setp.lt.s32 %r57,%r28,-1; @ ! %r57 bra $L1; bra $L6; $L5: .loc 1 69 0 mov.u32 %r58,139; st.u32 [%r29],%r58; bra $L7; $L6: mov.u32 %r59,139; st.u32 [%r29],%r59; $L1: .loc 1 73 0 mov.u32 %value,%r28; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: snprintf .visible .func (.param .u32 %value_out) snprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u32 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .u16 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .u16 %r38; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r48; .reg .u16 %r50; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r59; mov.u64 %r30,%ar0; mov.u64 %r31,%ar1; mov.u64 %r32,%ar2; .loc 1 100 0 ld.global.u64 %r25,[_impure_ptr]; .loc 1 102 0 setp.le.u64 %r33,%r31,2147483647; @ %r33 bra $L9; .loc 1 104 0 mov.u32 %r34,139; st.u32 [%r25],%r34; .loc 1 105 0 mov.u32 %r29,-1; bra $L8; $L9: .loc 1 107 0 mov.u16 %r35,520; st.u16 [%frame+16],%r35; .loc 1 108 0 st.u64 [%frame],%r30; st.u64 [%frame+24],%r30; .loc 1 109 0 setp.eq.u64 %r36,%r31,0; @ %r36 bra $L11; cvt.u32.u64 %r37,%r31; add.u32 %r26,%r37,-1; st.u32 [%frame+12],%r26; st.u32 [%frame+32],%r26; .loc 1 110 0 mov.u16 %r38,-1; st.u16 [%frame+18],%r38; .loc 1 116 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r44,[%value_in]; } mov.u32 %r29,%r44; .loc 1 118 0 setp.lt.s32 %r45,%r29,-1; @ %r45 bra $L12; $L14: .loc 1 121 0 ld.u64 %r24,[%frame]; mov.u32 %r46,0; st.u8 [%r24],%r46; bra $L8; $L11: .loc 1 109 0 cvt.u32.u64 %r48,%r31; st.u32 [%frame+12],%r48; st.u32 [%frame+32],%r48; .loc 1 110 0 mov.u16 %r50,-1; st.u16 [%frame+18],%r50; .loc 1 116 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r56,[%value_in]; } mov.u32 %r29,%r56; .loc 1 118 0 setp.lt.s32 %r57,%r29,-1; @ ! %r57 bra $L8; bra $L13; $L12: .loc 1 119 0 mov.u32 %r58,139; st.u32 [%r25],%r58; bra $L14; $L13: mov.u32 %r59,139; st.u32 [%r25],%r59; $L8: .loc 1 123 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } lib_a-sprintf.o/0 0 0 644 3377 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _sprintf_r .visible .func (.param .u32 %value_out) _sprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdio/sprintf.c" // BEGIN GLOBAL FUNCTION DECL: sprintf .visible .func (.param .u32 %value_out) sprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: _sprintf_r .visible .func (.param .u32 %value_out) _sprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r22; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r36; .reg .u32 %r37; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; .loc 1 597 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 598 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 605 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r36,[%value_in]; } .loc 1 607 0 ld.u64 %r22,[%frame]; mov.u32 %r37,0; st.u8 [%r22],%r37; .loc 1 609 0 mov.u32 %value,%r36; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: sprintf .visible .func (.param .u32 %value_out) sprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 636 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 637 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 644 0 ld.global.u64 %r36,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r36; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r37,[%value_in]; } .loc 1 646 0 ld.u64 %r23,[%frame]; mov.u32 %r38,0; st.u8 [%r23],%r38; .loc 1 648 0 mov.u32 %value,%r37; st.param.u32 [%value_out],%value; ret; } lib_a-srand48.o/0 0 0 644 1876 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _srand48_r .visible .func _srand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/srand48.c" // BEGIN GLOBAL FUNCTION DECL: srand48 .visible .func srand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: _srand48_r .visible .func _srand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r26; .reg .u64 %r27; .reg .u16 %r28; .reg .u64 %r29; .reg .u16 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 22 0 mov.u16 %r28,13070; st.u16 [%r26+240],%r28; .loc 1 23 0 st.u16 [%r26+242],%r27; .loc 1 24 0 shr.u64 %r29,%r27,16; st.u16 [%r26+244],%r29; .loc 1 25 0 mov.u16 %r30,-6547; st.u16 [%r26+246],%r30; .loc 1 26 0 mov.u16 %r31,-8468; st.u16 [%r26+248],%r31; .loc 1 27 0 mov.u16 %r32,5; st.u16 [%r26+250],%r32; .loc 1 28 0 mov.u16 %r33,11; st.u16 [%r26+252],%r33; .loc 1 29 0 ret; } // BEGIN GLOBAL FUNCTION DEF: srand48 .visible .func srand48 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u64 %r27; .reg .u16 %r28; .reg .u64 %r29; .reg .u16 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; mov.u64 %r27,%ar0; .loc 1 36 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 22 0 mov.u16 %r28,13070; st.u16 [%r22+240],%r28; .loc 1 23 0 st.u16 [%r22+242],%r27; .loc 1 24 0 shr.u64 %r29,%r27,16; st.u16 [%r22+244],%r29; .loc 1 25 0 mov.u16 %r30,-6547; st.u16 [%r22+246],%r30; .loc 1 26 0 mov.u16 %r31,-8468; st.u16 [%r22+248],%r31; .loc 1 27 0 mov.u16 %r32,5; st.u16 [%r22+250],%r32; .loc 1 28 0 mov.u16 %r33,11; st.u16 [%r22+252],%r33; .loc 1 37 0 ret; } lib_a-sscanf.o/ 0 0 0 644 4315 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sscanf .visible .func (.param .u32 %value_out) sscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/stdio/sscanf.c" // BEGIN GLOBAL FUNCTION DECL: _sscanf_r .visible .func (.param .u32 %value_out) _sscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __seofread .extern .func (.param .u32 %value_out) __seofread (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ssvfscanf_r .extern .func (.param .u32 %value_out) __ssvfscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: sscanf .visible .func (.param .u32 %value_out) sscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u64 %r41; .reg .u32 %r42; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; .loc 1 416 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 417 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 418 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 419 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 420 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 421 0 st.u64 [%frame+120],%r33; .loc 1 422 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 428 0 ld.global.u64 %r41,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r41; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r42,[%value_in]; } .loc 1 431 0 mov.u32 %value,%r42; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _sscanf_r .visible .func (.param .u32 %value_out) _sscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u32 %r41; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; mov.u64 %r28,%ar2; .loc 1 460 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 461 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 462 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 463 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 464 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 465 0 st.u64 [%frame+120],%r33; .loc 1 466 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 472 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r41,[%value_in]; } .loc 1 475 0 mov.u32 %value,%r41; st.param.u32 [%value_out],%value; ret; } lib_a-stpcpy.o/ 0 0 0 644 1851 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: stpcpy .visible .func (.param .u64 %value_out) stpcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/stpcpy.c" // BEGIN GLOBAL FUNCTION DEF: stpcpy .visible .func (.param .u64 %value_out) stpcpy (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .pred %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .pred %r112; .reg .u32 %r113; .reg .pred %r114; mov.u64 %r98,%ar0; mov.u64 %r99,%ar1; .loc 1 71 0 mov.u64 %r86,%r98; or.b64 %r100,%r99,%r98; and.b64 %r101,%r100,7; setp.ne.u64 %r102,%r101,0; @ %r102 bra $L2; .loc 1 78 0 ld.u64 %r79,[%r99]; add.u64 %r103,%r79,-72340172838076673; not.b64 %r104,%r79; and.b64 %r105,%r103,%r104; and.b64 %r106,%r105,-9187201950435737472; setp.ne.u64 %r107,%r106,0; @ %r107 bra $L2; $L3: .loc 1 80 0 add.u64 %r99,%r99,8; add.u64 %r98,%r98,8; st.u64 [%r86],%r79; .loc 1 78 0 ld.u64 %r79,[%r99]; mov.u64 %r86,%r98; add.u64 %r108,%r79,-72340172838076673; not.b64 %r109,%r79; and.b64 %r110,%r108,%r109; and.b64 %r111,%r110,-9187201950435737472; setp.eq.u64 %r112,%r111,0; @ %r112 bra $L3; $L2: mov.u64 %r94,%r98; mov.u64 %r93,%r99; $L4: mov.u64 %r97,%r94; .loc 1 88 0 ld.s8 %r85,[%r93]; cvt.u32.u32 %r113,%r85; st.u8 [%r94],%r113; add.u64 %r94,%r94,1; add.u64 %r93,%r93,1; setp.ne.u32 %r114,%r85,0; @ %r114 bra $L4; .loc 1 91 0 mov.u64 %value,%r97; st.param.u64 [%value_out],%value; ret; } lib_a-stpncpy.o/0 0 0 644 3242 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: stpncpy .visible .func (.param .u64 %value_out) stpncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/stpncpy.c" // BEGIN GLOBAL FUNCTION DEF: stpncpy .visible .func (.param .u64 %value_out) stpncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r91; .reg .u32 %r92; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u32 %r108; .reg .u32 %r109; .reg .u32 %r111; .reg .u32 %r112; .reg .u16 %r113; .reg .u16 %r114; .reg .u16 %r115; .reg .u32 %r116; .reg .u16 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .pred %r124; .reg .u32 %r125; .reg .pred %r126; .reg .pred %r127; .reg .pred %r128; .reg .pred %r129; .reg .u32 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .pred %r133; mov.u64 %r102,%ar0; mov.u64 %r103,%ar1; mov.u64 %r104,%ar2; .loc 1 83 0 mov.u64 %r100,%r102; or.b64 %r105,%r103,%r102; and.b64 %r106,%r105,7; set.u32.eq.u64 %r108,%r106,0; neg.s32 %r109,%r108; set.u32.gt.u64 %r111,%r104,7; neg.s32 %r112,%r111; cvt.u16.u32 %r114,%r109; cvt.u16.u32 %r115,%r112; and.b16 %r113,%r114,%r115; cvt.u32.u16 %r116,%r113; cvt.u16.u8 %r117,%r116; setp.ne.u16 %r118,%r117,0; @ ! %r118 bra $L3; bra $L2; $L4: .loc 1 92 0 add.u64 %r104,%r104,-8; .loc 1 93 0 add.u64 %r103,%r103,8; add.u64 %r100,%r100,8; mov.u64 %r102,%r100; st.u64 [%r97],%r79; .loc 1 90 0 setp.le.u64 %r119,%r104,7; @ %r119 bra $L3; $L2: mov.u64 %r97,%r100; ld.u64 %r79,[%r103]; add.u64 %r120,%r79,-72340172838076673; not.b64 %r121,%r79; and.b64 %r122,%r120,%r121; and.b64 %r123,%r122,-9187201950435737472; setp.eq.u64 %r124,%r123,0; @ %r124 bra $L4; mov.u64 %r102,%r100; bra $L5; $L7: .loc 1 103 0 add.u64 %r87,%r87,-1; add.u64 %r91,%r91,1; mov.u64 %r89,%r91; .loc 1 104 0 ld.s8 %r85,[%r98]; cvt.u32.u32 %r125,%r85; st.u8 [%r101],%r125; add.u64 %r98,%r98,1; setp.eq.u32 %r126,%r85,0; @ %r126 bra $L6; $L11: mov.u64 %r101,%r91; .loc 1 101 0 setp.ne.u64 %r127,%r87,0; @ %r127 bra $L7; bra $L1; $L14: .loc 1 104 0 mov.u64 %r101,%r102; $L6: .loc 1 111 0 setp.ne.u64 %r128,%r87,0; @ %r128 bra $L9; bra $L1; $L3: .loc 1 101 0 setp.eq.u64 %r129,%r104,0; @ %r129 bra $L13; $L5: .loc 1 103 0 add.u64 %r87,%r104,-1; .loc 1 104 0 add.u64 %r96,%r103,1; add.u64 %r89,%r102,1; ld.s8 %r92,[%r103]; cvt.u32.u32 %r130,%r92; st.u8 [%r102],%r130; setp.eq.u32 %r131,%r92,0; @ %r131 bra $L14; mov.u64 %r91,%r89; mov.u64 %r98,%r96; bra $L11; $L9: mov.u64 %r86,%r89; add.u64 %r88,%r86,%r87; .loc 1 112 0 mov.u32 %r132,0; $L12: st.u8 [%r86],%r132; add.u64 %r86,%r86,1; .loc 1 111 0 setp.ne.u64 %r133,%r88,%r86; @ %r133 bra $L12; bra $L1; $L13: .loc 1 101 0 mov.u64 %r101,%r102; $L1: .loc 1 115 0 mov.u64 %value,%r101; st.param.u64 [%value_out],%value; ret; } /578 0 0 0 644 2076 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcasecmp .visible .func (.param .u32 %value_out) strcasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strcasecmp.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strcasecmp .visible .func (.param .u32 %value_out) strcasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r49; .reg .u32 %r58; .reg .u32 %r62; .reg .u64 %r66; .reg .u64 %r67; .reg .u32 %r69; .reg .u64 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u16 %r77; .reg .u16 %r78; .reg .u16 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .u64 %r85; .reg .u16 %r88; .reg .u16 %r89; .reg .u16 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .pred %r93; .reg .u32 %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .u16 %r99; .loc 1 54 0 ld.global.u64 %r49,[__ctype_ptr__]; mov.u64 %r67,%ar0; mov.u64 %r66,%ar1; bra $L2; $L6: add.u64 %r67,%r67,1; add.u64 %r66,%r66,1; $L2: ld.u8 %r58,[%r67]; cvt.u32.u32 %r73,%r58; cvt.u64.u8 %r72,%r73; add.u64 %r74,%r49,%r72; ld.u8 %r99,[%r74+1]; mov.u16 %r78,%r99; and.b16 %r77,%r78,3; cvt.u32.u16 %r81,%r77; cvt.s32.s8 %r80,%r81; cvt.u16.u32 %r79,%r80; setp.ne.u16 %r82,%r79,1; @ %r82 bra $L3; add.u32 %r58,%r58,32; $L3: .loc 1 55 0 ld.u8 %r62,[%r66]; cvt.u32.u32 %r84,%r62; cvt.u64.u8 %r83,%r84; add.u64 %r85,%r49,%r83; ld.u8 %r99,[%r85+1]; mov.u16 %r89,%r99; and.b16 %r88,%r89,3; cvt.u32.u16 %r92,%r88; cvt.s32.s8 %r91,%r92; cvt.u16.u32 %r90,%r91; setp.ne.u16 %r93,%r90,1; @ %r93 bra $L4; add.u32 %r94,%r62,32; .loc 1 56 0 sub.u32 %r69,%r58,%r94; setp.ne.u32 %r95,%r69,0; @ ! %r95 bra $L6; bra $L1; $L4: sub.u32 %r69,%r58,%r62; setp.ne.u32 %r96,%r69,0; @ %r96 bra $L1; setp.ne.u32 %r97,%r62,0; @ %r97 bra $L6; $L1: .loc 1 60 0 mov.u32 %value,%r69; st.param.u32 [%value_out],%value; ret; } /598 0 0 0 644 35700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/str-two-way.h" // BEGIN FUNCTION DECL: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: strcasestr .visible .func (.param .u64 %value_out) strcasestr (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 2 "../../../../../newlib/libc/string/strcasestr.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DECL: strncasecmp .extern .func (.param .u32 %value_out) strncasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DEF: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u32 %r30; .reg .u64 %r36; .reg .u64 %r44; .reg .u64 %r49; .reg .u64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r65; .reg .u32 %r70; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u64 %r81; .reg .u16 %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .pred %r89; .reg .u32 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u32 %r94; .reg .u64 %r95; .reg .u16 %r98; .reg .u16 %r99; .reg .u16 %r100; .reg .u32 %r101; .reg .u32 %r102; .reg .pred %r103; .reg .u32 %r104; .reg .u16 %r105; .reg .u16 %r106; .reg .pred %r107; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .u16 %r119; .reg .u16 %r120; .reg .u16 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .pred %r124; .reg .u32 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u32 %r129; .reg .u64 %r130; .reg .u16 %r133; .reg .u16 %r134; .reg .u16 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .u32 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .pred %r142; .reg .pred %r145; .reg .pred %r146; .reg .pred %r147; .reg .pred %r148; .reg .u64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u64 %r153; .reg .u16 %r154; mov.u64 %r75,%ar0; mov.u64 %r76,%ar1; mov.u64 %r77,%ar2; .loc 1 116 0 ld.global.u64 %r23,[__ctype_ptr__]; .loc 1 113 0 mov.u64 %r56,1; mov.u64 %r54,%r56; .loc 1 112 0 mov.u64 %r36,0; .loc 1 111 0 mov.u64 %r52,-1; .loc 1 140 0 mov.u64 %r153,%r56; .loc 1 114 0 bra $L2; $L9: .loc 1 116 0 add.u64 %r78,%r75,%r151; ld.u8 %r57,[%r78]; cvt.u32.u32 %r80,%r57; cvt.u64.u8 %r79,%r80; add.u64 %r81,%r23,%r79; ld.u8 %r154,[%r81+1]; mov.u16 %r85,%r154; and.b16 %r84,%r85,3; cvt.u32.u16 %r88,%r84; cvt.s32.s8 %r87,%r88; cvt.u16.u32 %r86,%r87; setp.ne.u16 %r89,%r86,1; @ %r89 bra $L3; add.u32 %r57,%r57,32; $L3: cvt.u32.u32 %r90,%r57; cvt.u32.u8 %r70,%r90; .loc 1 117 0 add.u64 %r91,%r75,%r52; add.u64 %r92,%r91,%r54; ld.u8 %r58,[%r92]; cvt.u32.u32 %r94,%r58; cvt.u64.u8 %r93,%r94; add.u64 %r95,%r23,%r93; ld.u8 %r154,[%r95+1]; mov.u16 %r99,%r154; and.b16 %r98,%r99,3; cvt.u32.u16 %r102,%r98; cvt.s32.s8 %r101,%r102; cvt.u16.u32 %r100,%r101; setp.ne.u16 %r103,%r100,1; @ %r103 bra $L4; add.u32 %r58,%r58,32; $L4: cvt.u32.u32 %r104,%r58; .loc 1 118 0 cvt.u16.u32 %r105,%r70; cvt.u16.u8 %r106,%r104; setp.ge.u16 %r107,%r105,%r106; @ %r107 bra $L5; .loc 1 123 0 sub.u64 %r56,%r151,%r52; mov.u64 %r36,%r151; .loc 1 122 0 mov.u64 %r54,1; bra $L2; $L5: .loc 1 125 0 setp.ne.u16 %r110,%r105,%r106; @ %r110 bra $L7; .loc 1 128 0 setp.eq.u64 %r111,%r54,%r56; @ %r111 bra $L8; .loc 1 129 0 add.u64 %r54,%r54,1; bra $L2; $L8: .loc 1 132 0 mov.u64 %r36,%r151; .loc 1 133 0 mov.u64 %r54,1; bra $L2; $L7: .loc 1 139 0 mov.u64 %r52,%r36; add.u64 %r36,%r36,1; .loc 1 140 0 mov.u64 %r56,%r153; mov.u64 %r54,1; $L2: .loc 1 114 0 add.u64 %r151,%r36,%r54; setp.lt.u64 %r112,%r151,%r76; @ %r112 bra $L9; .loc 1 143 0 st.u64 [%r77],%r56; .loc 1 148 0 mov.u64 %r44,1; mov.u64 %r55,%r44; .loc 1 147 0 mov.u64 %r49,0; .loc 1 146 0 mov.u64 %r53,-1; .loc 1 175 0 mov.u64 %r152,%r44; .loc 1 149 0 bra $L10; $L17: .loc 1 151 0 add.u64 %r113,%r75,%r150; ld.u8 %r59,[%r113]; cvt.u32.u32 %r115,%r59; cvt.u64.u8 %r114,%r115; add.u64 %r116,%r23,%r114; ld.u8 %r154,[%r116+1]; mov.u16 %r120,%r154; and.b16 %r119,%r120,3; cvt.u32.u16 %r123,%r119; cvt.s32.s8 %r122,%r123; cvt.u16.u32 %r121,%r122; setp.ne.u16 %r124,%r121,1; @ %r124 bra $L11; add.u32 %r59,%r59,32; $L11: cvt.u32.u32 %r125,%r59; cvt.u32.u8 %r65,%r125; .loc 1 152 0 add.u64 %r126,%r75,%r53; add.u64 %r127,%r126,%r55; ld.u8 %r30,[%r127]; cvt.u32.u32 %r129,%r30; cvt.u64.u8 %r128,%r129; add.u64 %r130,%r23,%r128; ld.u8 %r154,[%r130+1]; mov.u16 %r134,%r154; and.b16 %r133,%r134,3; cvt.u32.u16 %r137,%r133; cvt.s32.s8 %r136,%r137; cvt.u16.u32 %r135,%r136; setp.ne.u16 %r138,%r135,1; @ %r138 bra $L12; add.u32 %r30,%r30,32; $L12: cvt.u32.u32 %r139,%r30; .loc 1 153 0 cvt.u16.u32 %r140,%r65; cvt.u16.u8 %r141,%r139; setp.le.u16 %r142,%r140,%r141; @ %r142 bra $L13; .loc 1 158 0 sub.u64 %r44,%r150,%r53; mov.u64 %r49,%r150; .loc 1 157 0 mov.u64 %r55,1; bra $L10; $L13: .loc 1 160 0 setp.ne.u16 %r145,%r140,%r141; @ %r145 bra $L15; .loc 1 163 0 setp.eq.u64 %r146,%r55,%r44; @ %r146 bra $L16; .loc 1 164 0 add.u64 %r55,%r55,1; bra $L10; $L16: .loc 1 167 0 mov.u64 %r49,%r150; .loc 1 168 0 mov.u64 %r55,1; bra $L10; $L15: .loc 1 174 0 mov.u64 %r53,%r49; add.u64 %r49,%r49,1; .loc 1 175 0 mov.u64 %r44,%r152; mov.u64 %r55,1; $L10: .loc 1 149 0 add.u64 %r150,%r49,%r55; setp.lt.u64 %r147,%r150,%r76; @ %r147 bra $L17; .loc 1 181 0 add.u64 %r51,%r53,1; add.u64 %r74,%r52,1; setp.lt.u64 %r148,%r51,%r74; @ %r148 bra $L1; .loc 1 183 0 st.u64 [%r77],%r44; .loc 1 184 0 mov.u64 %r74,%r51; $L1: .loc 1 185 0 mov.u64 %value,%r74; st.param.u64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[2056]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r76; .reg .u64 %r85; .reg .u64 %r90; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r116; .reg .u64 %r119; .reg .u64 %r144; .reg .u64 %r148; .reg .u64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u64 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .u32 %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .u64 %r170; .reg .u64 %r174; .reg .u64 %r185; .reg .u64 %r187; .reg .u64 %r190; .reg .u64 %r196; .reg .u64 %r202; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r210; .reg .u64 %r212; .reg .u64 %r219; .reg .u64 %r221; .reg .u64 %r226; .reg .u64 %r228; .reg .u64 %r230; .reg .u64 %r234; .reg .u64 %r236; .reg .u64 %r238; .reg .u64 %r240; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u64 %r245; .reg .u64 %r246; .reg .u64 %r250; .reg .u64 %r251; .reg .pred %r252; .reg .u64 %r253; .reg .pred %r254; .reg .u64 %r255; .reg .u32 %r256; .reg .u64 %r257; .reg .u16 %r260; .reg .u16 %r261; .reg .u16 %r262; .reg .u32 %r263; .reg .u32 %r264; .reg .pred %r265; .reg .u64 %r266; .reg .u64 %r267; .reg .u64 %r268; .reg .pred %r269; .reg .u32 %r273; .reg .pred %r274; .reg .u64 %r275; .reg .u64 %r277; .reg .u32 %r278; .reg .u64 %r279; .reg .u16 %r282; .reg .u16 %r283; .reg .u16 %r284; .reg .u32 %r285; .reg .u32 %r286; .reg .pred %r287; .reg .u64 %r288; .reg .u64 %r289; .reg .u64 %r290; .reg .pred %r291; .reg .pred %r292; .reg .pred %r293; .reg .pred %r294; .reg .u64 %r295; .reg .pred %r296; .reg .u64 %r297; .reg .u32 %r298; .reg .u64 %r299; .reg .u16 %r302; .reg .u16 %r303; .reg .u16 %r304; .reg .u32 %r305; .reg .u32 %r306; .reg .pred %r307; .reg .u64 %r308; .reg .u32 %r309; .reg .u64 %r310; .reg .u16 %r313; .reg .u16 %r314; .reg .u16 %r315; .reg .u32 %r316; .reg .u32 %r317; .reg .pred %r318; .reg .pred %r319; .reg .pred %r320; .reg .pred %r321; .reg .u64 %r322; .reg .pred %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u64 %r326; .reg .u16 %r329; .reg .u16 %r330; .reg .u16 %r331; .reg .u32 %r332; .reg .u32 %r333; .reg .pred %r334; .reg .u64 %r335; .reg .u32 %r336; .reg .u64 %r337; .reg .u16 %r340; .reg .u16 %r341; .reg .u16 %r342; .reg .u32 %r343; .reg .u32 %r344; .reg .pred %r345; .reg .pred %r346; .reg .u64 %r347; .reg .pred %r348; .reg .u64 %r349; .reg .u32 %r352; .reg .u64 %r354; .reg .u64 %r355; .reg .u64 %r356; .reg .u32 %r358; .reg .u32 %r359; .reg .u32 %r361; .reg .u32 %r362; .reg .u16 %r363; .reg .u16 %r364; .reg .u16 %r365; .reg .u32 %r366; .reg .u16 %r367; .reg .pred %r368; .reg .u64 %r369; .reg .u64 %r370; .reg .u64 %r371; .reg .u64 %r372; .reg .u64 %r374; .reg .u32 %r375; .reg .u64 %r376; .reg .u16 %r379; .reg .u16 %r380; .reg .u16 %r381; .reg .u32 %r382; .reg .u32 %r383; .reg .pred %r384; .reg .u64 %r385; .reg .u64 %r386; .reg .u64 %r387; .reg .pred %r388; .reg .pred %r389; .reg .u64 %r390; .reg .pred %r391; .reg .u64 %r392; .reg .u32 %r393; .reg .u64 %r394; .reg .u16 %r397; .reg .u16 %r398; .reg .u16 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .pred %r402; .reg .u64 %r403; .reg .u32 %r404; .reg .u64 %r405; .reg .u16 %r408; .reg .u16 %r409; .reg .u16 %r410; .reg .u32 %r411; .reg .u32 %r412; .reg .pred %r413; .reg .pred %r414; .reg .pred %r415; .reg .u64 %r417; .reg .u64 %r418; .reg .pred %r419; .reg .u64 %r420; .reg .u32 %r421; .reg .u64 %r422; .reg .u16 %r425; .reg .u16 %r426; .reg .u16 %r427; .reg .u32 %r428; .reg .u32 %r429; .reg .pred %r430; .reg .u64 %r431; .reg .u32 %r432; .reg .u64 %r433; .reg .u16 %r436; .reg .u16 %r437; .reg .u16 %r438; .reg .u32 %r439; .reg .u32 %r440; .reg .pred %r441; .reg .pred %r442; .reg .u64 %r443; .reg .u32 %r446; .reg .u64 %r448; .reg .u64 %r449; .reg .u64 %r450; .reg .u32 %r452; .reg .u32 %r453; .reg .u32 %r455; .reg .u32 %r456; .reg .u16 %r457; .reg .u16 %r458; .reg .u16 %r459; .reg .u32 %r460; .reg .u16 %r461; .reg .pred %r462; .reg .u64 %r464; .reg .u64 %r468; .reg .u64 %r469; .reg .u64 %r470; .reg .u32 %r474; .reg .pred %r475; .reg .u64 %r476; .reg .u64 %r477; .reg .u64 %r478; .reg .pred %r479; .reg .u16 %r480; mov.u64 %r243,%ar0; mov.u64 %r244,%ar1; mov.u64 %r245,%ar2; mov.u64 %r246,%ar3; .loc 1 304 0 add.u64 %r250,%frame,2048; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r245; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r246; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r250; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r251,[%value_in]; } mov.u64 %r202,%frame; $L20: .loc 1 311 0 st.u64 [%r202],%r246; add.u64 %r202,%r202,8; .loc 1 310 0 setp.ne.u64 %r252,%r250,%r202; @ %r252 bra $L20; ld.u64 %r253,[%frame+2048]; add.u64 %r240,%r245,%r253; .loc 1 312 0 setp.eq.u64 %r254,%r246,0; @ %r254 bra $L21; .loc 1 313 0 ld.global.u64 %r76,[__ctype_ptr__]; add.u64 %r238,%r246,-1; mov.u64 %r205,%r245; mov.u64 %r204,%r238; $L23: ld.u8 %r154,[%r205]; cvt.u32.u32 %r256,%r154; cvt.u64.u8 %r255,%r256; add.u64 %r257,%r76,%r255; ld.u8 %r480,[%r257+1]; mov.u16 %r261,%r480; and.b16 %r260,%r261,3; cvt.u32.u16 %r264,%r260; cvt.s32.s8 %r263,%r264; cvt.u16.u32 %r262,%r263; setp.ne.u16 %r265,%r262,1; @ %r265 bra $L22; add.u32 %r154,%r154,32; $L22: cvt.s64.s32 %r266,%r154; shl.b64 %r267,%r266,3; add.u64 %r268,%frame,%r267; st.u64 [%r268],%r204; add.u64 %r205,%r205,1; add.u64 %r204,%r204,-1; .loc 1 312 0 setp.ne.u64 %r269,%r204,-1; @ %r269 bra $L23; .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r245; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r240; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r251; call (%value_in),strncasecmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r273,[%value_in]; } setp.eq.u32 %r274,%r273,0; @ %r274 bra $L63; bra $L25; $L43: .loc 1 329 0 add.u64 %r275,%r243,%r109; ld.global.u64 %r85,[__ctype_ptr__]; ld.u8 %r155,[%r275+-1]; cvt.u32.u32 %r278,%r155; cvt.u64.u8 %r277,%r278; add.u64 %r279,%r85,%r277; ld.u8 %r480,[%r279+1]; mov.u16 %r283,%r480; and.b16 %r282,%r283,3; cvt.u32.u16 %r286,%r282; cvt.s32.s8 %r285,%r286; cvt.u16.u32 %r284,%r285; setp.ne.u16 %r287,%r284,1; @ %r287 bra $L26; add.u32 %r155,%r155,32; $L26: cvt.s64.s32 %r288,%r155; shl.b64 %r289,%r288,3; add.u64 %r290,%frame,%r289; ld.u64 %r153,[%r290]; .loc 1 330 0 setp.eq.u64 %r291,%r153,0; @ %r291 bra $L27; .loc 1 332 0 setp.eq.u64 %r292,%r152,0; @ %r292 bra $L28; ld.u64 %r90,[%frame+2048]; setp.le.u64 %r293,%r90,%r153; @ %r293 bra $L28; .loc 1 337 0 sub.u64 %r153,%r246,%r90; $L28: .loc 1 340 0 add.u64 %r151,%r151,%r153; .loc 1 339 0 mov.u64 %r152,0; .loc 1 341 0 bra $L29; $L27: .loc 1 345 0 max.u64 %r185,%r152,%r251; .loc 1 346 0 setp.ge.u64 %r294,%r185,%r238; @ %r294 bra $L30; add.u64 %r228,%r245,%r185; add.u64 %r295,%r151,%r185; add.u64 %r226,%r243,%r295; bra $L31; $L34: .loc 1 348 0 add.u64 %r185,%r185,1; add.u64 %r228,%r228,1; add.u64 %r226,%r226,1; .loc 1 346 0 setp.eq.u64 %r296,%r185,%r238; @ %r296 bra $L30; $L31: ld.u8 %r156,[%r228]; cvt.u32.u32 %r298,%r156; cvt.u64.u8 %r297,%r298; add.u64 %r299,%r85,%r297; ld.u8 %r480,[%r299+1]; mov.u16 %r303,%r480; and.b16 %r302,%r303,3; cvt.u32.u16 %r306,%r302; cvt.s32.s8 %r305,%r306; cvt.u16.u32 %r304,%r305; setp.ne.u16 %r307,%r304,1; @ %r307 bra $L32; add.u32 %r156,%r156,32; $L32: .loc 1 347 0 ld.u8 %r157,[%r226]; cvt.u32.u32 %r309,%r157; cvt.u64.u8 %r308,%r309; add.u64 %r310,%r85,%r308; ld.u8 %r480,[%r310+1]; mov.u16 %r314,%r480; and.b16 %r313,%r314,3; cvt.u32.u16 %r317,%r313; cvt.s32.s8 %r316,%r317; cvt.u16.u32 %r315,%r316; setp.ne.u16 %r318,%r315,1; @ %r318 bra $L33; add.u32 %r157,%r157,32; $L33: .loc 1 346 0 setp.eq.u32 %r319,%r156,%r157; @ %r319 bra $L34; .loc 1 349 0 setp.lt.u64 %r320,%r185,%r238; @ %r320 bra $L35; $L30: .loc 1 352 0 mov.u64 %r187,%r476; .loc 1 353 0 setp.ge.u64 %r321,%r152,%r251; @ %r321 bra $L64; add.u64 %r236,%r245,%r476; add.u64 %r322,%r151,%r476; add.u64 %r234,%r243,%r322; add.u64 %r230,%r152,-1; bra $L37; $L40: .loc 1 355 0 add.u64 %r190,%r187,-1; add.u64 %r236,%r236,-1; add.u64 %r234,%r234,-1; .loc 1 353 0 setp.eq.u64 %r323,%r190,%r230; @ %r323 bra $L65; mov.u64 %r187,%r190; $L37: add.u64 %r196,%r187,1; ld.u8 %r158,[%r236]; cvt.u32.u32 %r325,%r158; cvt.u64.u8 %r324,%r325; add.u64 %r326,%r85,%r324; ld.u8 %r480,[%r326+1]; mov.u16 %r330,%r480; and.b16 %r329,%r330,3; cvt.u32.u16 %r333,%r329; cvt.s32.s8 %r332,%r333; cvt.u16.u32 %r331,%r332; setp.ne.u16 %r334,%r331,1; @ %r334 bra $L38; add.u32 %r158,%r158,32; $L38: .loc 1 354 0 ld.u8 %r159,[%r234]; cvt.u32.u32 %r336,%r159; cvt.u64.u8 %r335,%r336; add.u64 %r337,%r85,%r335; ld.u8 %r480,[%r337+1]; mov.u16 %r341,%r480; and.b16 %r340,%r341,3; cvt.u32.u16 %r344,%r340; cvt.s32.s8 %r343,%r344; cvt.u16.u32 %r342,%r343; setp.ne.u16 %r345,%r342,1; @ %r345 bra $L39; add.u32 %r159,%r159,32; $L39: .loc 1 353 0 setp.eq.u32 %r346,%r158,%r159; @ %r346 bra $L40; bra $L36; $L64: mov.u64 %r196,%r251; bra $L36; $L65: mov.u64 %r196,%r187; $L36: .loc 1 356 0 add.u64 %r347,%r152,1; setp.le.u64 %r348,%r347,%r196; @ %r348 bra $L41; .loc 1 357 0 add.u64 %r242,%r243,%r151; bra $L19; $L41: .loc 1 360 0 ld.u64 %r108,[%frame+2048]; add.u64 %r151,%r151,%r108; .loc 1 361 0 sub.u64 %r152,%r246,%r108; bra $L29; $L35: sub.u64 %r349,%r151,%r251; add.u64 %r150,%r349,1; .loc 1 365 0 add.u64 %r151,%r150,%r185; .loc 1 366 0 mov.u64 %r152,%r153; $L29: .loc 1 339 0 mov.u64 %r244,%r109; bra $L24; $L63: .loc 1 322 0 mov.u64 %r152,0; .loc 1 324 0 mov.u64 %r151,%r152; .loc 1 352 0 add.u64 %r476,%r251,-1; $L24: .loc 1 325 0 add.u64 %r109,%r151,%r246; sub.u64 %r354,%r109,%r244; add.u64 %r355,%r243,%r244; mov.u32 %r352,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r355; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r352; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r354; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r356,[%value_in]; } set.u32.ne.u64 %r358,%r109,0; neg.s32 %r359,%r358; set.u32.eq.u64 %r361,%r356,0; neg.s32 %r362,%r361; cvt.u16.u32 %r364,%r359; cvt.u16.u32 %r365,%r362; and.b16 %r363,%r364,%r365; cvt.u32.u16 %r366,%r363; cvt.u16.u8 %r367,%r366; setp.ne.u16 %r368,%r367,0; @ %r368 bra $L43; $L61: .loc 1 408 0 mov.u64 %r242,0; bra $L19; $L25: .loc 1 375 0 sub.u64 %r370,%r246,%r251; max.u64 %r369,%r370,%r251; add.u64 %r371,%r369,1; st.u64 [%frame+2048],%r371; .loc 1 376 0 mov.u64 %r148,0; .loc 1 390 0 add.u64 %r477,%r246,-1; .loc 1 396 0 add.u64 %r478,%r251,-1; .loc 1 397 0 setp.eq.u64 %r479,%r478,-1; .loc 1 377 0 bra $L44; $L60: .loc 1 381 0 add.u64 %r372,%r243,%r144; ld.global.u64 %r119,[__ctype_ptr__]; ld.u8 %r160,[%r372+-1]; cvt.u32.u32 %r375,%r160; cvt.u64.u8 %r374,%r375; add.u64 %r376,%r119,%r374; ld.u8 %r480,[%r376+1]; mov.u16 %r380,%r480; and.b16 %r379,%r380,3; cvt.u32.u16 %r383,%r379; cvt.s32.s8 %r382,%r383; cvt.u16.u32 %r381,%r382; setp.ne.u16 %r384,%r381,1; @ %r384 bra $L45; add.u32 %r160,%r160,32; $L45: cvt.s64.s32 %r385,%r160; shl.b64 %r386,%r385,3; add.u64 %r387,%frame,%r386; ld.u64 %r170,[%r387]; .loc 1 382 0 setp.ne.u64 %r388,%r170,0; @ %r388 bra $L46; .loc 1 390 0 setp.ge.u64 %r389,%r251,%r477; @ %r389 bra $L47; add.u64 %r212,%r245,%r251; add.u64 %r390,%r148,%r251; add.u64 %r210,%r243,%r390; mov.u64 %r174,%r251; bra $L48; $L46: .loc 1 384 0 add.u64 %r148,%r148,%r170; .loc 1 385 0 bra $L49; $L52: .loc 1 392 0 add.u64 %r174,%r174,1; add.u64 %r212,%r212,1; add.u64 %r210,%r210,1; .loc 1 390 0 setp.ge.u64 %r391,%r174,%r477; @ %r391 bra $L47; $L48: ld.u8 %r161,[%r212]; cvt.u32.u32 %r393,%r161; cvt.u64.u8 %r392,%r393; add.u64 %r394,%r119,%r392; ld.u8 %r480,[%r394+1]; mov.u16 %r398,%r480; and.b16 %r397,%r398,3; cvt.u32.u16 %r401,%r397; cvt.s32.s8 %r400,%r401; cvt.u16.u32 %r399,%r400; setp.ne.u16 %r402,%r399,1; @ %r402 bra $L50; add.u32 %r161,%r161,32; $L50: .loc 1 391 0 ld.u8 %r162,[%r210]; cvt.u32.u32 %r404,%r162; cvt.u64.u8 %r403,%r404; add.u64 %r405,%r119,%r403; ld.u8 %r480,[%r405+1]; mov.u16 %r409,%r480; and.b16 %r408,%r409,3; cvt.u32.u16 %r412,%r408; cvt.s32.s8 %r411,%r412; cvt.u16.u32 %r410,%r411; setp.ne.u16 %r413,%r410,1; @ %r413 bra $L51; add.u32 %r162,%r162,32; $L51: .loc 1 390 0 setp.eq.u32 %r414,%r161,%r162; @ %r414 bra $L52; .loc 1 393 0 setp.lt.u64 %r415,%r174,%r477; @ %r415 bra $L53; $L47: .loc 1 397 0 @ %r479 bra $L54; add.u64 %r221,%r245,%r478; add.u64 %r417,%r148,%r478; add.u64 %r219,%r243,%r417; bra $L55; $L58: add.u64 %r221,%r221,-1; add.u64 %r219,%r219,-1; sub.u64 %r418,%r221,%r245; setp.eq.u64 %r419,%r418,-1; @ %r419 bra $L54; $L55: ld.u8 %r163,[%r221]; cvt.u32.u32 %r421,%r163; cvt.u64.u8 %r420,%r421; add.u64 %r422,%r119,%r420; ld.u8 %r480,[%r422+1]; mov.u16 %r426,%r480; and.b16 %r425,%r426,3; cvt.u32.u16 %r429,%r425; cvt.s32.s8 %r428,%r429; cvt.u16.u32 %r427,%r428; setp.ne.u16 %r430,%r427,1; @ %r430 bra $L56; add.u32 %r163,%r163,32; $L56: .loc 1 398 0 ld.u8 %r164,[%r219]; cvt.u32.u32 %r432,%r164; cvt.u64.u8 %r431,%r432; add.u64 %r433,%r119,%r431; ld.u8 %r480,[%r433+1]; mov.u16 %r437,%r480; and.b16 %r436,%r437,3; cvt.u32.u16 %r440,%r436; cvt.s32.s8 %r439,%r440; cvt.u16.u32 %r438,%r439; setp.ne.u16 %r441,%r438,1; @ %r441 bra $L57; add.u32 %r164,%r164,32; $L57: .loc 1 397 0 setp.eq.u32 %r442,%r163,%r164; @ %r442 bra $L58; bra $L76; $L53: sub.u64 %r443,%r148,%r251; add.u64 %r116,%r443,1; .loc 1 405 0 add.u64 %r148,%r116,%r174; $L49: .loc 1 390 0 mov.u64 %r244,%r144; $L44: .loc 1 377 0 add.u64 %r144,%r148,%r246; sub.u64 %r448,%r144,%r244; add.u64 %r449,%r243,%r244; mov.u32 %r446,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r446; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r448; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r450,[%value_in]; } set.u32.eq.u64 %r452,%r450,0; neg.s32 %r453,%r452; set.u32.ne.u64 %r455,%r144,0; neg.s32 %r456,%r455; cvt.u16.u32 %r458,%r453; cvt.u16.u32 %r459,%r456; and.b16 %r457,%r458,%r459; cvt.u32.u16 %r460,%r457; cvt.u16.u8 %r461,%r460; setp.ne.u16 %r462,%r461,0; @ %r462 bra $L60; bra $L61; $L54: .loc 1 401 0 add.u64 %r242,%r243,%r148; bra $L19; $L76: .loc 1 402 0 ld.u64 %r464,[%frame+2048]; add.u64 %r148,%r148,%r464; bra $L49; $L62: .loc 1 325 0 neg.s64 %r468,%r244; add.u64 %r469,%r243,%r244; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r469; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r474; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r468; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r470,[%value_in]; } .loc 1 408 0 mov.u64 %r242,%r246; bra $L19; $L21: .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r245; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r240; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r251; call (%value_in),strncasecmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r474,[%value_in]; } setp.eq.u32 %r475,%r474,0; @ %r475 bra $L62; bra $L25; $L19: .loc 1 409 0 mov.u64 %value,%r242; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strcasestr .visible .func (.param .u64 %value_out) strcasestr (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r22; .reg .u64 %r24; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r41; .reg .u32 %r42; .reg .u64 %r45; .reg .u64 %r47; .reg .u32 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r58; .reg .u64 %r59; .reg .u64 %r61; .reg .u64 %r67; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r80; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r105; .reg .u64 %r107; .reg .u64 %r113; .reg .u32 %r120; .reg .u32 %r121; .reg .u64 %r124; .reg .u32 %r137; .reg .u32 %r138; .reg .u64 %r141; .reg .u64 %r148; .reg .u64 %r149; .reg .u64 %r154; .reg .u64 %r156; .reg .u64 %r163; .reg .u64 %r165; .reg .u64 %r170; .reg .u64 %r172; .reg .u64 %r174; .reg .u64 %r178; .reg .u64 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .u64 %r183; .reg .pred %r184; .reg .pred %r185; .reg .u32 %r186; .reg .u64 %r187; .reg .u64 %r189; .reg .u16 %r192; .reg .u16 %r193; .reg .u16 %r194; .reg .u32 %r195; .reg .u32 %r196; .reg .pred %r197; .reg .u32 %r198; .reg .u64 %r199; .reg .u64 %r201; .reg .u16 %r204; .reg .u16 %r205; .reg .u16 %r206; .reg .u32 %r207; .reg .u32 %r208; .reg .pred %r209; .reg .u32 %r211; .reg .u32 %r212; .reg .pred %r213; .reg .pred %r214; .reg .pred %r215; .reg .u16 %r216; .reg .u32 %r217; .reg .pred %r218; .reg .pred %r219; .reg .pred %r220; .reg .u64 %r224; .reg .u64 %r228; .reg .u64 %r229; .reg .u32 %r230; .reg .pred %r231; .reg .pred %r232; .reg .u64 %r233; .reg .pred %r234; .reg .u64 %r235; .reg .u32 %r236; .reg .u64 %r237; .reg .u16 %r240; .reg .u16 %r241; .reg .u16 %r242; .reg .u32 %r243; .reg .u32 %r244; .reg .pred %r245; .reg .u64 %r246; .reg .u32 %r247; .reg .u64 %r248; .reg .u16 %r251; .reg .u16 %r252; .reg .u16 %r253; .reg .u32 %r254; .reg .u32 %r255; .reg .pred %r256; .reg .pred %r257; .reg .pred %r258; .reg .pred %r259; .reg .u64 %r260; .reg .pred %r261; .reg .u64 %r262; .reg .u32 %r263; .reg .u64 %r264; .reg .u16 %r267; .reg .u16 %r268; .reg .u16 %r269; .reg .u32 %r270; .reg .u32 %r271; .reg .pred %r272; .reg .u64 %r273; .reg .u32 %r274; .reg .u64 %r275; .reg .u16 %r278; .reg .u16 %r279; .reg .u16 %r280; .reg .u32 %r281; .reg .u32 %r282; .reg .pred %r283; .reg .pred %r284; .reg .u64 %r285; .reg .pred %r286; .reg .u64 %r287; .reg .u32 %r290; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u32 %r296; .reg .u32 %r297; .reg .u32 %r299; .reg .u32 %r300; .reg .u16 %r301; .reg .u16 %r302; .reg .u16 %r303; .reg .u32 %r304; .reg .u16 %r305; .reg .pred %r306; .reg .u64 %r307; .reg .u64 %r308; .reg .u64 %r309; .reg .pred %r310; .reg .u64 %r311; .reg .u32 %r312; .reg .u64 %r313; .reg .u16 %r316; .reg .u16 %r317; .reg .u16 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .pred %r321; .reg .u64 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u16 %r327; .reg .u16 %r328; .reg .u16 %r329; .reg .u32 %r330; .reg .u32 %r331; .reg .pred %r332; .reg .pred %r333; .reg .pred %r334; .reg .u64 %r336; .reg .u64 %r339; .reg .pred %r340; .reg .u64 %r341; .reg .u32 %r342; .reg .u64 %r343; .reg .u16 %r346; .reg .u16 %r347; .reg .u16 %r348; .reg .u32 %r349; .reg .u32 %r350; .reg .pred %r351; .reg .u64 %r352; .reg .u32 %r353; .reg .u64 %r354; .reg .u16 %r357; .reg .u16 %r358; .reg .u16 %r359; .reg .u32 %r360; .reg .u32 %r361; .reg .pred %r362; .reg .pred %r363; .reg .u64 %r364; .reg .u32 %r367; .reg .u64 %r369; .reg .u64 %r370; .reg .u64 %r371; .reg .u32 %r373; .reg .u32 %r374; .reg .u32 %r376; .reg .u32 %r377; .reg .u16 %r378; .reg .u16 %r379; .reg .u16 %r380; .reg .u32 %r381; .reg .u16 %r382; .reg .pred %r383; .reg .pred %r384; .reg .u64 %r385; .reg .u64 %r390; .reg .u64 %r392; .reg .u64 %r393; .reg .u64 %r394; .reg .u64 %r395; .reg .u64 %r396; .reg .pred %r397; .reg .u16 %r398; mov.u64 %r182,%ar0; mov.u64 %r183,%ar1; .loc 2 133 0 ld.s8 %r34,[%r182]; ld.s8 %r35,[%r183]; setp.eq.u32 %r184,%r34,0; @ %r184 bra $L78; setp.eq.u32 %r185,%r35,0; @ %r185 bra $L118; .loc 2 134 0 ld.global.u64 %r24,[__ctype_ptr__]; mov.u64 %r47,%r183; mov.u64 %r45,%r182; .loc 2 128 0 mov.u32 %r50,1; $L83: .loc 2 134 0 add.u64 %r45,%r45,1; cvt.u32.u32 %r186,%r34; cvt.u32.u8 %r41,%r186; cvt.u64.u8 %r187,%r186; add.u64 %r189,%r24,%r187; ld.u8 %r398,[%r189+1]; mov.u16 %r193,%r398; and.b16 %r192,%r193,3; cvt.u32.u16 %r196,%r192; cvt.s32.s8 %r195,%r196; cvt.u16.u32 %r194,%r195; setp.ne.u16 %r197,%r194,1; @ %r197 bra $L80; add.u32 %r41,%r41,32; $L80: .loc 2 135 0 add.u64 %r47,%r47,1; cvt.u32.u32 %r198,%r35; cvt.u32.u8 %r42,%r198; cvt.u64.u8 %r199,%r198; add.u64 %r201,%r24,%r199; ld.u8 %r398,[%r201+1]; mov.u16 %r205,%r398; and.b16 %r204,%r205,3; cvt.u32.u16 %r208,%r204; cvt.s32.s8 %r207,%r208; cvt.u16.u32 %r206,%r207; setp.ne.u16 %r209,%r206,1; @ %r209 bra $L81; add.u32 %r42,%r42,32; $L81: set.u32.eq.u32 %r211,%r41,%r42; neg.s32 %r212,%r211; .loc 2 134 0 and.b32 %r50,%r50,%r212; .loc 2 133 0 ld.s8 %r34,[%r45]; setp.eq.u32 %r213,%r34,0; @ %r213 bra $L82; ld.s8 %r35,[%r47]; setp.ne.u32 %r214,%r35,0; @ %r214 bra $L83; bra $L84; $L78: .loc 2 136 0 setp.eq.u32 %r215,%r35,0; .loc 2 137 0 selp.u64 %r181,%r182,0,%r215; bra $L77; $L82: .loc 2 136 0 ld.s8 %r217,[%r47]; cvt.u16.u32 %r216,%r217; setp.ne.u16 %r218,%r216,0; @ %r218 bra $L120; $L84: .loc 2 138 0 setp.ne.u32 %r219,%r50,0; @ %r219 bra $L121; .loc 2 140 0 sub.u64 %r51,%r47,%r183; .loc 2 141 0 add.u64 %r52,%r182,1; .loc 2 142 0 add.u64 %r53,%r51,-1; .loc 2 145 0 setp.gt.u64 %r220,%r51,31; @ %r220 bra $L85; .loc 1 209 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r183; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r51; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r224,[%value_in]; } .loc 1 213 0 ld.u64 %r229,[%frame]; add.u64 %r228,%r183,%r229; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r183; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r228; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r224; call (%value_in),strncasecmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r230,[%value_in]; } setp.eq.u32 %r231,%r230,0; @ %r231 bra $L122; bra $L134; $L102: .loc 1 223 0 max.u64 %r59,%r224,%r58; .loc 1 224 0 setp.le.u64 %r232,%r51,%r59; @ %r232 bra $L88; ld.global.u64 %r61,[__ctype_ptr__]; add.u64 %r172,%r183,%r59; add.u64 %r233,%r59,%r67; add.u64 %r170,%r52,%r233; bra $L89; $L92: .loc 1 226 0 add.u64 %r59,%r59,1; add.u64 %r172,%r172,1; add.u64 %r170,%r170,1; .loc 1 224 0 setp.eq.u64 %r234,%r51,%r59; @ %r234 bra $L88; $L89: ld.u8 %r74,[%r172]; cvt.u32.u32 %r236,%r74; cvt.u64.u8 %r235,%r236; add.u64 %r237,%r61,%r235; ld.u8 %r398,[%r237+1]; mov.u16 %r241,%r398; and.b16 %r240,%r241,3; cvt.u32.u16 %r244,%r240; cvt.s32.s8 %r243,%r244; cvt.u16.u32 %r242,%r243; setp.ne.u16 %r245,%r242,1; @ %r245 bra $L90; add.u32 %r74,%r74,32; $L90: .loc 1 225 0 ld.u8 %r75,[%r170]; cvt.u32.u32 %r247,%r75; cvt.u64.u8 %r246,%r247; add.u64 %r248,%r61,%r246; ld.u8 %r398,[%r248+1]; mov.u16 %r252,%r398; and.b16 %r251,%r252,3; cvt.u32.u16 %r255,%r251; cvt.s32.s8 %r254,%r255; cvt.u16.u32 %r253,%r254; setp.ne.u16 %r256,%r253,1; @ %r256 bra $L91; add.u32 %r75,%r75,32; $L91: .loc 1 224 0 setp.eq.u32 %r257,%r74,%r75; @ %r257 bra $L92; .loc 1 227 0 setp.gt.u64 %r258,%r51,%r59; @ %r258 bra $L93; $L88: .loc 1 230 0 mov.u64 %r77,%r393; .loc 1 231 0 setp.le.u64 %r259,%r224,%r58; @ %r259 bra $L123; ld.global.u64 %r80,[__ctype_ptr__]; add.u64 %r180,%r183,%r393; add.u64 %r260,%r224,%r67; add.u64 %r178,%r182,%r260; add.u64 %r174,%r58,-1; bra $L95; $L98: .loc 1 233 0 add.u64 %r78,%r77,-1; add.u64 %r180,%r180,-1; add.u64 %r178,%r178,-1; .loc 1 231 0 setp.eq.u64 %r261,%r78,%r174; @ %r261 bra $L124; mov.u64 %r77,%r78; $L95: add.u64 %r148,%r77,1; ld.u8 %r92,[%r180]; cvt.u32.u32 %r263,%r92; cvt.u64.u8 %r262,%r263; add.u64 %r264,%r80,%r262; ld.u8 %r398,[%r264+1]; mov.u16 %r268,%r398; and.b16 %r267,%r268,3; cvt.u32.u16 %r271,%r267; cvt.s32.s8 %r270,%r271; cvt.u16.u32 %r269,%r270; setp.ne.u16 %r272,%r269,1; @ %r272 bra $L96; add.u32 %r92,%r92,32; $L96: .loc 1 232 0 ld.u8 %r93,[%r178]; cvt.u32.u32 %r274,%r93; cvt.u64.u8 %r273,%r274; add.u64 %r275,%r80,%r273; ld.u8 %r398,[%r275+1]; mov.u16 %r279,%r398; and.b16 %r278,%r279,3; cvt.u32.u16 %r282,%r278; cvt.s32.s8 %r281,%r282; cvt.u16.u32 %r280,%r281; setp.ne.u16 %r283,%r280,1; @ %r283 bra $L97; add.u32 %r93,%r93,32; $L97: .loc 1 231 0 setp.eq.u32 %r284,%r92,%r93; @ %r284 bra $L98; bra $L94; $L123: mov.u64 %r148,%r224; bra $L94; $L124: mov.u64 %r148,%r77; $L94: .loc 1 234 0 add.u64 %r285,%r58,1; setp.le.u64 %r286,%r285,%r148; @ %r286 bra $L99; .loc 1 235 0 add.u64 %r181,%r52,%r67; bra $L77; $L99: .loc 1 238 0 ld.u64 %r97,[%frame]; add.u64 %r67,%r67,%r97; .loc 1 239 0 sub.u64 %r58,%r51,%r97; bra $L101; $L93: sub.u64 %r287,%r67,%r224; add.u64 %r149,%r287,1; .loc 1 243 0 add.u64 %r67,%r59,%r149; .loc 1 244 0 mov.u64 %r58,0; $L101: mov.u64 %r53,%r98; bra $L86; $L122: .loc 1 218 0 mov.u64 %r58,0; .loc 1 219 0 mov.u64 %r67,%r58; .loc 1 230 0 add.u64 %r393,%r224,-1; $L86: .loc 1 220 0 add.u64 %r98,%r51,%r67; sub.u64 %r292,%r98,%r53; add.u64 %r293,%r52,%r53; mov.u32 %r290,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r293; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r290; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r292; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r294,[%value_in]; } set.u32.eq.u64 %r296,%r294,0; neg.s32 %r297,%r296; set.u32.ne.u64 %r299,%r98,0; neg.s32 %r300,%r299; cvt.u16.u32 %r302,%r297; cvt.u16.u32 %r303,%r300; and.b16 %r301,%r302,%r303; cvt.u32.u16 %r304,%r301; cvt.u16.u8 %r305,%r304; setp.ne.u16 %r306,%r305,0; @ %r306 bra $L102; bra $L103; $L134: .loc 1 252 0 sub.u64 %r308,%r51,%r224; max.u64 %r307,%r308,%r224; add.u64 %r309,%r307,1; st.u64 [%frame],%r309; .loc 1 253 0 mov.u64 %r113,0; .loc 1 264 0 add.u64 %r396,%r224,-1; .loc 1 265 0 setp.eq.u64 %r397,%r396,-1; bra $L104; $L108: .loc 1 260 0 add.u64 %r105,%r105,1; add.u64 %r156,%r156,1; add.u64 %r154,%r154,1; .loc 1 258 0 setp.eq.u64 %r310,%r51,%r105; @ %r310 bra $L105; $L116: ld.u8 %r120,[%r156]; cvt.u32.u32 %r312,%r120; cvt.u64.u8 %r311,%r312; add.u64 %r313,%r107,%r311; ld.u8 %r398,[%r313+1]; mov.u16 %r317,%r398; and.b16 %r316,%r317,3; cvt.u32.u16 %r320,%r316; cvt.s32.s8 %r319,%r320; cvt.u16.u32 %r318,%r319; setp.ne.u16 %r321,%r318,1; @ %r321 bra $L106; add.u32 %r120,%r120,32; $L106: .loc 1 259 0 ld.u8 %r121,[%r154]; cvt.u32.u32 %r323,%r121; cvt.u64.u8 %r322,%r323; add.u64 %r324,%r107,%r322; ld.u8 %r398,[%r324+1]; mov.u16 %r328,%r398; and.b16 %r327,%r328,3; cvt.u32.u16 %r331,%r327; cvt.s32.s8 %r330,%r331; cvt.u16.u32 %r329,%r330; setp.ne.u16 %r332,%r329,1; @ %r332 bra $L107; add.u32 %r121,%r121,32; $L107: .loc 1 258 0 setp.eq.u32 %r333,%r120,%r121; @ %r333 bra $L108; .loc 1 261 0 setp.gt.u64 %r334,%r51,%r105; @ %r334 bra $L109; $L105: .loc 1 265 0 @ %r397 bra $L110; ld.global.u64 %r124,[__ctype_ptr__]; add.u64 %r165,%r183,%r396; add.u64 %r336,%r224,%r113; add.u64 %r163,%r182,%r336; not.b64 %r394,%r182; sub.u64 %r395,%r394,%r113; bra $L111; $L114: add.u64 %r165,%r165,-1; add.u64 %r163,%r163,-1; add.u64 %r339,%r395,%r163; setp.eq.u64 %r340,%r339,-1; @ %r340 bra $L110; $L111: ld.u8 %r137,[%r165]; cvt.u32.u32 %r342,%r137; cvt.u64.u8 %r341,%r342; add.u64 %r343,%r124,%r341; ld.u8 %r398,[%r343+1]; mov.u16 %r347,%r398; and.b16 %r346,%r347,3; cvt.u32.u16 %r350,%r346; cvt.s32.s8 %r349,%r350; cvt.u16.u32 %r348,%r349; setp.ne.u16 %r351,%r348,1; @ %r351 bra $L112; add.u32 %r137,%r137,32; $L112: .loc 1 266 0 ld.u8 %r138,[%r163]; cvt.u32.u32 %r353,%r138; cvt.u64.u8 %r352,%r353; add.u64 %r354,%r124,%r352; ld.u8 %r398,[%r354+1]; mov.u16 %r358,%r398; and.b16 %r357,%r358,3; cvt.u32.u16 %r361,%r357; cvt.s32.s8 %r360,%r361; cvt.u16.u32 %r359,%r360; setp.ne.u16 %r362,%r359,1; @ %r362 bra $L113; add.u32 %r138,%r138,32; $L113: .loc 1 265 0 setp.eq.u32 %r363,%r137,%r138; @ %r363 bra $L114; bra $L135; $L109: sub.u64 %r364,%r113,%r224; add.u64 %r22,%r364,1; .loc 1 273 0 add.u64 %r113,%r22,%r105; $L117: .loc 1 258 0 mov.u64 %r53,%r141; $L104: .loc 1 254 0 add.u64 %r141,%r51,%r113; sub.u64 %r369,%r141,%r53; add.u64 %r370,%r52,%r53; mov.u32 %r367,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r370; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r367; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r369; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r371,[%value_in]; } set.u32.ne.u64 %r373,%r141,0; neg.s32 %r374,%r373; set.u32.eq.u64 %r376,%r371,0; neg.s32 %r377,%r376; cvt.u16.u32 %r379,%r374; cvt.u16.u32 %r380,%r377; and.b16 %r378,%r379,%r380; cvt.u32.u16 %r381,%r378; cvt.u16.u8 %r382,%r381; setp.eq.u16 %r383,%r382,0; @ %r383 bra $L103; .loc 1 258 0 setp.le.u64 %r384,%r51,%r224; @ %r384 bra $L105; ld.global.u64 %r107,[__ctype_ptr__]; add.u64 %r156,%r183,%r224; add.u64 %r385,%r224,%r113; add.u64 %r154,%r52,%r385; mov.u64 %r105,%r224; bra $L116; $L103: .loc 1 276 0 mov.u64 %r181,0; .loc 2 146 0 bra $L77; $L85: .loc 2 149 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r52; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r53; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r183; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r51; call (%value_in),two_way_long_needle,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r390,[%value_in]; } mov.u64 %r181,%r390; bra $L77; $L118: .loc 2 133 0 mov.u64 %r181,%r182; bra $L77; $L120: .loc 2 137 0 mov.u64 %r181,0; bra $L77; $L121: mov.u64 %r181,%r182; bra $L77; $L110: .loc 1 269 0 add.u64 %r181,%r52,%r113; bra $L77; $L135: .loc 1 270 0 ld.u64 %r392,[%frame]; add.u64 %r113,%r113,%r392; bra $L117; $L77: .loc 2 152 0 mov.u64 %value,%r181; st.param.u64 [%value_out],%value; ret; } lib_a-strcat.o/ 0 0 0 644 2235 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcat .visible .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strcat.c" // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strcat .visible .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r78; .reg .u64 %r84; .reg .u64 %r86; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .pred %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .pred %r100; .reg .u16 %r101; .reg .u32 %r102; .reg .pred %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .u32 %r110; .reg .pred %r111; .reg .u64 %r114; mov.u64 %r92,%ar0; mov.u64 %r93,%ar1; .loc 1 81 0 and.b64 %r94,%r92,7; setp.ne.u64 %r95,%r94,0; @ %r95 bra $L6; .loc 1 84 0 ld.u64 %r86,[%r92]; add.u64 %r96,%r86,-72340172838076673; not.b64 %r97,%r86; and.b64 %r98,%r96,%r97; and.b64 %r99,%r98,-9187201950435737472; setp.eq.u64 %r100,%r99,0; @ %r100 bra $L7; mov.u64 %r84,%r92; bra $L2; $L6: mov.u64 %r84,%r92; $L2: .loc 1 90 0 ld.s8 %r102,[%r84]; cvt.u16.u32 %r101,%r102; setp.ne.u16 %r103,%r101,0; @ %r103 bra $L4; bra $L5; $L7: .loc 1 84 0 mov.u64 %r84,%r92; $L3: .loc 1 85 0 add.u64 %r84,%r84,8; .loc 1 84 0 ld.u64 %r78,[%r84]; add.u64 %r104,%r78,-72340172838076673; not.b64 %r105,%r78; and.b64 %r106,%r104,%r105; and.b64 %r107,%r106,-9187201950435737472; setp.eq.u64 %r108,%r107,0; @ %r108 bra $L3; bra $L2; $L4: .loc 1 91 0 add.u64 %r84,%r84,1; .loc 1 90 0 ld.s8 %r110,[%r84]; cvt.u16.u32 %r109,%r110; setp.ne.u16 %r111,%r109,0; @ %r111 bra $L4; $L5: .loc 1 100 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r84; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r93; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r114,[%value_in]; } .loc 1 104 0 mov.u64 %value,%r92; st.param.u64 [%value_out],%value; ret; } lib_a-strchr.o/ 0 0 0 644 5616 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strchr .visible .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/string/strchr.c" // BEGIN GLOBAL FUNCTION DEF: strchr .visible .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r93; .reg .u32 %r98; .reg .u32 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u32 %r115; .reg .u32 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .pred %r133; .reg .pred %r134; .reg .u16 %r135; .reg .u16 %r136; .reg .pred %r137; .reg .pred %r138; .reg .u16 %r139; .reg .pred %r140; .reg .u16 %r141; .reg .pred %r142; .reg .u64 %r143; .reg .pred %r144; .reg .u64 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u64 %r148; .reg .pred %r149; .reg .u64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u64 %r153; .reg .pred %r154; .reg .u16 %r155; .reg .pred %r156; .reg .u16 %r157; .reg .pred %r158; .reg .pred %r159; .reg .u16 %r160; .reg .pred %r162; .reg .u64 %r163; .reg .pred %r164; .reg .u64 %r166; .reg .u64 %r167; .reg .u64 %r168; .reg .u64 %r169; .reg .u64 %r170; .reg .u64 %r171; .reg .u64 %r172; .reg .u64 %r173; .reg .pred %r174; .reg .u64 %r175; .reg .u64 %r176; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .pred %r183; .reg .pred %r184; .reg .u16 %r185; .reg .u16 %r186; .reg .pred %r187; .reg .pred %r188; .reg .u16 %r189; .reg .pred %r191; .reg .u16 %r193; .reg .u16 %r194; mov.u64 %r129,%ar0; mov.u32 %r130,%ar1; .loc 1 66 0 cvt.u32.u32 %r131,%r130; cvt.u32.u8 %r102,%r131; and.b64 %r127,%r129,7; .loc 1 73 0 setp.eq.u32 %r132,%r102,0; @ %r132 bra $L2; .loc 1 93 0 setp.eq.u64 %r133,%r127,0; @ %r133 bra $L3; .loc 1 95 0 ld.u8 %r121,[%r129]; setp.eq.u32 %r134,%r121,0; @ %r134 bra $L16; .loc 1 97 0 cvt.u16.u32 %r135,%r102; cvt.u16.u32 %r136,%r121; setp.eq.u16 %r137,%r135,%r136; @ %r137 bra $L17; cvt.u16.u32 %r194,%r102; bra $L5; $L2: .loc 1 75 0 setp.eq.u64 %r138,%r127,0; @ %r138 bra $L6; .loc 1 77 0 ld.u8 %r139,[%r129]; setp.eq.u16 %r140,%r139,0; @ ! %r140 bra $L7; bra $L18; $L8: ld.u8 %r141,[%r129]; setp.eq.u16 %r142,%r141,0; @ %r142 bra $L19; $L7: .loc 1 79 0 add.u64 %r129,%r129,1; .loc 1 75 0 and.b64 %r143,%r129,7; setp.ne.u64 %r144,%r143,0; @ %r144 bra $L8; $L6: .loc 1 83 0 ld.u64 %r106,[%r129]; not.b64 %r145,%r106; add.u64 %r146,%r106,-72340172838076673; and.b64 %r147,%r145,%r146; and.b64 %r148,%r147,-9187201950435737472; setp.ne.u64 %r149,%r148,0; @ %r149 bra $L9; $L10: .loc 1 84 0 add.u64 %r129,%r129,8; .loc 1 83 0 ld.u64 %r79,[%r129]; add.u64 %r150,%r79,-72340172838076673; not.b64 %r151,%r79; and.b64 %r152,%r150,%r151; and.b64 %r153,%r152,-9187201950435737472; setp.eq.u64 %r154,%r153,0; @ %r154 bra $L10; $L9: .loc 1 87 0 ld.u8 %r155,[%r129]; setp.eq.u16 %r156,%r155,0; @ %r156 bra $L20; $L11: .loc 1 88 0 add.u64 %r129,%r129,1; .loc 1 87 0 ld.u8 %r157,[%r129]; setp.ne.u16 %r158,%r157,0; @ %r158 bra $L11; .loc 1 88 0 mov.u64 %r128,%r129; bra $L1; $L12: .loc 1 95 0 ld.u8 %r85,[%r129]; setp.eq.u32 %r159,%r85,0; @ %r159 bra $L21; .loc 1 97 0 cvt.u16.u32 %r160,%r85; setp.eq.u16 %r162,%r160,%r194; @ %r162 bra $L22; $L5: .loc 1 99 0 add.u64 %r129,%r129,1; .loc 1 93 0 and.b64 %r163,%r129,7; setp.ne.u64 %r164,%r163,0; @ %r164 bra $L12; $L3: .loc 1 102 0 cvt.u64.u8 %r103,%r131; .loc 1 104 0 shl.b64 %r125,%r103,8; or.b64 %r124,%r103,%r125; shl.b64 %r123,%r124,16; or.b64 %r122,%r123,%r124; shl.b64 %r88,%r122,32; or.b64 %r104,%r88,%r122; .loc 1 107 0 ld.u64 %r108,[%r129]; xor.b64 %r107,%r104,%r108; not.b64 %r166,%r107; add.u64 %r167,%r107,-72340172838076673; and.b64 %r168,%r166,%r167; add.u64 %r169,%r108,-72340172838076673; not.b64 %r170,%r108; and.b64 %r171,%r169,%r170; or.b64 %r172,%r168,%r171; and.b64 %r173,%r172,-9187201950435737472; setp.ne.u64 %r174,%r173,0; @ %r174 bra $L13; $L14: .loc 1 108 0 add.u64 %r129,%r129,8; .loc 1 107 0 ld.u64 %r89,[%r129]; xor.b64 %r93,%r89,%r104; add.u64 %r175,%r89,-72340172838076673; not.b64 %r176,%r89; and.b64 %r177,%r175,%r176; add.u64 %r178,%r93,-72340172838076673; not.b64 %r179,%r93; and.b64 %r180,%r178,%r179; or.b64 %r181,%r177,%r180; and.b64 %r182,%r181,-9187201950435737472; setp.eq.u64 %r183,%r182,0; @ %r183 bra $L14; $L13: .loc 1 118 0 ld.u8 %r115,[%r129]; setp.eq.u32 %r184,%r115,0; @ %r184 bra $L23; cvt.u16.u32 %r185,%r102; cvt.u16.u32 %r186,%r115; setp.eq.u16 %r187,%r185,%r186; @ %r187 bra $L24; cvt.u16.u32 %r193,%r102; $L15: .loc 1 119 0 add.u64 %r129,%r129,1; .loc 1 118 0 ld.u8 %r98,[%r129]; setp.eq.u32 %r188,%r98,0; @ %r188 bra $L25; cvt.u16.u32 %r189,%r98; setp.ne.u16 %r191,%r189,%r193; @ %r191 bra $L15; .loc 1 119 0 mov.u64 %r128,%r129; bra $L1; $L16: .loc 1 96 0 mov.u64 %r128,0; bra $L1; $L17: .loc 1 97 0 mov.u64 %r128,%r129; bra $L1; $L18: .loc 1 77 0 mov.u64 %r128,%r129; bra $L1; $L19: .loc 1 79 0 mov.u64 %r128,%r129; bra $L1; $L20: .loc 1 87 0 mov.u64 %r128,%r129; bra $L1; $L21: .loc 1 96 0 mov.u64 %r128,0; bra $L1; $L22: .loc 1 99 0 mov.u64 %r128,%r129; bra $L1; $L23: .loc 1 96 0 mov.u64 %r128,0; bra $L1; $L24: .loc 1 118 0 mov.u64 %r128,%r129; bra $L1; $L25: .loc 1 96 0 mov.u64 %r128,0; $L1: .loc 1 123 0 mov.u64 %value,%r128; st.param.u64 [%value_out],%value; ret; } /618 0 0 0 644 1431 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strchrnul .visible .func (.param .u64 %value_out) strchrnul (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/string/strchrnul.c" // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: strchrnul .visible .func (.param .u64 %value_out) strchrnul (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r25; .reg .u64 %r28; .reg .pred %r29; .reg .u64 %r31; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; .loc 1 44 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } mov.u64 %r23,%r28; .loc 1 46 0 setp.ne.u64 %r29,%r23,0; @ %r29 bra $L1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } add.u64 %r23,%r24,%r31; $L1: .loc 1 47 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-strcmp.o/ 0 0 0 644 2833 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcmp .visible .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strcmp.c" // BEGIN GLOBAL FUNCTION DEF: strcmp .visible .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r84; .reg .u32 %r86; .reg .u32 %r90; .reg .u32 %r95; .reg .u64 %r96; .reg .u32 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .pred %r106; .reg .u64 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .pred %r113; .reg .pred %r114; .reg .u16 %r115; .reg .u32 %r116; .reg .u16 %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .pred %r124; .reg .u64 %r125; .reg .pred %r126; .reg .pred %r127; .reg .u16 %r128; .reg .u32 %r129; .reg .u16 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .u32 %r133; mov.u64 %r102,%ar0; mov.u64 %r103,%ar1; .loc 1 78 0 or.b64 %r104,%r102,%r103; and.b64 %r105,%r104,7; setp.ne.u64 %r106,%r105,0; @ %r106 bra $L2; .loc 1 83 0 ld.u64 %r96,[%r103]; ld.u64 %r107,[%r102]; setp.ne.u64 %r108,%r96,%r107; @ %r108 bra $L2; .loc 1 87 0 add.u64 %r109,%r96,-72340172838076673; not.b64 %r110,%r96; and.b64 %r111,%r109,%r110; and.b64 %r112,%r111,-9187201950435737472; setp.ne.u64 %r113,%r112,0; @ ! %r113 bra $L4; bra $L8; $L2: .loc 1 99 0 ld.s8 %r95,[%r102]; setp.eq.u32 %r114,%r95,0; @ %r114 bra $L9; ld.s8 %r116,[%r103]; cvt.u16.u32 %r115,%r116; cvt.u16.u32 %r117,%r95; setp.eq.u16 %r118,%r115,%r117; @ %r118 bra $L6; cvt.u32.u32 %r119,%r95; cvt.u32.u8 %r90,%r119; bra $L5; $L7: .loc 1 87 0 add.u64 %r120,%r84,-72340172838076673; not.b64 %r121,%r84; and.b64 %r122,%r120,%r121; and.b64 %r123,%r122,-9187201950435737472; setp.ne.u64 %r124,%r123,0; @ %r124 bra $L10; $L4: .loc 1 90 0 add.u64 %r102,%r102,8; .loc 1 91 0 add.u64 %r103,%r103,8; .loc 1 83 0 ld.u64 %r84,[%r102]; ld.u64 %r125,[%r103]; setp.eq.u64 %r126,%r84,%r125; @ %r126 bra $L7; bra $L2; $L6: .loc 1 101 0 add.u64 %r102,%r102,1; .loc 1 102 0 add.u64 %r103,%r103,1; .loc 1 99 0 ld.s8 %r86,[%r102]; setp.eq.u32 %r127,%r86,0; @ %r127 bra $L11; ld.s8 %r129,[%r103]; cvt.u16.u32 %r128,%r129; cvt.u16.u32 %r130,%r86; setp.eq.u16 %r131,%r128,%r130; @ %r131 bra $L6; cvt.u32.u32 %r132,%r86; cvt.u32.u8 %r90,%r132; bra $L5; $L9: mov.u32 %r90,%r95; bra $L5; $L11: mov.u32 %r90,%r86; $L5: .loc 1 104 0 ld.u8 %r133,[%r103]; sub.u32 %r101,%r90,%r133; bra $L1; $L8: .loc 1 88 0 cvt.u32.u64 %r101,%r105; bra $L1; $L10: mov.u32 %r101,0; $L1: .loc 1 106 0 mov.u32 %value,%r101; st.param.u32 [%value_out],%value; ret; } lib_a-strcoll.o/0 0 0 644 1015 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcoll .visible .func (.param .u32 %value_out) strcoll (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strcoll.c" // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strcoll .visible .func (.param .u32 %value_out) strcoll (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r27; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r27,[%value_in]; } .loc 1 48 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } lib_a-strcpy.o/ 0 0 0 644 1934 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcpy .visible .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strcpy.c" // BEGIN GLOBAL FUNCTION DEF: strcpy .visible .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r96; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .pred %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .pred %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .pred %r114; .reg .u32 %r115; .reg .pred %r116; mov.u64 %r100,%ar0; mov.u64 %r101,%ar1; .loc 1 79 0 mov.u64 %r96,%r100; or.b64 %r102,%r101,%r100; and.b64 %r103,%r102,7; setp.eq.u64 %r104,%r103,0; @ %r104 bra $L2; .loc 1 73 0 mov.u64 %r88,%r100; bra $L4; $L6: mov.u64 %r88,%r100; $L4: mov.u64 %r87,%r88; mov.u64 %r86,%r101; bra $L3; $L2: .loc 1 86 0 ld.u64 %r79,[%r101]; add.u64 %r105,%r79,-72340172838076673; not.b64 %r106,%r79; and.b64 %r107,%r105,%r106; and.b64 %r108,%r107,-9187201950435737472; setp.ne.u64 %r109,%r108,0; @ %r109 bra $L6; $L5: .loc 1 88 0 add.u64 %r101,%r101,8; add.u64 %r88,%r96,8; st.u64 [%r96],%r79; .loc 1 86 0 ld.u64 %r79,[%r101]; mov.u64 %r96,%r88; add.u64 %r110,%r79,-72340172838076673; not.b64 %r111,%r79; and.b64 %r112,%r110,%r111; and.b64 %r113,%r112,-9187201950435737472; setp.eq.u64 %r114,%r113,0; @ %r114 bra $L5; bra $L4; $L3: .loc 1 95 0 ld.s8 %r85,[%r86]; cvt.u32.u32 %r115,%r85; st.u8 [%r87],%r115; add.u64 %r87,%r87,1; add.u64 %r86,%r86,1; setp.ne.u32 %r116,%r85,0; @ %r116 bra $L3; .loc 1 99 0 mov.u64 %value,%r100; st.param.u64 [%value_out],%value; ret; } lib_a-strcspn.o/0 0 0 644 1675 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcspn .visible .func (.param .u64 %value_out) strcspn (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strcspn.c" // BEGIN GLOBAL FUNCTION DEF: strcspn .visible .func (.param .u64 %value_out) strcspn (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u16 %r64; .reg .pred %r66; .reg .pred %r67; .reg .u16 %r70; .reg .pred %r71; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; mov.u64 %r61,%ar0; mov.u64 %r62,%ar1; .loc 1 41 0 ld.s8 %r51,[%r61]; mov.u64 %r59,%r61; setp.ne.u32 %r63,%r51,0; @ %r63 bra $L2; mov.u64 %r60,0; bra $L1; $L5: .loc 1 45 0 cvt.u16.u32 %r64,%r50; setp.ne.u16 %r66,%r64,%r75; @ %r66 bra $L4; sub.u64 %r60,%r61,%r59; bra $L1; $L8: mov.u64 %r52,%r62; cvt.u16.u32 %r75,%r51; $L4: .loc 1 43 0 add.u64 %r52,%r52,1; ld.s8 %r50,[%r52]; setp.ne.u32 %r67,%r50,0; @ %r67 bra $L5; bra $L6; $L2: ld.s8 %r49,[%r62]; setp.eq.u32 %r74,%r49,0; .loc 1 45 0 cvt.u16.u32 %r76,%r49; $L7: .loc 1 43 0 @ %r74 bra $L6; .loc 1 45 0 cvt.u16.u32 %r70,%r51; setp.ne.u16 %r71,%r76,%r70; @ %r71 bra $L8; sub.u64 %r60,%r61,%r59; .loc 1 53 0 bra $L1; $L6: .loc 1 50 0 add.u64 %r61,%r61,1; .loc 1 41 0 ld.s8 %r51,[%r61]; setp.ne.u32 %r73,%r51,0; @ %r73 bra $L7; sub.u64 %r60,%r61,%r59; $L1: .loc 1 54 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } lib_a-strdup.o/ 0 0 0 644 1031 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strdup .visible .func (.param .u64 %value_out) strdup (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/string/strdup.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strdup_r .extern .func (.param .u64 %value_out) _strdup_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strdup .visible .func (.param .u64 %value_out) strdup (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r27; .reg .u64 %r28; mov.u64 %r24,%ar0; .loc 1 10 0 ld.global.u64 %r27,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),_strdup_r,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } .loc 1 11 0 mov.u64 %value,%r28; st.param.u64 [%value_out],%value; ret; } /637 0 0 0 644 1883 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strdup_r .visible .func (.param .u64 %value_out) _strdup_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strdup_r.c" // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: _strdup_r .visible .func (.param .u64 %value_out) _strdup_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r28; .reg .u64 %r31; .reg .pred %r32; .reg .u64 %r36; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; .loc 1 10 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r28,[%value_in]; } add.u64 %r23,%r28,1; .loc 1 11 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r23; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r31,[%value_in]; } .loc 1 12 0 setp.eq.u64 %r32,%r31,0; @ %r32 bra $L1; .loc 1 14 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r23; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r36,[%value_in]; } $L1: .loc 1 17 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } /655 0 0 0 644 23230 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _strerror_r .visible .func (.param .u64 %value_out) _strerror_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/string/strerror.c" // BEGIN GLOBAL FUNCTION DECL: strerror .visible .func (.param .u64 %value_out) strerror (.param .u32 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _user_strerror .extern .func (.param .u64 %value_out) _user_strerror (.param .u32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[16] = {66,97,100,32,102,105,108,101,32,110,117,109,98,101,114,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[12] = {78,111,32,99,104,105,108,100,114,101,110,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[29] = {68,101,115,116,105,110,97,116,105,111,110,32,97,100,100,114,101,115,115,32,114,101,113,117,105,114,101,100,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[18] = {78,111,32,109,111,114,101,32,112,114,111,99,101,115,115,101,115,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[17] = {78,111,116,32,101,110,111,117,103,104,32,115,112,97,99,101,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[18] = {80,101,114,109,105,115,115,105,111,110,32,100,101,110,105,101,100,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[12] = {66,97,100,32,97,100,100,114,101,115,115,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[24] = {68,101,118,105,99,101,32,111,114,32,114,101,115,111,117,114,99,101,32,98,117,115,121,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[12] = {70,105,108,101,32,101,120,105,115,116,115,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[18] = {67,114,111,115,115,45,100,101,118,105,99,101,32,108,105,110,107,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[15] = {78,111,32,115,117,99,104,32,100,101,118,105,99,101,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[16] = {78,111,116,32,97,32,100,105,114,101,99,116,111,114,121,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[13] = {72,111,115,116,32,105,115,32,100,111,119,110,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[31] = {67,111,110,110,101,99,116,105,111,110,32,97,108,114,101,97,100,121,32,105,110,32,112,114,111,103,114,101,115,115,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[15] = {73,115,32,97,32,100,105,114,101,99,116,111,114,121,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[17] = {73,110,118,97,108,105,100,32,97,114,103,117,109,101,110,116,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[36] = {78,101,116,119,111,114,107,32,105,110,116,101,114,102,97,99,101,32,105,115,32,110,111,116,32,99,111,110,102,105,103,117,114,101,100,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[30] = {84,111,111,32,109,97,110,121,32,111,112,101,110,32,102,105,108,101,115,32,105,110,32,115,121,115,116,101,109,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[20] = {84,111,111,32,109,97,110,121,32,111,112,101,110,32,102,105,108,101,115,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[23] = {78,111,116,32,97,32,99,104,97,114,97,99,116,101,114,32,100,101,118,105,99,101,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[15] = {84,101,120,116,32,102,105,108,101,32,98,117,115,121,0 }; // BEGIN VAR DEF: $LC31 .const .align 1 .u8 $LC31[15] = {70,105,108,101,32,116,111,111,32,108,97,114,103,101,0 }; // BEGIN VAR DEF: $LC32 .const .align 1 .u8 $LC32[20] = {72,111,115,116,32,105,115,32,117,110,114,101,97,99,104,97,98,108,101,0 }; // BEGIN VAR DEF: $LC33 .const .align 1 .u8 $LC33[24] = {78,111,32,115,112,97,99,101,32,108,101,102,116,32,111,110,32,100,101,118,105,99,101,0 }; // BEGIN VAR DEF: $LC34 .const .align 1 .u8 $LC34[14] = {78,111,116,32,115,117,112,112,111,114,116,101,100,0 }; // BEGIN VAR DEF: $LC35 .const .align 1 .u8 $LC35[13] = {73,108,108,101,103,97,108,32,115,101,101,107,0 }; // BEGIN VAR DEF: $LC36 .const .align 1 .u8 $LC36[22] = {82,101,97,100,45,111,110,108,121,32,102,105,108,101,32,115,121,115,116,101,109,0 }; // BEGIN VAR DEF: $LC37 .const .align 1 .u8 $LC37[15] = {84,111,111,32,109,97,110,121,32,108,105,110,107,115,0 }; // BEGIN VAR DEF: $LC38 .const .align 1 .u8 $LC38[12] = {66,114,111,107,101,110,32,112,105,112,101,0 }; // BEGIN VAR DEF: $LC39 .const .align 1 .u8 $LC39[14] = {77,97,116,104,32,97,114,103,117,109,101,110,116,0 }; // BEGIN VAR DEF: $LC40 .const .align 1 .u8 $LC40[17] = {82,101,115,117,108,116,32,116,111,111,32,108,97,114,103,101,0 }; // BEGIN VAR DEF: $LC41 .const .align 1 .u8 $LC41[27] = {78,111,32,109,101,115,115,97,103,101,32,111,102,32,100,101,115,105,114,101,100,32,116,121,112,101,0 }; // BEGIN VAR DEF: $LC42 .const .align 1 .u8 $LC42[19] = {73,100,101,110,116,105,102,105,101,114,32,114,101,109,111,118,101,100,0 }; // BEGIN VAR DEF: $LC43 .const .align 1 .u8 $LC43[9] = {68,101,97,100,108,111,99,107,0 }; // BEGIN VAR DEF: $LC44 .const .align 1 .u8 $LC44[23] = {78,101,116,119,111,114,107,32,105,115,32,117,110,114,101,97,99,104,97,98,108,101,0 }; // BEGIN VAR DEF: $LC45 .const .align 1 .u8 $LC45[8] = {78,111,32,108,111,99,107,0 }; // BEGIN VAR DEF: $LC46 .const .align 1 .u8 $LC46[13] = {78,111,116,32,97,32,115,116,114,101,97,109,0 }; // BEGIN VAR DEF: $LC47 .const .align 1 .u8 $LC47[21] = {83,116,114,101,97,109,32,105,111,99,116,108,32,116,105,109,101,111,117,116,0 }; // BEGIN VAR DEF: $LC48 .const .align 1 .u8 $LC48[20] = {78,111,32,115,116,114,101,97,109,32,114,101,115,111,117,114,99,101,115,0 }; // BEGIN VAR DEF: $LC49 .const .align 1 .u8 $LC49[24] = {86,105,114,116,117,97,108,32,99,105,114,99,117,105,116,32,105,115,32,103,111,110,101,0 }; // BEGIN VAR DEF: $LC50 .const .align 1 .u8 $LC50[15] = {80,114,111,116,111,99,111,108,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC51 .const .align 1 .u8 $LC51[17] = {85,110,107,110,111,119,110,32,112,114,111,116,111,99,111,108,0 }; // BEGIN VAR DEF: $LC52 .const .align 1 .u8 $LC52[19] = {77,117,108,116,105,104,111,112,32,97,116,116,101,109,112,116,101,100,0 }; // BEGIN VAR DEF: $LC53 .const .align 1 .u8 $LC53[12] = {66,97,100,32,109,101,115,115,97,103,101,0 }; // BEGIN VAR DEF: $LC54 .const .align 1 .u8 $LC54[25] = {70,117,110,99,116,105,111,110,32,110,111,116,32,105,109,112,108,101,109,101,110,116,101,100,0 }; // BEGIN VAR DEF: $LC55 .const .align 1 .u8 $LC55[20] = {68,105,114,101,99,116,111,114,121,32,110,111,116,32,101,109,112,116,121,0 }; // BEGIN VAR DEF: $LC56 .const .align 1 .u8 $LC56[27] = {70,105,108,101,32,111,114,32,112,97,116,104,32,110,97,109,101,32,116,111,111,32,108,111,110,103,0 }; // BEGIN VAR DEF: $LC57 .const .align 1 .u8 $LC57[24] = {84,111,111,32,109,97,110,121,32,115,121,109,98,111,108,105,99,32,108,105,110,107,115,0 }; // BEGIN VAR DEF: $LC58 .const .align 1 .u8 $LC58[26] = {78,111,32,98,117,102,102,101,114,32,115,112,97,99,101,32,97,118,97,105,108,97,98,108,101,0 }; // BEGIN VAR DEF: $LC59 .const .align 1 .u8 $LC59[48] = {65,100,100,114,101,115,115,32,102,97,109,105,108,121,32,110,111,116,32,115,117,112,112,111,114,116,101,100,32,98,121,32,112,114,111,116,111,99,111,108,32,102,97,109,105,108,121,0 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {83,117,99,99,101,115,115,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[10] = {78,111,116,32,111,119,110,101,114,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[26] = {78,111,32,115,117,99,104,32,102,105,108,101,32,111,114,32,100,105,114,101,99,116,111,114,121,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[16] = {78,111,32,115,117,99,104,32,112,114,111,99,101,115,115,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[24] = {73,110,116,101,114,114,117,112,116,101,100,32,115,121,115,116,101,109,32,99,97,108,108,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[10] = {73,47,79,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[26] = {78,111,32,115,117,99,104,32,100,101,118,105,99,101,32,111,114,32,97,100,100,114,101,115,115,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[18] = {65,114,103,32,108,105,115,116,32,116,111,111,32,108,111,110,103,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[18] = {69,120,101,99,32,102,111,114,109,97,116,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[25] = {83,111,99,107,101,116,32,97,108,114,101,97,100,121,32,99,111,110,110,101,99,116,101,100,0 }; // BEGIN VAR DEF: $LC60 .const .align 1 .u8 $LC60[31] = {80,114,111,116,111,99,111,108,32,119,114,111,110,103,32,116,121,112,101,32,102,111,114,32,115,111,99,107,101,116,0 }; // BEGIN VAR DEF: $LC61 .const .align 1 .u8 $LC61[31] = {83,111,99,107,101,116,32,111,112,101,114,97,116,105,111,110,32,111,110,32,110,111,110,45,115,111,99,107,101,116,0 }; // BEGIN VAR DEF: $LC62 .const .align 1 .u8 $LC62[23] = {80,114,111,116,111,99,111,108,32,110,111,116,32,97,118,97,105,108,97,98,108,101,0 }; // BEGIN VAR DEF: $LC63 .const .align 1 .u8 $LC63[19] = {67,111,110,110,101,99,116,105,111,110,32,114,101,102,117,115,101,100,0 }; // BEGIN VAR DEF: $LC64 .const .align 1 .u8 $LC64[23] = {65,100,100,114,101,115,115,32,97,108,114,101,97,100,121,32,105,110,32,117,115,101,0 }; // BEGIN VAR DEF: $LC65 .const .align 1 .u8 $LC65[33] = {83,111,102,116,119,97,114,101,32,99,97,117,115,101,100,32,99,111,110,110,101,99,116,105,111,110,32,97,98,111,114,116,0 }; // BEGIN VAR DEF: $LC66 .const .align 1 .u8 $LC66[24] = {83,111,99,107,101,116,32,105,115,32,110,111,116,32,99,111,110,110,101,99,116,101,100,0 }; // BEGIN VAR DEF: $LC67 .const .align 1 .u8 $LC67[28] = {83,111,99,107,101,116,32,105,115,32,97,108,114,101,97,100,121,32,99,111,110,110,101,99,116,101,100,0 }; // BEGIN VAR DEF: $LC68 .const .align 1 .u8 $LC68[19] = {79,112,101,114,97,116,105,111,110,32,99,97,110,99,101,108,101,100,0 }; // BEGIN VAR DEF: $LC69 .const .align 1 .u8 $LC69[22] = {83,116,97,116,101,32,110,111,116,32,114,101,99,111,118,101,114,97,98,108,101,0 }; // BEGIN VAR DEF: $LC70 .const .align 1 .u8 $LC70[20] = {80,114,101,118,105,111,117,115,32,111,119,110,101,114,32,100,105,101,100,0 }; // BEGIN VAR DEF: $LC71 .const .align 1 .u8 $LC71[34] = {79,112,101,114,97,116,105,111,110,32,110,111,116,32,115,117,112,112,111,114,116,101,100,32,111,110,32,115,111,99,107,101,116,0 }; // BEGIN VAR DEF: $LC72 .const .align 1 .u8 $LC72[17] = {77,101,115,115,97,103,101,32,116,111,111,32,108,111,110,103,0 }; // BEGIN VAR DEF: $LC73 .const .align 1 .u8 $LC73[21] = {67,111,110,110,101,99,116,105,111,110,32,116,105,109,101,100,32,111,117,116,0 }; // BEGIN VAR DEF: $LC74 .const .align 1 .u8 $LC74[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: _strerror_r .visible .func (.param .u64 %value_out) _strerror_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r22; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; .reg .pred %r30; .reg .pred %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; .reg .pred %r35; .reg .pred %r36; .reg .pred %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .pred %r41; .reg .pred %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .pred %r57; .reg .pred %r58; .reg .pred %r59; .reg .pred %r60; .reg .pred %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .pred %r65; .reg .pred %r66; .reg .pred %r67; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .pred %r73; .reg .pred %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .pred %r84; .reg .pred %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .pred %r89; .reg .pred %r90; .reg .pred %r91; .reg .pred %r92; .reg .pred %r93; .reg .pred %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .pred %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .pred %r113; .reg .pred %r114; .reg .pred %r115; .reg .pred %r116; .reg .u64 %r120; .reg .pred %r121; mov.u64 %r23,%ar0; mov.u32 %r24,%ar1; mov.u32 %r25,%ar2; mov.u64 %r26,%ar3; .loc 1 365 0 setp.eq.u32 %r27,%r24,45; @ %r27 bra $L3; setp.gt.s32 %r28,%r24,45; @ %r28 bra $L4; setp.eq.u32 %r29,%r24,18; @ %r29 bra $L5; setp.gt.s32 %r30,%r24,18; @ %r30 bra $L6; setp.eq.u32 %r31,%r24,8; @ %r31 bra $L7; setp.gt.s32 %r32,%r24,8; @ %r32 bra $L8; setp.eq.u32 %r33,%r24,3; @ %r33 bra $L9; setp.gt.s32 %r34,%r24,3; @ %r34 bra $L10; setp.eq.u32 %r35,%r24,1; @ %r35 bra $L11; setp.gt.s32 %r36,%r24,1; @ %r36 bra $L12; setp.eq.u32 %r37,%r24,0; @ %r37 bra $L96; bra $L2; $L10: setp.eq.u32 %r38,%r24,5; @ %r38 bra $L14; setp.lt.s32 %r39,%r24,5; @ %r39 bra $L15; setp.eq.u32 %r40,%r24,6; @ %r40 bra $L16; setp.eq.u32 %r41,%r24,7; @ %r41 bra $L17; bra $L2; $L8: setp.eq.u32 %r42,%r24,12; @ %r42 bra $L18; setp.gt.s32 %r43,%r24,12; @ %r43 bra $L19; setp.eq.u32 %r44,%r24,10; @ %r44 bra $L20; setp.gt.s32 %r45,%r24,10; @ ! %r45 bra $L97; bra $L21; $L19: setp.eq.u32 %r46,%r24,14; @ %r46 bra $L23; setp.lt.s32 %r47,%r24,14; @ %r47 bra $L24; setp.eq.u32 %r48,%r24,16; @ %r48 bra $L25; setp.eq.u32 %r49,%r24,17; @ %r49 bra $L26; bra $L2; $L6: setp.eq.u32 %r50,%r24,27; @ %r50 bra $L27; setp.gt.s32 %r51,%r24,27; @ %r51 bra $L28; setp.eq.u32 %r52,%r24,22; @ %r52 bra $L29; setp.gt.s32 %r53,%r24,22; @ %r53 bra $L30; setp.eq.u32 %r54,%r24,20; @ %r54 bra $L31; setp.gt.s32 %r55,%r24,20; @ ! %r55 bra $L98; bra $L32; $L30: setp.eq.u32 %r56,%r24,24; @ %r56 bra $L34; setp.lt.s32 %r57,%r24,24; @ %r57 bra $L35; setp.eq.u32 %r58,%r24,25; @ %r58 bra $L36; setp.eq.u32 %r59,%r24,26; @ %r59 bra $L37; bra $L2; $L28: setp.eq.u32 %r60,%r24,32; @ %r60 bra $L38; setp.gt.s32 %r61,%r24,32; @ %r61 bra $L39; setp.eq.u32 %r62,%r24,29; @ %r62 bra $L40; setp.lt.s32 %r63,%r24,29; @ %r63 bra $L41; setp.eq.u32 %r64,%r24,30; @ %r64 bra $L42; setp.eq.u32 %r65,%r24,31; @ %r65 bra $L43; bra $L2; $L39: setp.eq.u32 %r66,%r24,34; @ %r66 bra $L44; setp.lt.s32 %r67,%r24,34; @ %r67 bra $L45; setp.eq.u32 %r68,%r24,35; @ %r68 bra $L46; setp.eq.u32 %r69,%r24,36; @ %r69 bra $L47; bra $L2; $L4: setp.eq.u32 %r70,%r24,111; @ %r70 bra $L48; setp.gt.s32 %r71,%r24,111; @ %r71 bra $L49; setp.eq.u32 %r72,%r24,88; @ %r72 bra $L50; setp.gt.s32 %r73,%r24,88; @ %r73 bra $L51; setp.eq.u32 %r74,%r24,63; @ %r74 bra $L52; setp.gt.s32 %r75,%r24,63; @ %r75 bra $L53; setp.eq.u32 %r76,%r24,60; @ %r76 bra $L54; setp.eq.u32 %r77,%r24,62; @ %r77 bra $L55; setp.eq.u32 %r78,%r24,46; @ ! %r78 bra $L2; bra $L56; $L53: setp.eq.u32 %r79,%r24,71; @ %r79 bra $L57; setp.gt.s32 %r80,%r24,71; @ %r80 bra $L58; setp.eq.u32 %r81,%r24,67; @ %r81 bra $L59; bra $L2; $L58: setp.eq.u32 %r82,%r24,74; @ %r82 bra $L60; setp.eq.u32 %r83,%r24,77; @ %r83 bra $L61; bra $L2; $L51: setp.eq.u32 %r84,%r24,105; @ %r84 bra $L62; setp.gt.s32 %r85,%r24,105; @ %r85 bra $L63; setp.eq.u32 %r86,%r24,91; @ %r86 bra $L64; setp.gt.s32 %r87,%r24,91; @ %r87 bra $L65; setp.eq.u32 %r88,%r24,90; @ %r88 bra $L66; bra $L2; $L65: setp.eq.u32 %r89,%r24,92; @ %r89 bra $L67; setp.eq.u32 %r90,%r24,95; @ %r90 bra $L68; bra $L2; $L63: setp.eq.u32 %r91,%r24,107; @ %r91 bra $L69; setp.lt.s32 %r92,%r24,107; @ %r92 bra $L70; setp.eq.u32 %r93,%r24,108; @ %r93 bra $L71; setp.eq.u32 %r94,%r24,109; @ %r94 bra $L72; bra $L2; $L49: setp.eq.u32 %r95,%r24,120; @ %r95 bra $L73; setp.gt.s32 %r96,%r24,120; @ %r96 bra $L74; setp.eq.u32 %r97,%r24,115; @ %r97 bra $L75; setp.gt.s32 %r98,%r24,115; @ %r98 bra $L76; setp.eq.u32 %r99,%r24,113; @ %r99 bra $L77; setp.gt.s32 %r100,%r24,113; @ ! %r100 bra $L99; bra $L78; $L76: setp.eq.u32 %r101,%r24,117; @ %r101 bra $L80; setp.lt.s32 %r102,%r24,117; @ %r102 bra $L81; setp.eq.u32 %r103,%r24,118; @ %r103 bra $L82; setp.eq.u32 %r104,%r24,119; @ %r104 bra $L83; bra $L2; $L74: setp.eq.u32 %r105,%r24,128; @ %r105 bra $L84; setp.gt.s32 %r106,%r24,128; @ %r106 bra $L85; setp.eq.u32 %r107,%r24,122; @ %r107 bra $L86; setp.lt.s32 %r108,%r24,122; @ %r108 bra $L87; setp.eq.u32 %r109,%r24,123; @ %r109 bra $L88; setp.eq.u32 %r110,%r24,127; @ %r110 bra $L89; bra $L2; $L85: setp.eq.u32 %r111,%r24,140; @ %r111 bra $L90; setp.gt.s32 %r112,%r24,140; @ %r112 bra $L91; setp.eq.u32 %r113,%r24,134; @ %r113 bra $L92; bra $L2; $L91: setp.eq.u32 %r114,%r24,141; @ %r114 bra $L93; setp.eq.u32 %r115,%r24,142; @ %r115 bra $L94; bra $L2; $L11: .loc 1 373 0 cvta.const.u64 %r22,$LC1; bra $L1; $L12: .loc 1 378 0 cvta.const.u64 %r22,$LC2; .loc 1 379 0 bra $L1; $L9: .loc 1 383 0 cvta.const.u64 %r22,$LC3; .loc 1 384 0 bra $L1; $L15: .loc 1 388 0 cvta.const.u64 %r22,$LC4; .loc 1 389 0 bra $L1; $L14: .loc 1 393 0 cvta.const.u64 %r22,$LC5; .loc 1 394 0 bra $L1; $L16: .loc 1 399 0 cvta.const.u64 %r22,$LC6; .loc 1 400 0 bra $L1; $L17: .loc 1 404 0 cvta.const.u64 %r22,$LC7; .loc 1 405 0 bra $L1; $L7: .loc 1 409 0 cvta.const.u64 %r22,$LC8; .loc 1 410 0 bra $L1; $L73: .loc 1 414 0 cvta.const.u64 %r22,$LC9; .loc 1 415 0 bra $L1; $L97: .loc 1 419 0 cvta.const.u64 %r22,$LC10; .loc 1 420 0 bra $L1; $L20: .loc 1 424 0 cvta.const.u64 %r22,$LC11; .loc 1 425 0 bra $L1; $L87: .loc 1 429 0 cvta.const.u64 %r22,$LC12; .loc 1 430 0 bra $L1; $L21: .loc 1 434 0 cvta.const.u64 %r22,$LC13; .loc 1 435 0 bra $L1; $L18: .loc 1 439 0 cvta.const.u64 %r22,$LC14; .loc 1 440 0 bra $L1; $L24: .loc 1 444 0 cvta.const.u64 %r22,$LC15; .loc 1 445 0 bra $L1; $L23: .loc 1 449 0 cvta.const.u64 %r22,$LC16; .loc 1 450 0 bra $L1; $L25: .loc 1 459 0 cvta.const.u64 %r22,$LC17; .loc 1 460 0 bra $L1; $L26: .loc 1 464 0 cvta.const.u64 %r22,$LC18; .loc 1 465 0 bra $L1; $L5: .loc 1 469 0 cvta.const.u64 %r22,$LC19; .loc 1 470 0 bra $L1; $L98: .loc 1 474 0 cvta.const.u64 %r22,$LC20; .loc 1 475 0 bra $L1; $L31: .loc 1 479 0 cvta.const.u64 %r22,$LC21; .loc 1 480 0 bra $L1; $L80: .loc 1 484 0 cvta.const.u64 %r22,$LC22; .loc 1 485 0 bra $L1; $L83: .loc 1 489 0 cvta.const.u64 %r22,$LC23; .loc 1 490 0 bra $L1; $L32: .loc 1 494 0 cvta.const.u64 %r22,$LC24; .loc 1 495 0 bra $L1; $L29: .loc 1 499 0 cvta.const.u64 %r22,$LC25; .loc 1 500 0 bra $L1; $L75: .loc 1 504 0 cvta.const.u64 %r22,$LC26; .loc 1 505 0 bra $L1; $L35: .loc 1 509 0 cvta.const.u64 %r22,$LC27; .loc 1 510 0 bra $L1; $L34: .loc 1 514 0 cvta.const.u64 %r22,$LC28; .loc 1 515 0 bra $L1; $L36: .loc 1 519 0 cvta.const.u64 %r22,$LC29; .loc 1 520 0 bra $L1; $L37: .loc 1 524 0 cvta.const.u64 %r22,$LC30; .loc 1 525 0 bra $L1; $L27: .loc 1 529 0 cvta.const.u64 %r22,$LC31; .loc 1 530 0 bra $L1; $L82: .loc 1 534 0 cvta.const.u64 %r22,$LC32; .loc 1 535 0 bra $L1; $L41: .loc 1 539 0 cvta.const.u64 %r22,$LC33; .loc 1 540 0 bra $L1; $L92: .loc 1 544 0 cvta.const.u64 %r22,$LC34; .loc 1 545 0 bra $L1; $L40: .loc 1 549 0 cvta.const.u64 %r22,$LC35; .loc 1 550 0 bra $L1; $L42: .loc 1 554 0 cvta.const.u64 %r22,$LC36; .loc 1 555 0 bra $L1; $L43: .loc 1 559 0 cvta.const.u64 %r22,$LC37; .loc 1 560 0 bra $L1; $L38: .loc 1 564 0 cvta.const.u64 %r22,$LC38; .loc 1 565 0 bra $L1; $L45: .loc 1 569 0 cvta.const.u64 %r22,$LC39; .loc 1 570 0 bra $L1; $L44: .loc 1 574 0 cvta.const.u64 %r22,$LC40; .loc 1 575 0 bra $L1; $L46: .loc 1 579 0 cvta.const.u64 %r22,$LC41; .loc 1 580 0 bra $L1; $L47: .loc 1 584 0 cvta.const.u64 %r22,$LC42; .loc 1 585 0 bra $L1; $L3: .loc 1 589 0 cvta.const.u64 %r22,$LC43; .loc 1 590 0 bra $L1; $L78: .loc 1 594 0 cvta.const.u64 %r22,$LC44; .loc 1 595 0 bra $L1; $L56: .loc 1 599 0 cvta.const.u64 %r22,$LC45; .loc 1 600 0 bra $L1; $L54: .loc 1 604 0 cvta.const.u64 %r22,$LC46; .loc 1 605 0 bra $L1; $L55: .loc 1 609 0 cvta.const.u64 %r22,$LC47; .loc 1 610 0 bra $L1; $L52: .loc 1 614 0 cvta.const.u64 %r22,$LC48; .loc 1 615 0 bra $L1; $L59: .loc 1 634 0 cvta.const.u64 %r22,$LC49; .loc 1 635 0 bra $L1; $L57: .loc 1 654 0 cvta.const.u64 %r22,$LC50; .loc 1 655 0 bra $L1; $L88: .loc 1 659 0 cvta.const.u64 %r22,$LC51; .loc 1 660 0 bra $L1; $L60: .loc 1 664 0 cvta.const.u64 %r22,$LC52; .loc 1 665 0 bra $L1; $L61: .loc 1 669 0 cvta.const.u64 %r22,$LC53; .loc 1 670 0 bra $L1; $L50: .loc 1 699 0 cvta.const.u64 %r22,$LC54; .loc 1 700 0 bra $L1; $L66: .loc 1 709 0 cvta.const.u64 %r22,$LC55; .loc 1 710 0 bra $L1; $L64: .loc 1 714 0 cvta.const.u64 %r22,$LC56; .loc 1 715 0 bra $L1; $L67: .loc 1 719 0 cvta.const.u64 %r22,$LC57; .loc 1 720 0 bra $L1; $L62: .loc 1 724 0 cvta.const.u64 %r22,$LC58; .loc 1 725 0 bra $L1; $L70: .loc 1 729 0 cvta.const.u64 %r22,$LC59; .loc 1 730 0 bra $L1; $L69: .loc 1 734 0 cvta.const.u64 %r22,$LC60; .loc 1 735 0 bra $L1; $L71: .loc 1 739 0 cvta.const.u64 %r22,$LC61; .loc 1 740 0 bra $L1; $L72: .loc 1 744 0 cvta.const.u64 %r22,$LC62; .loc 1 745 0 bra $L1; $L48: .loc 1 754 0 cvta.const.u64 %r22,$LC63; .loc 1 755 0 bra $L1; $L99: .loc 1 759 0 cvta.const.u64 %r22,$LC64; .loc 1 760 0 bra $L1; $L77: .loc 1 764 0 cvta.const.u64 %r22,$LC65; .loc 1 765 0 bra $L1; $L84: .loc 1 774 0 cvta.const.u64 %r22,$LC66; .loc 1 775 0 bra $L1; $L89: .loc 1 784 0 cvta.const.u64 %r22,$LC67; .loc 1 785 0 bra $L1; $L90: .loc 1 789 0 cvta.const.u64 %r22,$LC68; .loc 1 790 0 bra $L1; $L93: .loc 1 794 0 cvta.const.u64 %r22,$LC69; .loc 1 795 0 bra $L1; $L94: .loc 1 799 0 cvta.const.u64 %r22,$LC70; .loc 1 800 0 bra $L1; $L68: .loc 1 809 0 cvta.const.u64 %r22,$LC71; .loc 1 810 0 bra $L1; $L86: .loc 1 814 0 cvta.const.u64 %r22,$LC72; .loc 1 815 0 bra $L1; $L81: .loc 1 819 0 cvta.const.u64 %r22,$LC73; .loc 1 820 0 bra $L1; $L2: .loc 1 823 0 setp.ne.u64 %r116,%r26,0; .loc 1 824 0 selp.u64 %r26,%r26,%r23,%r116; .loc 1 825 0 { .param .u64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; call (%value_in),_user_strerror,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r120,[%value_in]; } mov.u64 %r22,%r120; setp.ne.u64 %r121,%r22,0; @ %r121 bra $L1; .loc 1 826 0 cvta.const.u64 %r22,$LC74; bra $L1; $L96: .loc 1 368 0 cvta.const.u64 %r22,$LC0; $L1: .loc 1 831 0 mov.u64 %value,%r22; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strerror .visible .func (.param .u64 %value_out) strerror (.param .u32 %in_ar0) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r24; .reg .u32 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; mov.u32 %r24,%ar0; .loc 1 837 0 ld.global.u64 %r29,[_impure_ptr]; mov.u64 %r28,0; cvt.u32.u64 %r27,%r28; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r28; call (%value_in),_strerror_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 838 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } /673 0 0 0 644 2308 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strerror_r .visible .func (.param .u64 %value_out) strerror_r (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strerror_r.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strerror_r .extern .func (.param .u64 %value_out) _strerror_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strerror_r .visible .func (.param .u64 %value_out) strerror_r (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r35; .reg .pred %r36; .reg .u64 %r39; mov.u32 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; .loc 1 80 0 ld.global.u64 %r32,[_impure_ptr]; mov.u64 %r31,0; mov.u32 %r30,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r31; call (%value_in),_strerror_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r33,[%value_in]; } mov.u64 %r24,%r33; .loc 1 82 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r35,[%value_in]; } setp.ge.u64 %r36,%r35,%r27; @ %r36 bra $L1; .loc 1 84 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r39,[%value_in]; } mov.u64 %r24,%r39; $L1: .loc 1 85 0 mov.u64 %value,%r24; st.param.u64 [%value_out],%value; ret; } lib_a-strlcat.o/0 0 0 644 2527 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlcat .visible .func (.param .u64 %value_out) strlcat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strlcat.c" // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: strlcat .visible .func (.param .u64 %value_out) strlcat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r51; .reg .u64 %r54; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .u16 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r72; .reg .u16 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .u64 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; mov.u64 %r65,%ar0; mov.u64 %r66,%ar1; mov.u64 %r67,%ar2; mov.u64 %r62,%r65; .loc 1 56 0 setp.eq.u64 %r68,%r67,0; @ %r68 bra $L11; ld.s8 %r70,[%r65]; cvt.u16.u32 %r69,%r70; setp.eq.u16 %r71,%r69,0; @ %r71 bra $L12; add.u64 %r54,%r65,%r67; $L6: .loc 1 57 0 add.u64 %r65,%r65,1; .loc 1 56 0 setp.ne.u64 %r72,%r65,%r54; @ %r72 bra $L4; sub.u64 %r64,%r65,%r62; sub.u64 %r67,%r67,%r64; bra $L5; $L4: ld.s8 %r74,[%r65]; cvt.u16.u32 %r73,%r74; setp.ne.u16 %r75,%r73,0; @ %r75 bra $L6; sub.u64 %r64,%r65,%r62; sub.u64 %r67,%r67,%r64; $L5: .loc 1 61 0 setp.eq.u64 %r76,%r67,0; @ ! %r76 bra $L3; bra $L2; $L12: .loc 1 56 0 mov.u64 %r64,0; $L3: .loc 1 63 0 ld.s8 %r51,[%r66]; mov.u64 %r63,%r66; setp.ne.u32 %r77,%r51,0; @ %r77 bra $L7; bra $L8; $L11: .loc 1 56 0 mov.u64 %r64,%r67; $L2: .loc 1 62 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r66; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r79,[%value_in]; } add.u64 %r64,%r64,%r79; bra $L1; $L7: .loc 1 64 0 setp.eq.u64 %r80,%r67,1; @ %r80 bra $L10; .loc 1 65 0 cvt.u32.u32 %r81,%r51; st.u8 [%r65],%r81; .loc 1 66 0 add.u64 %r67,%r67,-1; .loc 1 65 0 add.u64 %r65,%r65,1; $L10: .loc 1 68 0 add.u64 %r66,%r66,1; .loc 1 63 0 ld.s8 %r51,[%r66]; setp.ne.u32 %r82,%r51,0; @ %r82 bra $L7; sub.u64 %r83,%r66,%r63; add.u64 %r64,%r64,%r83; $L8: .loc 1 70 0 mov.u32 %r84,0; st.u8 [%r65],%r84; $L1: .loc 1 73 0 mov.u64 %value,%r64; st.param.u64 [%value_out],%value; ret; } lib_a-strlcpy.o/0 0 0 644 1810 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlcpy .visible .func (.param .u64 %value_out) strlcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strlcpy.c" // BEGIN GLOBAL FUNCTION DEF: strlcpy .visible .func (.param .u64 %value_out) strlcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r49; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .pred %r69; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r72; .reg .u32 %r73; .reg .u16 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r78; mov.u64 %r65,%ar0; mov.u64 %r66,%ar1; mov.u64 %r67,%ar2; .loc 1 53 0 setp.eq.u64 %r68,%r67,0; @ %r68 bra $L7; add.u64 %r56,%r67,-1; setp.eq.u64 %r69,%r56,0; @ %r69 bra $L8; mov.u64 %r57,%r65; mov.u64 %r62,%r66; $L5: add.u64 %r55,%r62,1; add.u64 %r65,%r65,1; .loc 1 55 0 ld.s8 %r49,[%r62]; cvt.u32.u32 %r70,%r49; st.u8 [%r57],%r70; setp.eq.u32 %r71,%r49,0; @ %r71 bra $L4; .loc 1 57 0 add.u64 %r56,%r56,-1; mov.u64 %r57,%r65; mov.u64 %r62,%r55; setp.ne.u64 %r72,%r56,0; @ %r72 bra $L5; bra $L3; $L8: .loc 1 49 0 mov.u64 %r55,%r66; $L3: .loc 1 63 0 mov.u32 %r73,0; st.u8 [%r65],%r73; bra $L2; $L7: .loc 1 49 0 mov.u64 %r55,%r66; $L2: mov.u64 %r63,%r55; $L6: add.u64 %r63,%r63,1; mov.u64 %r55,%r63; .loc 1 64 0 ld.s8 %r75,[%r63+-1]; cvt.u16.u32 %r74,%r75; setp.ne.u16 %r76,%r74,0; @ %r76 bra $L6; $L4: .loc 1 68 0 sub.u64 %r78,%r55,%r66; add.u64 %value,%r78,-1; .loc 1 69 0 st.param.u64 [%value_out],%value; ret; } lib_a-strlen.o/ 0 0 0 644 2292 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlen .visible .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/string/strlen.c" // BEGIN GLOBAL FUNCTION DEF: strlen .visible .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r79; .reg .u64 %r87; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u16 %r103; .reg .u32 %r104; .reg .pred %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .pred %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .pred %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .pred %r120; .reg .u16 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .u16 %r124; .reg .u32 %r125; .reg .pred %r126; mov.u64 %r100,%ar0; mov.u64 %r98,%r100; .loc 1 66 0 and.b64 %r101,%r100,7; setp.eq.u64 %r102,%r101,0; @ %r102 bra $L2; .loc 1 68 0 ld.s8 %r104,[%r100]; cvt.u16.u32 %r103,%r104; setp.eq.u16 %r105,%r103,0; @ ! %r105 bra $L4; bra $L11; $L6: ld.s8 %r107,[%r100]; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L4; sub.u64 %r99,%r100,%r98; bra $L1; $L11: mov.u64 %r99,0; .loc 1 69 0 bra $L1; $L4: .loc 1 70 0 add.u64 %r100,%r100,1; .loc 1 66 0 and.b64 %r109,%r100,7; setp.ne.u64 %r110,%r109,0; @ %r110 bra $L6; $L2: .loc 1 76 0 ld.u64 %r87,[%r100]; add.u64 %r111,%r87,-72340172838076673; not.b64 %r112,%r87; and.b64 %r113,%r111,%r112; and.b64 %r114,%r113,-9187201950435737472; setp.ne.u64 %r115,%r114,0; @ %r115 bra $L7; $L8: .loc 1 77 0 add.u64 %r100,%r100,8; .loc 1 76 0 ld.u64 %r79,[%r100]; add.u64 %r116,%r79,-72340172838076673; not.b64 %r117,%r79; and.b64 %r118,%r116,%r117; and.b64 %r119,%r118,-9187201950435737472; setp.eq.u64 %r120,%r119,0; @ %r120 bra $L8; $L7: .loc 1 85 0 ld.s8 %r122,[%r100]; cvt.u16.u32 %r121,%r122; setp.eq.u16 %r123,%r121,0; @ %r123 bra $L9; $L10: .loc 1 86 0 add.u64 %r100,%r100,1; .loc 1 85 0 ld.s8 %r125,[%r100]; cvt.u16.u32 %r124,%r125; setp.ne.u16 %r126,%r124,0; @ %r126 bra $L10; $L9: .loc 1 87 0 sub.u64 %r99,%r100,%r98; $L1: .loc 1 88 0 mov.u64 %value,%r99; st.param.u64 [%value_out],%value; ret; } lib_a-strlwr.o/ 0 0 0 644 1412 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlwr .visible .func (.param .u64 %value_out) strlwr (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/string/strlwr.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strlwr .visible .func (.param .u64 %value_out) strlwr (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r58; .reg .u64 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u16 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r76; mov.u64 %r60,%ar0; .loc 1 41 0 ld.u8 %r55,[%r60]; setp.eq.u32 %r61,%r55,0; @ %r61 bra $L2; mov.u64 %r58,%r60; $L4: mov.u32 %r56,%r55; .loc 1 43 0 cvt.u32.u32 %r63,%r56; cvt.u64.u8 %r62,%r63; ld.global.u64 %r64,[__ctype_ptr__]; add.u64 %r65,%r64,%r62; ld.u8 %r76,[%r65+1]; mov.u16 %r69,%r76; and.b16 %r68,%r69,3; cvt.u32.u16 %r72,%r68; cvt.s32.s8 %r71,%r72; cvt.u16.u32 %r70,%r71; setp.ne.u16 %r73,%r70,1; @ %r73 bra $L3; add.u32 %r56,%r56,32; $L3: st.u8 [%r58],%r56; .loc 1 41 0 add.u64 %r58,%r58,1; ld.u8 %r55,[%r58]; setp.ne.u32 %r74,%r55,0; @ %r74 bra $L4; $L2: .loc 1 46 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } /693 0 0 0 644 2511 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncasecmp .visible .func (.param .u32 %value_out) strncasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strncasecmp.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strncasecmp .visible .func (.param .u32 %value_out) strncasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r49; .reg .u32 %r58; .reg .u32 %r62; .reg .u64 %r65; .reg .u64 %r67; .reg .u64 %r68; .reg .u32 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u16 %r80; .reg .u16 %r81; .reg .u16 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .u32 %r87; .reg .u64 %r88; .reg .u16 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .pred %r96; .reg .u32 %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .u16 %r103; mov.u64 %r71,%ar0; mov.u64 %r72,%ar1; mov.u64 %r73,%ar2; .loc 1 55 0 setp.eq.u64 %r74,%r73,0; @ %r74 bra $L7; .loc 1 57 0 ld.global.u64 %r49,[__ctype_ptr__]; mov.u64 %r68,%r71; mov.u64 %r67,%r72; add.u64 %r65,%r68,%r73; $L6: ld.u8 %r58,[%r68]; cvt.u32.u32 %r76,%r58; cvt.u64.u8 %r75,%r76; add.u64 %r77,%r49,%r75; ld.u8 %r103,[%r77+1]; mov.u16 %r81,%r103; and.b16 %r80,%r81,3; cvt.u32.u16 %r84,%r80; cvt.s32.s8 %r83,%r84; cvt.u16.u32 %r82,%r83; setp.ne.u16 %r85,%r82,1; @ %r85 bra $L3; add.u32 %r58,%r58,32; $L3: .loc 1 58 0 ld.u8 %r62,[%r67]; cvt.u32.u32 %r87,%r62; cvt.u64.u8 %r86,%r87; add.u64 %r88,%r49,%r86; ld.u8 %r103,[%r88+1]; mov.u16 %r92,%r103; and.b16 %r91,%r92,3; cvt.u32.u16 %r95,%r91; cvt.s32.s8 %r94,%r95; cvt.u16.u32 %r93,%r94; setp.ne.u16 %r96,%r93,1; @ %r96 bra $L4; add.u32 %r97,%r62,32; .loc 1 59 0 sub.u32 %r70,%r58,%r97; setp.ne.u32 %r98,%r70,0; @ ! %r98 bra $L5; bra $L1; $L4: sub.u32 %r70,%r58,%r62; setp.ne.u32 %r99,%r70,0; @ %r99 bra $L1; setp.eq.u32 %r100,%r62,0; @ %r100 bra $L1; $L5: add.u64 %r68,%r68,1; add.u64 %r67,%r67,1; .loc 1 55 0 setp.ne.u64 %r101,%r65,%r68; @ %r101 bra $L6; mov.u32 %r70,0; bra $L1; $L7: cvt.u32.u64 %r70,%r73; $L1: .loc 1 63 0 mov.u32 %value,%r70; st.param.u32 [%value_out],%value; ret; } lib_a-strncat.o/0 0 0 644 2647 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncat .visible .func (.param .u64 %value_out) strncat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strncat.c" // BEGIN GLOBAL FUNCTION DEF: strncat .visible .func (.param .u64 %value_out) strncat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r78; .reg .u64 %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r89; .reg .u64 %r91; .reg .u64 %r96; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .pred %r107; .reg .u16 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .pred %r115; .reg .u16 %r116; .reg .u32 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r120; .reg .pred %r121; .reg .u32 %r122; .reg .pred %r123; mov.u64 %r98,%ar0; mov.u64 %r99,%ar1; mov.u64 %r100,%ar2; .loc 1 89 0 and.b64 %r101,%r98,7; setp.ne.u64 %r102,%r101,0; @ %r102 bra $L11; .loc 1 92 0 ld.u64 %r85,[%r98]; not.b64 %r103,%r85; add.u64 %r104,%r85,-72340172838076673; and.b64 %r105,%r103,%r104; and.b64 %r106,%r105,-9187201950435737472; setp.eq.u64 %r107,%r106,0; @ %r107 bra $L12; mov.u64 %r89,%r98; bra $L2; $L11: mov.u64 %r89,%r98; $L2: .loc 1 98 0 ld.s8 %r109,[%r89]; cvt.u16.u32 %r108,%r109; setp.ne.u16 %r110,%r108,0; @ %r110 bra $L4; bra $L5; $L12: .loc 1 92 0 mov.u64 %r89,%r98; $L3: .loc 1 93 0 add.u64 %r89,%r89,8; .loc 1 92 0 ld.u64 %r78,[%r89]; add.u64 %r111,%r78,-72340172838076673; not.b64 %r112,%r78; and.b64 %r113,%r111,%r112; and.b64 %r114,%r113,-9187201950435737472; setp.eq.u64 %r115,%r114,0; @ %r115 bra $L3; bra $L2; $L4: .loc 1 99 0 add.u64 %r89,%r89,1; .loc 1 98 0 ld.s8 %r117,[%r89]; cvt.u16.u32 %r116,%r117; setp.ne.u16 %r118,%r116,0; @ %r118 bra $L4; bra $L5; $L9: add.u64 %r91,%r91,1; add.u64 %r84,%r84,1; .loc 1 109 0 setp.ne.u64 %r119,%r100,0; @ %r119 bra $L6; .loc 1 110 0 cvt.u32.u64 %r120,%r100; st.u8 [%r87+1],%r120; bra $L7; $L5: mov.u64 %r91,%r89; mov.u64 %r84,%r99; add.u64 %r96,%r91,%r100; $L6: mov.u64 %r87,%r91; .loc 1 107 0 add.u64 %r100,%r100,-1; setp.ne.u64 %r121,%r91,%r96; @ ! %r121 bra $L7; ld.s8 %r86,[%r84]; cvt.u32.u32 %r122,%r86; st.u8 [%r91],%r122; setp.ne.u32 %r123,%r86,0; @ %r123 bra $L9; $L7: .loc 1 115 0 mov.u64 %value,%r98; st.param.u64 [%value_out],%value; ret; } lib_a-strncmp.o/0 0 0 644 4213 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncmp .visible .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strncmp.c" // BEGIN GLOBAL FUNCTION DEF: strncmp .visible .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r84; .reg .u32 %r86; .reg .u64 %r92; .reg .u32 %r98; .reg .u64 %r101; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .pred %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .pred %r114; .reg .pred %r115; .reg .u64 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .pred %r123; .reg .pred %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u64 %r131; .reg .pred %r132; .reg .u16 %r133; .reg .u32 %r134; .reg .u16 %r135; .reg .pred %r136; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r142; .reg .u32 %r143; .reg .u16 %r144; .reg .u16 %r145; .reg .u16 %r146; .reg .u32 %r147; .reg .u16 %r148; .reg .pred %r149; .reg .u32 %r151; .reg .u32 %r152; .reg .u32 %r155; .reg .u32 %r156; .reg .u16 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u32 %r160; .reg .u16 %r161; .reg .pred %r162; .reg .u16 %r163; .reg .u32 %r164; .reg .u16 %r165; .reg .pred %r166; .reg .u32 %r167; .reg .u32 %r168; mov.u64 %r108,%ar0; mov.u64 %r109,%ar1; mov.u64 %r110,%ar2; .loc 1 84 0 setp.eq.u64 %r111,%r110,0; @ %r111 bra $L9; .loc 1 88 0 or.b64 %r112,%r108,%r109; and.b64 %r113,%r112,7; setp.ne.u64 %r114,%r113,0; @ %r114 bra $L3; .loc 1 93 0 setp.le.u64 %r115,%r110,7; @ %r115 bra $L3; ld.u64 %r101,[%r108]; ld.u64 %r116,[%r109]; setp.ne.u64 %r117,%r101,%r116; @ %r117 bra $L3; .loc 1 95 0 add.u64 %r110,%r110,-8; .loc 1 99 0 setp.eq.u64 %r118,%r110,0; @ %r118 bra $L10; add.u64 %r119,%r101,-72340172838076673; not.b64 %r120,%r101; and.b64 %r121,%r119,%r120; and.b64 %r122,%r121,-9187201950435737472; setp.ne.u64 %r123,%r122,0; @ ! %r123 bra $L4; bra $L11; $L5: .loc 1 95 0 add.u64 %r110,%r110,-8; .loc 1 99 0 setp.eq.u64 %r124,%r110,0; @ %r124 bra $L12; add.u64 %r125,%r84,-72340172838076673; not.b64 %r126,%r84; and.b64 %r127,%r125,%r126; and.b64 %r128,%r127,-9187201950435737472; setp.ne.u64 %r129,%r128,0; @ %r129 bra $L13; $L4: .loc 1 102 0 add.u64 %r108,%r108,8; .loc 1 103 0 add.u64 %r109,%r109,8; .loc 1 93 0 setp.le.u64 %r130,%r110,7; @ %r130 bra $L3; ld.u64 %r84,[%r108]; ld.u64 %r131,[%r109]; setp.eq.u64 %r132,%r84,%r131; @ %r132 bra $L5; $L3: .loc 1 111 0 add.u64 %r92,%r110,-1; ld.s8 %r98,[%r109]; ld.s8 %r134,[%r108]; cvt.u16.u32 %r133,%r134; cvt.u16.u32 %r135,%r98; setp.ne.u16 %r136,%r133,%r135; @ %r136 bra $L6; .loc 1 115 0 set.u32.eq.u16 %r139,%r133,0; neg.s32 %r140,%r139; set.u32.eq.u64 %r142,%r92,0; neg.s32 %r143,%r142; cvt.u16.u32 %r145,%r140; cvt.u16.u32 %r146,%r143; or.b16 %r144,%r145,%r146; cvt.u32.u16 %r147,%r144; cvt.u16.u8 %r148,%r147; setp.ne.u16 %r149,%r148,0; @ ! %r149 bra $L7; bra $L14; $L8: set.u32.eq.u64 %r151,%r92,0; neg.s32 %r152,%r151; set.u32.eq.u16 %r155,%r163,0; neg.s32 %r156,%r155; cvt.u16.u32 %r158,%r152; cvt.u16.u32 %r159,%r156; or.b16 %r157,%r158,%r159; cvt.u32.u16 %r160,%r157; cvt.u16.u8 %r161,%r160; setp.ne.u16 %r162,%r161,0; @ %r162 bra $L15; $L7: .loc 1 117 0 add.u64 %r108,%r108,1; .loc 1 118 0 add.u64 %r109,%r109,1; .loc 1 111 0 add.u64 %r92,%r92,-1; ld.s8 %r86,[%r108]; ld.s8 %r164,[%r109]; cvt.u16.u32 %r163,%r164; cvt.u16.u32 %r165,%r86; setp.eq.u16 %r166,%r163,%r165; @ %r166 bra $L8; $L6: .loc 1 120 0 ld.u8 %r167,[%r108]; ld.u8 %r168,[%r109]; sub.u32 %r107,%r167,%r168; bra $L1; $L9: .loc 1 85 0 cvt.u32.u64 %r107,%r110; bra $L1; $L10: cvt.u32.u64 %r107,%r110; bra $L1; $L11: cvt.u32.u64 %r107,%r113; bra $L1; $L12: cvt.u32.u64 %r107,%r110; bra $L1; $L13: mov.u32 %r107,0; bra $L1; $L14: mov.u32 %r107,0; bra $L1; $L15: mov.u32 %r107,0; $L1: .loc 1 122 0 mov.u32 %value,%r107; st.param.u32 [%value_out],%value; ret; } lib_a-strncpy.o/0 0 0 644 3161 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncpy .visible .func (.param .u64 %value_out) strncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strncpy.c" // BEGIN GLOBAL FUNCTION DEF: strncpy .visible .func (.param .u64 %value_out) strncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u32 %r95; .reg .u64 %r96; .reg .u64 %r100; .reg .u64 %r103; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r114; .reg .u32 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u16 %r118; .reg .u32 %r119; .reg .u16 %r120; .reg .pred %r121; .reg .pred %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .pred %r127; .reg .u32 %r128; .reg .pred %r129; .reg .pred %r130; .reg .pred %r131; .reg .pred %r132; .reg .u32 %r133; .reg .pred %r134; .reg .u32 %r135; .reg .pred %r136; mov.u64 %r105,%ar0; mov.u64 %r106,%ar1; mov.u64 %r107,%ar2; .loc 1 97 0 mov.u64 %r103,%r105; or.b64 %r108,%r106,%r105; and.b64 %r109,%r108,7; set.u32.eq.u64 %r111,%r109,0; neg.s32 %r112,%r111; set.u32.gt.u64 %r114,%r107,7; neg.s32 %r115,%r114; cvt.u16.u32 %r117,%r112; cvt.u16.u32 %r118,%r115; and.b16 %r116,%r117,%r118; cvt.u32.u16 %r119,%r116; cvt.u16.u8 %r120,%r119; setp.ne.u16 %r121,%r120,0; @ %r121 bra $L2; .loc 1 91 0 mov.u64 %r92,%r105; bra $L3; $L4: .loc 1 106 0 add.u64 %r107,%r107,-8; .loc 1 107 0 add.u64 %r106,%r106,8; add.u64 %r103,%r103,8; mov.u64 %r92,%r103; st.u64 [%r100],%r79; .loc 1 104 0 setp.le.u64 %r122,%r107,7; @ %r122 bra $L3; $L2: mov.u64 %r100,%r103; ld.u64 %r79,[%r106]; add.u64 %r123,%r79,-72340172838076673; not.b64 %r124,%r79; and.b64 %r125,%r123,%r124; and.b64 %r126,%r125,-9187201950435737472; setp.eq.u64 %r127,%r126,0; @ %r127 bra $L4; mov.u64 %r92,%r103; bra $L5; $L7: .loc 1 116 0 add.u64 %r90,%r90,-1; add.u64 %r93,%r93,1; .loc 1 117 0 ld.s8 %r85,[%r87]; cvt.u32.u32 %r128,%r85; st.u8 [%r86],%r128; add.u64 %r87,%r87,1; mov.u64 %r86,%r93; setp.eq.u32 %r129,%r85,0; @ %r129 bra $L6; $L10: .loc 1 114 0 setp.ne.u64 %r130,%r90,0; @ %r130 bra $L7; bra $L8; $L6: .loc 1 121 0 setp.ne.u64 %r131,%r90,0; @ %r131 bra $L9; bra $L8; $L3: .loc 1 114 0 setp.eq.u64 %r132,%r107,0; @ %r132 bra $L8; $L5: .loc 1 116 0 add.u64 %r90,%r107,-1; .loc 1 117 0 add.u64 %r96,%r106,1; add.u64 %r93,%r92,1; ld.s8 %r95,[%r106]; cvt.u32.u32 %r133,%r95; st.u8 [%r92],%r133; setp.eq.u32 %r134,%r95,0; @ %r134 bra $L6; mov.u64 %r87,%r96; mov.u64 %r86,%r93; bra $L10; $L9: mov.u64 %r91,%r93; add.u64 %r88,%r91,%r90; .loc 1 122 0 mov.u32 %r135,0; $L11: st.u8 [%r91],%r135; add.u64 %r91,%r91,1; .loc 1 121 0 setp.ne.u64 %r136,%r88,%r91; @ %r136 bra $L11; $L8: .loc 1 126 0 mov.u64 %value,%r105; st.param.u64 [%value_out],%value; ret; } lib_a-strndup.o/0 0 0 644 1246 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strndup .visible .func (.param .u64 %value_out) strndup (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strndup.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strndup_r .extern .func (.param .u64 %value_out) _strndup_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: strndup .visible .func (.param .u64 %value_out) strndup (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r29; .reg .u64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 13 0 ld.global.u64 %r29,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),_strndup_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r30,[%value_in]; } .loc 1 14 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } /714 0 0 0 644 2513 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strndup_r .visible .func (.param .u64 %value_out) _strndup_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strndup_r.c" // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: _strndup_r .visible .func (.param .u64 %value_out) _strndup_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r51; .reg .u64 %r53; .reg .u64 %r58; .reg .u64 %r61; .reg .u64 %r62; .reg .u64 %r63; .reg .pred %r64; .reg .u16 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .pred %r68; .reg .u16 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r74; .reg .pred %r75; .reg .u64 %r79; .reg .u64 %r80; .reg .u32 %r81; mov.u64 %r61,%ar0; mov.u64 %r62,%ar1; mov.u64 %r63,%ar2; .loc 1 15 0 setp.eq.u64 %r64,%r63,0; @ %r64 bra $L6; ld.s8 %r66,[%r62]; cvt.u16.u32 %r65,%r66; setp.eq.u16 %r67,%r65,0; @ %r67 bra $L7; add.u64 %r53,%r62,%r63; mov.u64 %r51,%r62; $L4: .loc 1 16 0 add.u64 %r51,%r51,1; .loc 1 15 0 setp.ne.u64 %r68,%r51,%r53; @ %r68 bra $L3; sub.u64 %r63,%r51,%r62; add.u64 %r58,%r63,1; bra $L2; $L3: ld.s8 %r70,[%r51]; cvt.u16.u32 %r69,%r70; setp.ne.u16 %r71,%r69,0; @ %r71 bra $L4; sub.u64 %r63,%r51,%r62; add.u64 %r58,%r63,1; bra $L2; $L6: mov.u64 %r58,1; bra $L2; $L7: mov.u64 %r63,0; mov.u64 %r58,1; $L2: .loc 1 20 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r61; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r58; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r74,[%value_in]; } .loc 1 21 0 setp.eq.u64 %r75,%r74,0; @ %r75 bra $L1; .loc 1 23 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r74; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r62; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r63; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r79,[%value_in]; } .loc 1 24 0 add.u64 %r80,%r74,%r63; mov.u32 %r81,0; st.u8 [%r80],%r81; $L1: .loc 1 27 0 mov.u64 %value,%r74; st.param.u64 [%value_out],%value; ret; } lib_a-strnlen.o/0 0 0 644 1312 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strnlen .visible .func (.param .u64 %value_out) strnlen (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strnlen.c" // BEGIN GLOBAL FUNCTION DEF: strnlen .visible .func (.param .u64 %value_out) strnlen (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r51; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .pred %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .pred %r64; .reg .u16 %r65; .reg .u32 %r66; .reg .pred %r67; mov.u64 %r58,%ar0; mov.u64 %r59,%ar1; mov.u64 %r56,%r58; .loc 1 45 0 setp.eq.u64 %r60,%r59,0; @ %r60 bra $L5; ld.s8 %r62,[%r58]; cvt.u16.u32 %r61,%r62; setp.eq.u16 %r63,%r61,0; @ %r63 bra $L6; add.u64 %r51,%r58,%r59; $L4: .loc 1 46 0 add.u64 %r58,%r58,1; .loc 1 45 0 setp.ne.u64 %r64,%r58,%r51; @ %r64 bra $L3; sub.u64 %r57,%r58,%r56; bra $L1; $L3: ld.s8 %r66,[%r58]; cvt.u16.u32 %r65,%r66; setp.ne.u16 %r67,%r65,0; @ %r67 bra $L4; sub.u64 %r57,%r58,%r56; bra $L1; $L5: mov.u64 %r57,%r59; bra $L1; $L6: mov.u64 %r57,0; $L1: .loc 1 49 0 mov.u64 %value,%r57; st.param.u64 [%value_out],%value; ret; } lib_a-strpbrk.o/0 0 0 644 1809 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strpbrk .visible .func (.param .u64 %value_out) strpbrk (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strpbrk.c" // BEGIN GLOBAL FUNCTION DEF: strpbrk .visible .func (.param .u64 %value_out) strpbrk (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u32 %r50; .reg .u64 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .pred %r57; .reg .u16 %r59; .reg .pred %r60; .reg .pred %r61; .reg .u16 %r63; .reg .pred %r65; .reg .u16 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r70; .reg .pred %r71; .reg .u16 %r72; .reg .u16 %r73; mov.u64 %r55,%ar0; mov.u64 %r56,%ar1; .loc 1 39 0 ld.s8 %r49,[%r55]; setp.eq.u32 %r57,%r49,0; @ ! %r57 bra $L13; bra $L9; $L4: .loc 1 46 0 cvt.u16.u32 %r59,%r50; setp.eq.u16 %r60,%r72,%r59; @ %r60 bra $L1; $L6: .loc 1 44 0 add.u64 %r52,%r52,1; ld.s8 %r50,[%r52]; setp.ne.u32 %r61,%r50,0; @ %r61 bra $L4; bra $L5; $L13: ld.s8 %r53,[%r56]; mov.u64 %r54,%r55; setp.eq.u32 %r71,%r53,0; .loc 1 46 0 cvt.u16.u32 %r73,%r53; $L7: .loc 1 44 0 @ %r71 bra $L10; .loc 1 46 0 cvt.u16.u32 %r63,%r49; setp.eq.u16 %r65,%r63,%r73; @ %r65 bra $L1; mov.u64 %r52,%r56; cvt.u16.u32 %r72,%r49; bra $L6; $L14: .loc 1 54 0 ld.s8 %r67,[%r52]; cvt.u16.u32 %r66,%r67; setp.eq.u16 %r68,%r66,0; .loc 1 55 0 selp.u64 %r54,0,%r54,%r68; bra $L1; $L9: mov.u64 %r54,0; bra $L1; $L10: .loc 1 44 0 mov.u64 %r52,%r56; $L5: .loc 1 51 0 add.u64 %r54,%r54,1; .loc 1 42 0 ld.s8 %r49,[%r54]; setp.ne.u32 %r70,%r49,0; @ %r70 bra $L7; bra $L14; $L1: .loc 1 58 0 mov.u64 %value,%r54; st.param.u64 [%value_out],%value; ret; } lib_a-strrchr.o/0 0 0 644 1551 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strrchr .visible .func (.param .u64 %value_out) strrchr (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/string/strrchr.c" // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strrchr .visible .func (.param .u64 %value_out) strrchr (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r25; .reg .pred %r26; .reg .u64 %r29; .reg .pred %r30; .reg .u64 %r33; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; .loc 1 45 0 setp.ne.u32 %r26,%r25,0; @ %r26 bra $L6; bra $L7; $L4: .loc 1 50 0 add.u64 %r24,%r29,1; mov.u64 %r23,%r29; bra $L2; $L6: .loc 1 43 0 mov.u64 %r23,0; $L2: .loc 1 47 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r29,[%value_in]; } setp.ne.u64 %r30,%r29,0; @ %r30 bra $L4; bra $L1; $L7: .loc 1 55 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r33,[%value_in]; } mov.u64 %r23,%r33; $L1: .loc 1 59 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-strsep.o/ 0 0 0 644 1260 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strsep .visible .func (.param .u64 %value_out) strsep (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strsep.c" // BEGIN GLOBAL FUNCTION DECL: __strtok_r .extern .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strsep .visible .func (.param .u64 %value_out) strsep (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u32 %r29; .reg .u64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 18 0 mov.u32 %r29,0; ld.u64 %r26,[%r24]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r24; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r29; call (%value_in),__strtok_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 19 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } /733 0 0 0 644 8971 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: strsignal .visible .func (.param .u64 %value_out) strsignal (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/string/strsignal.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: siprintf .extern .func (.param .u32 %value_out) siprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {72,97,110,103,117,112,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[10] = {73,110,116,101,114,114,117,112,116,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[5] = {81,117,105,116,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[20] = {73,108,108,101,103,97,108,32,105,110,115,116,114,117,99,116,105,111,110,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[22] = {84,114,97,99,101,47,98,114,101,97,107,112,111,105,110,116,32,116,114,97,112,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[9] = {73,79,84,32,116,114,97,112,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[9] = {69,77,84,32,116,114,97,112,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[25] = {70,108,111,97,116,105,110,103,32,112,111,105,110,116,32,101,120,99,101,112,116,105,111,110,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[7] = {75,105,108,108,101,100,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[10] = {66,117,115,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[19] = {83,101,103,109,101,110,116,97,116,105,111,110,32,102,97,117,108,116,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[16] = {66,97,100,32,115,121,115,116,101,109,32,99,97,108,108,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[12] = {66,114,111,107,101,110,32,112,105,112,101,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[12] = {65,108,97,114,109,32,99,108,111,99,107,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[11] = {84,101,114,109,105,110,97,116,101,100,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[21] = {85,114,103,101,110,116,32,73,47,79,32,99,111,110,100,105,116,105,111,110,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[17] = {83,116,111,112,112,101,100,32,40,115,105,103,110,97,108,41,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[8] = {83,116,111,112,112,101,100,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[10] = {67,111,110,116,105,110,117,101,100,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[13] = {67,104,105,108,100,32,101,120,105,116,101,100,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[18] = {85,110,107,110,111,119,110,32,115,105,103,110,97,108,32,37,100,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[20] = {83,116,111,112,112,101,100,32,40,116,116,121,32,105,110,112,117,116,41,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[13] = {73,47,79,32,112,111,115,115,105,98,108,101,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[15] = {87,105,110,100,111,119,32,99,104,97,110,103,101,100,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[22] = {85,115,101,114,32,100,101,102,105,110,101,100,32,115,105,103,110,97,108,32,49,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[22] = {85,115,101,114,32,100,101,102,105,110,101,100,32,115,105,103,110,97,108,32,50,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[24] = {67,80,85,32,116,105,109,101,32,108,105,109,105,116,32,101,120,99,101,101,100,101,100,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[25] = {70,105,108,101,32,115,105,122,101,32,108,105,109,105,116,32,101,120,99,101,101,100,101,100,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[22] = {86,105,114,116,117,97,108,32,116,105,109,101,114,32,101,120,112,105,114,101,100,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[24] = {80,114,111,102,105,108,105,110,103,32,116,105,109,101,114,32,101,120,112,105,114,101,100,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[14] = {82,101,115,111,117,114,99,101,32,108,111,115,116,0 }; // BEGIN GLOBAL FUNCTION DEF: strsignal .visible .func (.param .u64 %value_out) strsignal (.param .u32 %in_ar0) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .local .align 8 .b8 %stack_ar[8]; .reg .u64 %stack; cvta.local.u64 %stack,%stack_ar; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .reg .pred %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; .reg .pred %r30; .reg .pred %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; .reg .pred %r35; .reg .pred %r36; .reg .pred %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .pred %r41; .reg .pred %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u64 %r59; .reg .u32 %r60; mov.u32 %r24,%ar0; .loc 1 80 0 setp.eq.u32 %r25,%r24,15; @ %r25 bra $L3; setp.gt.s32 %r26,%r24,15; @ %r26 bra $L4; setp.eq.u32 %r27,%r24,7; @ %r27 bra $L5; setp.gt.s32 %r28,%r24,7; @ %r28 bra $L6; setp.eq.u32 %r29,%r24,3; @ %r29 bra $L7; setp.gt.s32 %r30,%r24,3; @ %r30 bra $L8; setp.eq.u32 %r31,%r24,1; @ %r31 bra $L40; setp.eq.u32 %r32,%r24,2; @ %r32 bra $L10; bra $L2; $L8: setp.eq.u32 %r33,%r24,5; @ %r33 bra $L11; setp.gt.s32 %r34,%r24,5; @ ! %r34 bra $L41; bra $L12; $L6: setp.eq.u32 %r35,%r24,11; @ %r35 bra $L14; setp.gt.s32 %r36,%r24,11; @ %r36 bra $L15; setp.eq.u32 %r37,%r24,9; @ %r37 bra $L16; setp.gt.s32 %r38,%r24,9; @ ! %r38 bra $L42; bra $L17; $L15: setp.eq.u32 %r39,%r24,13; @ %r39 bra $L19; setp.gt.s32 %r40,%r24,13; @ ! %r40 bra $L43; bra $L20; $L4: setp.eq.u32 %r41,%r24,24; @ %r41 bra $L22; setp.gt.s32 %r42,%r24,24; @ %r42 bra $L23; setp.eq.u32 %r43,%r24,19; @ %r43 bra $L24; setp.gt.s32 %r44,%r24,19; @ %r44 bra $L25; setp.eq.u32 %r45,%r24,17; @ %r45 bra $L26; setp.gt.s32 %r46,%r24,17; @ ! %r46 bra $L44; bra $L27; $L25: setp.eq.u32 %r47,%r24,21; @ %r47 bra $L29; setp.lt.s32 %r48,%r24,21; @ %r48 bra $L30; setp.eq.u32 %r49,%r24,23; @ %r49 bra $L31; bra $L2; $L23: setp.eq.u32 %r50,%r24,28; @ %r50 bra $L32; setp.gt.s32 %r51,%r24,28; @ %r51 bra $L33; setp.eq.u32 %r52,%r24,26; @ %r52 bra $L34; setp.gt.s32 %r53,%r24,26; @ ! %r53 bra $L45; bra $L35; $L33: setp.eq.u32 %r54,%r24,30; @ %r54 bra $L37; setp.lt.s32 %r55,%r24,30; @ %r55 bra $L38; setp.eq.u32 %r56,%r24,31; @ %r56 bra $L39; bra $L2; $L10: .loc 1 88 0 cvta.const.u64 %r23,$LC1; bra $L1; $L7: .loc 1 93 0 cvta.const.u64 %r23,$LC2; .loc 1 94 0 bra $L1; $L41: .loc 1 98 0 cvta.const.u64 %r23,$LC3; .loc 1 99 0 bra $L1; $L11: .loc 1 103 0 cvta.const.u64 %r23,$LC4; .loc 1 104 0 bra $L1; $L12: .loc 1 111 0 cvta.const.u64 %r23,$LC5; .loc 1 112 0 bra $L1; $L5: .loc 1 116 0 cvta.const.u64 %r23,$LC6; .loc 1 117 0 bra $L1; $L42: .loc 1 121 0 cvta.const.u64 %r23,$LC7; .loc 1 122 0 bra $L1; $L16: .loc 1 126 0 cvta.const.u64 %r23,$LC8; .loc 1 127 0 bra $L1; $L17: .loc 1 131 0 cvta.const.u64 %r23,$LC9; .loc 1 132 0 bra $L1; $L14: .loc 1 136 0 cvta.const.u64 %r23,$LC10; .loc 1 137 0 bra $L1; $L43: .loc 1 141 0 cvta.const.u64 %r23,$LC11; .loc 1 142 0 bra $L1; $L19: .loc 1 146 0 cvta.const.u64 %r23,$LC12; .loc 1 147 0 bra $L1; $L20: .loc 1 151 0 cvta.const.u64 %r23,$LC13; .loc 1 152 0 bra $L1; $L3: .loc 1 156 0 cvta.const.u64 %r23,$LC14; .loc 1 157 0 bra $L1; $L44: .loc 1 161 0 cvta.const.u64 %r23,$LC15; .loc 1 162 0 bra $L1; $L26: .loc 1 166 0 cvta.const.u64 %r23,$LC16; .loc 1 167 0 bra $L1; $L27: .loc 1 171 0 cvta.const.u64 %r23,$LC17; .loc 1 172 0 bra $L1; $L24: .loc 1 176 0 cvta.const.u64 %r23,$LC18; .loc 1 177 0 bra $L1; $L30: .loc 1 184 0 cvta.const.u64 %r23,$LC19; .loc 1 185 0 bra $L1; $L29: .loc 1 189 0 cvta.const.u64 %r23,$LC20; .loc 1 190 0 bra $L1; $L31: .loc 1 202 0 cvta.const.u64 %r23,$LC21; .loc 1 203 0 bra $L1; $L32: .loc 1 207 0 cvta.const.u64 %r23,$LC22; .loc 1 208 0 bra $L1; $L37: .loc 1 212 0 cvta.const.u64 %r23,$LC23; .loc 1 213 0 bra $L1; $L39: .loc 1 217 0 cvta.const.u64 %r23,$LC24; .loc 1 218 0 bra $L1; $L22: .loc 1 227 0 cvta.const.u64 %r23,$LC25; .loc 1 228 0 bra $L1; $L45: .loc 1 232 0 cvta.const.u64 %r23,$LC26; .loc 1 233 0 bra $L1; $L34: .loc 1 237 0 cvta.const.u64 %r23,$LC27; .loc 1 238 0 bra $L1; $L35: .loc 1 242 0 cvta.const.u64 %r23,$LC28; .loc 1 243 0 bra $L1; $L38: .loc 1 247 0 cvta.const.u64 %r23,$LC29; .loc 1 248 0 bra $L1; $L2: .loc 1 71 0 ld.global.u64 %r57,[_impure_ptr]; add.u64 %r23,%r57,288; .loc 1 251 0 st.u32 [%stack],%r24; cvta.const.u64 %r59,$LC30; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r59; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),siprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r60,[%value_in]; } .loc 1 252 0 bra $L1; $L40: .loc 1 83 0 cvta.const.u64 %r23,$LC0; $L1: .loc 1 256 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-strspn.o/ 0 0 0 644 1658 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strspn .visible .func (.param .u64 %value_out) strspn (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strspn.c" // BEGIN GLOBAL FUNCTION DEF: strspn .visible .func (.param .u64 %value_out) strspn (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u16 %r64; .reg .pred %r66; .reg .pred %r67; .reg .u16 %r70; .reg .pred %r71; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; mov.u64 %r61,%ar0; mov.u64 %r62,%ar1; .loc 1 46 0 ld.s8 %r51,[%r61]; mov.u64 %r59,%r61; setp.ne.u32 %r63,%r51,0; @ %r63 bra $L2; mov.u64 %r60,0; bra $L1; $L5: .loc 1 50 0 cvt.u16.u32 %r64,%r50; setp.eq.u16 %r66,%r64,%r75; @ %r66 bra $L4; $L7: .loc 1 48 0 add.u64 %r52,%r52,1; ld.s8 %r50,[%r52]; setp.ne.u32 %r67,%r50,0; @ %r67 bra $L5; sub.u64 %r60,%r61,%r59; bra $L1; $L2: ld.s8 %r49,[%r62]; setp.ne.u32 %r74,%r49,0; .loc 1 50 0 cvt.u16.u32 %r76,%r49; $L8: .loc 1 48 0 @ %r74 bra $L6; sub.u64 %r60,%r61,%r59; bra $L1; $L6: .loc 1 50 0 cvt.u16.u32 %r70,%r51; setp.eq.u16 %r71,%r76,%r70; @ %r71 bra $L4; mov.u64 %r52,%r62; cvt.u16.u32 %r75,%r51; bra $L7; $L4: .loc 1 55 0 add.u64 %r61,%r61,1; .loc 1 46 0 ld.s8 %r51,[%r61]; setp.ne.u32 %r73,%r51,0; @ %r73 bra $L8; sub.u64 %r60,%r61,%r59; $L1: .loc 1 59 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } lib_a-strstr.o/ 0 0 0 644 27264 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/str-two-way.h" // BEGIN FUNCTION DECL: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: strstr .visible .func (.param .u64 %value_out) strstr (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 2 "../../../../../newlib/libc/string/strstr.c" // BEGIN GLOBAL FUNCTION DECL: memcmp .extern .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN FUNCTION DEF: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .pred %r54; .reg .pred %r57; .reg .pred %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .u16 %r63; .reg .u16 %r64; .reg .pred %r65; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .u64 %r73; .reg .u64 %r74; mov.u64 %r46,%ar0; mov.u64 %r47,%ar1; mov.u64 %r48,%ar2; .loc 1 113 0 mov.u64 %r37,1; mov.u64 %r35,%r37; .loc 1 112 0 mov.u64 %r28,0; .loc 1 111 0 mov.u64 %r32,-1; .loc 1 140 0 mov.u64 %r74,%r37; .loc 1 114 0 bra $L2; $L7: .loc 1 116 0 add.u64 %r49,%r46,%r27; .loc 1 117 0 add.u64 %r50,%r46,%r32; add.u64 %r51,%r50,%r35; .loc 1 118 0 ld.u8 %r52,[%r49]; ld.u8 %r53,[%r51]; setp.ge.u16 %r54,%r52,%r53; @ %r54 bra $L3; .loc 1 123 0 sub.u64 %r37,%r27,%r32; mov.u64 %r28,%r27; .loc 1 122 0 mov.u64 %r35,1; bra $L2; $L3: .loc 1 125 0 setp.ne.u16 %r57,%r52,%r53; @ %r57 bra $L5; .loc 1 128 0 setp.eq.u64 %r58,%r35,%r37; @ %r58 bra $L6; .loc 1 129 0 add.u64 %r35,%r35,1; bra $L2; $L6: .loc 1 132 0 mov.u64 %r28,%r27; .loc 1 133 0 mov.u64 %r35,1; bra $L2; $L5: .loc 1 139 0 mov.u64 %r32,%r28; add.u64 %r28,%r28,1; .loc 1 140 0 mov.u64 %r37,%r74; mov.u64 %r35,1; $L2: .loc 1 114 0 add.u64 %r27,%r28,%r35; setp.lt.u64 %r59,%r27,%r47; @ %r59 bra $L7; .loc 1 143 0 st.u64 [%r48],%r37; .loc 1 148 0 mov.u64 %r38,1; mov.u64 %r36,%r38; .loc 1 147 0 mov.u64 %r22,0; .loc 1 146 0 mov.u64 %r26,-1; .loc 1 175 0 mov.u64 %r73,%r38; .loc 1 149 0 bra $L8; $L13: .loc 1 151 0 add.u64 %r60,%r46,%r33; .loc 1 152 0 add.u64 %r61,%r46,%r26; add.u64 %r62,%r61,%r36; .loc 1 153 0 ld.u8 %r63,[%r60]; ld.u8 %r64,[%r62]; setp.le.u16 %r65,%r63,%r64; @ %r65 bra $L9; .loc 1 158 0 sub.u64 %r38,%r33,%r26; mov.u64 %r22,%r33; .loc 1 157 0 mov.u64 %r36,1; bra $L8; $L9: .loc 1 160 0 setp.ne.u16 %r68,%r63,%r64; @ %r68 bra $L11; .loc 1 163 0 setp.eq.u64 %r69,%r36,%r38; @ %r69 bra $L12; .loc 1 164 0 add.u64 %r36,%r36,1; bra $L8; $L12: .loc 1 167 0 mov.u64 %r22,%r33; .loc 1 168 0 mov.u64 %r36,1; bra $L8; $L11: .loc 1 174 0 mov.u64 %r26,%r22; add.u64 %r22,%r22,1; .loc 1 175 0 mov.u64 %r38,%r73; mov.u64 %r36,1; $L8: .loc 1 149 0 add.u64 %r33,%r22,%r36; setp.lt.u64 %r70,%r33,%r47; @ %r70 bra $L13; .loc 1 181 0 add.u64 %r34,%r26,1; add.u64 %r45,%r32,1; setp.lt.u64 %r71,%r34,%r45; @ %r71 bra $L1; .loc 1 183 0 st.u64 [%r48],%r38; .loc 1 184 0 mov.u64 %r45,%r34; $L1: .loc 1 185 0 mov.u64 %value,%r45; st.param.u64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[2056]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r76; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r86; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r96; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r107; .reg .u32 %r113; .reg .u32 %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u64 %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r134; .reg .u64 %r136; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r151; .reg .u64 %r159; .reg .u64 %r172; .reg .u64 %r175; .reg .u64 %r176; .reg .u64 %r179; .reg .u64 %r186; .reg .u64 %r189; .reg .u64 %r194; .reg .u64 %r195; .reg .u64 %r197; .reg .u64 %r200; .reg .u64 %r201; .reg .u64 %r202; .reg .u64 %r203; .reg .u64 %r204; .reg .u64 %r208; .reg .u64 %r209; .reg .pred %r210; .reg .u64 %r211; .reg .pred %r212; .reg .u64 %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .pred %r217; .reg .u32 %r221; .reg .pred %r222; .reg .u64 %r223; .reg .u64 %r226; .reg .u64 %r227; .reg .u64 %r228; .reg .pred %r229; .reg .pred %r230; .reg .pred %r231; .reg .pred %r232; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .u16 %r236; .reg .u16 %r237; .reg .pred %r238; .reg .u64 %r240; .reg .u64 %r241; .reg .pred %r242; .reg .u16 %r243; .reg .u16 %r244; .reg .pred %r245; .reg .pred %r246; .reg .u64 %r247; .reg .u64 %r248; .reg .u64 %r249; .reg .u16 %r250; .reg .u16 %r251; .reg .pred %r252; .reg .u64 %r253; .reg .pred %r254; .reg .u16 %r255; .reg .u16 %r256; .reg .pred %r257; .reg .u64 %r258; .reg .pred %r259; .reg .u32 %r261; .reg .u64 %r263; .reg .u64 %r264; .reg .u64 %r265; .reg .u32 %r267; .reg .u32 %r268; .reg .u32 %r270; .reg .u32 %r271; .reg .u16 %r272; .reg .u16 %r273; .reg .u16 %r274; .reg .u32 %r275; .reg .u16 %r276; .reg .pred %r277; .reg .u64 %r278; .reg .u64 %r279; .reg .u64 %r280; .reg .u64 %r281; .reg .u64 %r284; .reg .u64 %r285; .reg .u64 %r286; .reg .pred %r287; .reg .pred %r288; .reg .u64 %r289; .reg .u64 %r291; .reg .u16 %r292; .reg .u16 %r293; .reg .pred %r294; .reg .u64 %r295; .reg .pred %r296; .reg .u16 %r297; .reg .u16 %r298; .reg .pred %r299; .reg .u64 %r301; .reg .u64 %r303; .reg .u16 %r304; .reg .u16 %r305; .reg .pred %r306; .reg .u64 %r307; .reg .pred %r308; .reg .u16 %r309; .reg .u16 %r310; .reg .pred %r311; .reg .u32 %r313; .reg .u64 %r315; .reg .u64 %r316; .reg .u64 %r317; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r322; .reg .u32 %r323; .reg .u16 %r324; .reg .u16 %r325; .reg .u16 %r326; .reg .u32 %r327; .reg .u16 %r328; .reg .pred %r329; .reg .u64 %r331; .reg .u64 %r335; .reg .u64 %r336; .reg .u64 %r337; .reg .u32 %r341; .reg .pred %r342; .reg .u64 %r343; .reg .u64 %r345; .reg .u64 %r347; .reg .u64 %r348; .reg .u64 %r349; .reg .u64 %r350; .reg .u64 %r351; .reg .u64 %r352; .reg .pred %r353; .reg .u64 %r354; .reg .u64 %r355; .reg .u64 %r356; mov.u64 %r201,%ar0; mov.u64 %r202,%ar1; mov.u64 %r203,%ar2; mov.u64 %r204,%ar3; .loc 1 304 0 add.u64 %r208,%frame,2048; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r203; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r204; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r208; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r209,[%value_in]; } mov.u64 %r197,%frame; $L16: .loc 1 311 0 st.u64 [%r197],%r204; add.u64 %r197,%r197,8; .loc 1 310 0 setp.ne.u64 %r210,%r208,%r197; @ %r210 bra $L16; ld.u64 %r211,[%frame+2048]; add.u64 %r172,%r203,%r211; .loc 1 312 0 setp.eq.u64 %r212,%r204,0; @ %r212 bra $L17; add.u64 %r175,%r204,-1; mov.u64 %r194,%r203; mov.u64 %r195,%r175; $L18: .loc 1 313 0 ld.u8 %r214,[%r194]; shl.b64 %r215,%r214,3; add.u64 %r216,%frame,%r215; st.u64 [%r216],%r195; add.u64 %r194,%r194,1; add.u64 %r195,%r195,-1; .loc 1 312 0 setp.ne.u64 %r217,%r195,-1; @ %r217 bra $L18; .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r203; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r172; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r209; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r221,[%value_in]; } setp.eq.u32 %r222,%r221,0; @ %r222 bra $L45; bra $L20; $L31: .loc 1 329 0 add.u64 %r223,%r201,%r100; ld.u8 %r226,[%r223+-1]; shl.b64 %r227,%r226,3; add.u64 %r228,%frame,%r227; ld.u64 %r128,[%r228]; .loc 1 330 0 setp.eq.u64 %r229,%r128,0; @ %r229 bra $L21; .loc 1 332 0 setp.eq.u64 %r230,%r127,0; @ %r230 bra $L22; ld.u64 %r86,[%frame+2048]; setp.le.u64 %r231,%r86,%r128; @ %r231 bra $L22; .loc 1 337 0 sub.u64 %r128,%r204,%r86; $L22: .loc 1 340 0 add.u64 %r115,%r115,%r128; .loc 1 339 0 mov.u64 %r127,0; .loc 1 341 0 bra $L23; $L21: .loc 1 345 0 max.u64 %r140,%r127,%r209; .loc 1 346 0 setp.ge.u64 %r232,%r140,%r175; @ %r232 bra $L24; add.u64 %r233,%r203,%r140; .loc 1 347 0 add.u64 %r234,%r201,%r115; add.u64 %r235,%r234,%r140; .loc 1 346 0 ld.u8 %r236,[%r233]; ld.u8 %r237,[%r235]; setp.ne.u16 %r238,%r236,%r237; @ %r238 bra $L25; add.u64 %r347,%r140,1; add.u64 %r76,%r203,%r347; add.u64 %r240,%r115,1; add.u64 %r241,%r240,%r140; add.u64 %r179,%r201,%r241; $L26: .loc 1 348 0 mov.u64 %r140,%r347; .loc 1 346 0 setp.eq.u64 %r242,%r347,%r175; @ %r242 bra $L24; ld.u8 %r88,[%r76]; .loc 1 347 0 ld.u8 %r89,[%r179]; add.u64 %r76,%r76,1; add.u64 %r179,%r179,1; .loc 1 346 0 cvt.u16.u32 %r243,%r88; cvt.u16.u32 %r244,%r89; setp.eq.u16 %r245,%r243,%r244; @ ! %r245 bra $L25; add.u64 %r347,%r347,1; bra $L26; $L24: .loc 1 352 0 mov.u64 %r159,%r349; .loc 1 353 0 setp.ge.u64 %r246,%r127,%r209; @ %r246 bra $L46; .loc 1 354 0 add.u64 %r247,%r201,%r115; add.u64 %r248,%r247,%r349; .loc 1 353 0 add.u64 %r249,%r203,%r349; ld.u8 %r250,[%r248]; ld.u8 %r251,[%r249]; setp.ne.u16 %r252,%r250,%r251; @ %r252 bra $L47; add.u64 %r151,%r203,%r350; add.u64 %r253,%r115,%r350; add.u64 %r126,%r201,%r253; add.u64 %r99,%r127,-1; bra $L28; $L48: mov.u64 %r159,%r141; $L28: .loc 1 355 0 add.u64 %r141,%r159,-1; .loc 1 353 0 setp.eq.u64 %r254,%r99,%r141; @ %r254 bra $L27; ld.u8 %r92,[%r151]; .loc 1 354 0 ld.u8 %r93,[%r126]; add.u64 %r151,%r151,-1; add.u64 %r126,%r126,-1; .loc 1 353 0 cvt.u16.u32 %r255,%r92; cvt.u16.u32 %r256,%r93; setp.eq.u16 %r257,%r255,%r256; @ %r257 bra $L48; bra $L27; $L46: mov.u64 %r159,%r209; bra $L27; $L47: mov.u64 %r159,%r209; $L27: .loc 1 356 0 add.u64 %r258,%r127,1; setp.le.u64 %r259,%r258,%r159; @ %r259 bra $L29; .loc 1 357 0 add.u64 %r200,%r201,%r115; bra $L15; $L29: .loc 1 360 0 ld.u64 %r96,[%frame+2048]; add.u64 %r115,%r115,%r96; .loc 1 361 0 sub.u64 %r127,%r204,%r96; $L23: .loc 1 339 0 mov.u64 %r202,%r100; bra $L19; $L45: .loc 1 322 0 mov.u64 %r127,0; .loc 1 324 0 mov.u64 %r115,%r127; .loc 1 352 0 add.u64 %r349,%r209,-1; add.u64 %r350,%r209,-2; $L19: .loc 1 325 0 add.u64 %r100,%r115,%r204; sub.u64 %r263,%r100,%r202; add.u64 %r264,%r201,%r202; mov.u32 %r261,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r264; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r261; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r263; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r265,[%value_in]; } set.u32.eq.u64 %r267,%r265,0; neg.s32 %r268,%r267; set.u32.ne.u64 %r270,%r100,0; neg.s32 %r271,%r270; cvt.u16.u32 %r273,%r268; cvt.u16.u32 %r274,%r271; and.b16 %r272,%r273,%r274; cvt.u32.u16 %r275,%r272; cvt.u16.u8 %r276,%r275; setp.ne.u16 %r277,%r276,0; @ %r277 bra $L31; $L43: .loc 1 408 0 mov.u64 %r200,0; bra $L15; $L20: .loc 1 375 0 sub.u64 %r279,%r204,%r209; max.u64 %r278,%r279,%r209; add.u64 %r280,%r278,1; st.u64 [%frame+2048],%r280; .loc 1 376 0 mov.u64 %r123,0; .loc 1 390 0 add.u64 %r351,%r204,-1; .loc 1 396 0 add.u64 %r352,%r209,-1; .loc 1 397 0 setp.eq.u64 %r353,%r352,-1; add.u64 %r354,%r209,-2; add.u64 %r355,%r203,-1; add.u64 %r356,%r209,1; .loc 1 377 0 bra $L32; $L42: .loc 1 381 0 add.u64 %r281,%r201,%r79; ld.u8 %r284,[%r281+-1]; shl.b64 %r285,%r284,3; add.u64 %r286,%frame,%r285; ld.u64 %r134,[%r286]; .loc 1 382 0 setp.ne.u64 %r287,%r134,0; @ %r287 bra $L33; .loc 1 390 0 setp.ge.u64 %r288,%r209,%r351; @ ! %r288 bra $L60; add.u64 %r348,%r201,%r123; bra $L34; $L60: add.u64 %r289,%r203,%r209; .loc 1 391 0 add.u64 %r348,%r201,%r123; add.u64 %r291,%r348,%r209; .loc 1 390 0 ld.u8 %r292,[%r289]; ld.u8 %r293,[%r291]; setp.eq.u16 %r294,%r292,%r293; @ %r294 bra $L35; mov.u64 %r136,%r209; bra $L36; $L33: .loc 1 384 0 add.u64 %r123,%r123,%r134; .loc 1 385 0 bra $L37; $L35: add.u64 %r186,%r203,%r356; add.u64 %r295,%r123,%r356; add.u64 %r189,%r201,%r295; .loc 1 390 0 mov.u64 %r136,%r209; $L38: .loc 1 392 0 add.u64 %r136,%r136,1; .loc 1 390 0 setp.ge.u64 %r296,%r136,%r351; @ %r296 bra $L34; ld.u8 %r113,[%r186]; .loc 1 391 0 ld.u8 %r114,[%r189]; add.u64 %r186,%r186,1; add.u64 %r189,%r189,1; .loc 1 390 0 cvt.u16.u32 %r297,%r113; cvt.u16.u32 %r298,%r114; setp.eq.u16 %r299,%r297,%r298; @ %r299 bra $L38; bra $L36; $L34: .loc 1 397 0 @ %r353 bra $L39; add.u64 %r301,%r203,%r352; .loc 1 398 0 add.u64 %r303,%r348,%r352; .loc 1 397 0 ld.u8 %r304,[%r301]; ld.u8 %r305,[%r303]; setp.ne.u16 %r306,%r304,%r305; @ %r306 bra $L40; add.u64 %r176,%r203,%r354; add.u64 %r307,%r354,%r123; add.u64 %r80,%r201,%r307; $L41: setp.eq.u64 %r308,%r176,%r355; @ %r308 bra $L39; ld.u8 %r116,[%r176]; .loc 1 398 0 ld.u8 %r117,[%r80]; add.u64 %r176,%r176,-1; add.u64 %r80,%r80,-1; .loc 1 397 0 cvt.u16.u32 %r309,%r116; cvt.u16.u32 %r310,%r117; setp.eq.u16 %r311,%r309,%r310; @ %r311 bra $L41; bra $L40; $L37: .loc 1 390 0 mov.u64 %r202,%r79; $L32: .loc 1 377 0 add.u64 %r79,%r123,%r204; sub.u64 %r315,%r79,%r202; add.u64 %r316,%r201,%r202; mov.u32 %r313,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r316; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r313; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r315; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r317,[%value_in]; } set.u32.ne.u64 %r319,%r79,0; neg.s32 %r320,%r319; set.u32.eq.u64 %r322,%r317,0; neg.s32 %r323,%r322; cvt.u16.u32 %r325,%r320; cvt.u16.u32 %r326,%r323; and.b16 %r324,%r325,%r326; cvt.u32.u16 %r327,%r324; cvt.u16.u8 %r328,%r327; setp.ne.u16 %r329,%r328,0; @ %r329 bra $L42; bra $L43; $L40: .loc 1 402 0 ld.u64 %r331,[%frame+2048]; add.u64 %r123,%r123,%r331; bra $L37; $L39: .loc 1 401 0 mov.u64 %r200,%r348; bra $L15; $L44: .loc 1 325 0 neg.s64 %r335,%r202; add.u64 %r336,%r201,%r202; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r336; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r341; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r335; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r337,[%value_in]; } .loc 1 408 0 mov.u64 %r200,%r204; bra $L15; $L17: .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r203; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r172; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r209; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r341,[%value_in]; } setp.eq.u32 %r342,%r341,0; @ %r342 bra $L44; bra $L20; $L25: sub.u64 %r343,%r115,%r209; add.u64 %r125,%r343,1; .loc 1 365 0 add.u64 %r115,%r125,%r140; .loc 1 366 0 mov.u64 %r127,%r128; bra $L23; $L36: sub.u64 %r345,%r123,%r209; add.u64 %r107,%r345,1; .loc 1 405 0 add.u64 %r123,%r107,%r136; bra $L37; $L15: .loc 1 409 0 mov.u64 %value,%r200; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strstr .visible .func (.param .u64 %value_out) strstr (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .local .align 8 .b8 %frame_ar[8]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r25; .reg .u64 %r37; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u32 %r47; .reg .u64 %r48; .reg .u64 %r50; .reg .u64 %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u64 %r70; .reg .u64 %r71; .reg .u64 %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r85; .reg .u64 %r88; .reg .u32 %r95; .reg .u32 %r96; .reg .u64 %r108; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r119; .reg .u64 %r122; .reg .u64 %r127; .reg .u64 %r130; .reg .u64 %r137; .reg .u64 %r140; .reg .u64 %r146; .reg .u64 %r147; .reg .pred %r148; .reg .pred %r149; .reg .u16 %r151; .reg .u16 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .pred %r155; .reg .pred %r156; .reg .pred %r157; .reg .pred %r158; .reg .pred %r159; .reg .u64 %r162; .reg .u64 %r163; .reg .u32 %r165; .reg .u32 %r166; .reg .u32 %r168; .reg .u32 %r169; .reg .u16 %r170; .reg .u16 %r171; .reg .u16 %r172; .reg .u32 %r173; .reg .u16 %r174; .reg .pred %r175; .reg .pred %r176; .reg .pred %r177; .reg .u64 %r181; .reg .u64 %r185; .reg .u64 %r186; .reg .u32 %r187; .reg .pred %r188; .reg .pred %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .u16 %r193; .reg .u16 %r194; .reg .pred %r195; .reg .u64 %r197; .reg .u64 %r198; .reg .pred %r199; .reg .u16 %r200; .reg .u16 %r201; .reg .pred %r202; .reg .pred %r203; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r206; .reg .u16 %r207; .reg .u16 %r208; .reg .pred %r209; .reg .u64 %r210; .reg .pred %r211; .reg .u16 %r212; .reg .u16 %r213; .reg .pred %r214; .reg .u64 %r215; .reg .pred %r216; .reg .u32 %r218; .reg .u64 %r220; .reg .u64 %r221; .reg .u64 %r222; .reg .u32 %r224; .reg .u32 %r225; .reg .u32 %r227; .reg .u32 %r228; .reg .u16 %r229; .reg .u16 %r230; .reg .u16 %r231; .reg .u32 %r232; .reg .u16 %r233; .reg .pred %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .u64 %r237; .reg .u64 %r238; .reg .pred %r239; .reg .u16 %r240; .reg .u16 %r241; .reg .pred %r242; .reg .u64 %r244; .reg .u64 %r245; .reg .u16 %r246; .reg .u16 %r247; .reg .pred %r248; .reg .u64 %r249; .reg .pred %r250; .reg .u16 %r251; .reg .u16 %r252; .reg .pred %r253; .reg .u32 %r255; .reg .u64 %r257; .reg .u64 %r258; .reg .u64 %r259; .reg .u32 %r261; .reg .u32 %r262; .reg .u32 %r264; .reg .u32 %r265; .reg .u16 %r266; .reg .u16 %r267; .reg .u16 %r268; .reg .u32 %r269; .reg .u16 %r270; .reg .pred %r271; .reg .pred %r272; .reg .u64 %r273; .reg .u64 %r274; .reg .u64 %r275; .reg .u16 %r276; .reg .u16 %r277; .reg .pred %r278; .reg .u64 %r283; .reg .u64 %r285; .reg .u64 %r286; .reg .u64 %r289; .reg .u64 %r291; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u64 %r295; .reg .pred %r296; .reg .u64 %r297; .reg .u64 %r298; .reg .u64 %r299; mov.u64 %r146,%ar0; mov.u64 %r147,%ar1; .loc 2 97 0 ld.s8 %r25,[%r146]; ld.s8 %r96,[%r147]; setp.eq.u32 %r148,%r25,0; @ %r148 bra $L62; setp.eq.u32 %r149,%r96,0; @ %r149 bra $L101; mov.u64 %r45,%r147; mov.u64 %r44,%r146; mov.u32 %r95,%r96; .loc 2 92 0 mov.u32 %r47,1; $L65: .loc 2 98 0 add.u64 %r44,%r44,1; add.u64 %r45,%r45,1; cvt.u16.u32 %r151,%r95; cvt.u16.u32 %r152,%r25; set.u32.eq.u16 %r153,%r151,%r152; neg.s32 %r154,%r153; and.b32 %r47,%r47,%r154; .loc 2 97 0 ld.s8 %r25,[%r44]; ld.s8 %r95,[%r45]; setp.eq.u32 %r155,%r25,0; @ %r155 bra $L64; setp.ne.u32 %r156,%r95,0; @ %r156 bra $L65; bra $L66; $L62: .loc 2 99 0 setp.eq.u32 %r157,%r96,0; .loc 2 100 0 selp.u64 %r146,%r146,0,%r157; bra $L101; $L64: .loc 2 99 0 setp.ne.u32 %r158,%r95,0; @ %r158 bra $L91; $L66: .loc 2 101 0 setp.ne.u32 %r159,%r47,0; @ %r159 bra $L101; .loc 2 106 0 sub.u64 %r48,%r45,%r147; .loc 2 107 0 add.u64 %r162,%r146,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r162; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r96; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r163,[%value_in]; } .loc 2 108 0 set.u32.eq.u64 %r165,%r163,0; neg.s32 %r166,%r165; set.u32.eq.u64 %r168,%r48,1; neg.s32 %r169,%r168; cvt.u16.u32 %r171,%r166; cvt.u16.u32 %r172,%r169; or.b16 %r170,%r171,%r172; cvt.u32.u16 %r173,%r170; cvt.u16.u8 %r174,%r173; setp.ne.u16 %r175,%r174,0; @ %r175 bra $L92; .loc 2 110 0 add.u64 %r37,%r146,%r48; .loc 2 111 0 setp.lt.u64 %r176,%r37,%r163; @ %r176 bra $L93; sub.u64 %r43,%r37,%r163; bra $L67; $L93: mov.u64 %r43,1; $L67: .loc 2 114 0 setp.gt.u64 %r177,%r48,31; @ %r177 bra $L68; .loc 1 209 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r147; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r48; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r181,[%value_in]; } .loc 1 213 0 ld.u64 %r186,[%frame]; add.u64 %r185,%r147,%r186; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r147; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r185; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r181; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r187,[%value_in]; } setp.eq.u32 %r188,%r187,0; @ %r188 bra $L94; bra $L111; $L78: .loc 1 223 0 max.u64 %r57,%r181,%r56; .loc 1 224 0 setp.le.u64 %r189,%r48,%r57; @ %r189 bra $L71; .loc 1 225 0 add.u64 %r190,%r163,%r57; add.u64 %r191,%r190,%r59; .loc 1 224 0 add.u64 %r192,%r147,%r57; ld.u8 %r193,[%r191]; ld.u8 %r194,[%r192]; setp.ne.u16 %r195,%r193,%r194; @ %r195 bra $L72; add.u64 %r291,%r57,1; add.u64 %r119,%r147,%r291; add.u64 %r197,%r59,1; add.u64 %r198,%r197,%r57; add.u64 %r122,%r163,%r198; $L73: .loc 1 226 0 mov.u64 %r57,%r291; .loc 1 224 0 setp.eq.u64 %r199,%r48,%r291; @ %r199 bra $L71; ld.u8 %r58,[%r119]; .loc 1 225 0 ld.u8 %r60,[%r122]; add.u64 %r119,%r119,1; add.u64 %r122,%r122,1; .loc 1 224 0 cvt.u16.u32 %r200,%r58; cvt.u16.u32 %r201,%r60; setp.eq.u16 %r202,%r200,%r201; @ ! %r202 bra $L72; add.u64 %r291,%r291,1; bra $L73; $L71: .loc 1 230 0 mov.u64 %r115,%r293; .loc 1 231 0 setp.le.u64 %r203,%r181,%r56; @ %r203 bra $L95; add.u64 %r204,%r147,%r293; .loc 1 232 0 add.u64 %r205,%r163,%r59; add.u64 %r206,%r205,%r293; .loc 1 231 0 ld.u8 %r207,[%r204]; ld.u8 %r208,[%r206]; setp.ne.u16 %r209,%r207,%r208; @ %r209 bra $L96; add.u64 %r62,%r147,%r294; add.u64 %r210,%r294,%r59; add.u64 %r116,%r163,%r210; add.u64 %r64,%r56,-1; bra $L75; $L97: mov.u64 %r115,%r63; $L75: .loc 1 233 0 add.u64 %r63,%r115,-1; .loc 1 231 0 setp.eq.u64 %r211,%r63,%r64; @ %r211 bra $L74; ld.u8 %r65,[%r62]; .loc 1 232 0 ld.u8 %r66,[%r116]; add.u64 %r62,%r62,-1; add.u64 %r116,%r116,-1; .loc 1 231 0 cvt.u16.u32 %r212,%r65; cvt.u16.u32 %r213,%r66; setp.eq.u16 %r214,%r212,%r213; @ %r214 bra $L97; bra $L74; $L95: mov.u64 %r115,%r181; bra $L74; $L96: mov.u64 %r115,%r181; $L74: .loc 1 234 0 add.u64 %r215,%r56,1; setp.le.u64 %r216,%r215,%r115; @ %r216 bra $L76; .loc 1 235 0 add.u64 %r146,%r163,%r59; bra $L101; $L76: .loc 1 238 0 ld.u64 %r70,[%frame]; add.u64 %r59,%r59,%r70; .loc 1 239 0 sub.u64 %r56,%r48,%r70; $L89: .loc 1 244 0 mov.u64 %r43,%r71; bra $L69; $L94: .loc 1 218 0 mov.u64 %r56,0; .loc 1 219 0 mov.u64 %r59,%r56; .loc 1 230 0 add.u64 %r293,%r181,-1; add.u64 %r294,%r181,-2; $L69: .loc 1 220 0 add.u64 %r71,%r48,%r59; sub.u64 %r220,%r71,%r43; add.u64 %r221,%r163,%r43; mov.u32 %r218,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r221; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r218; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r220; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r222,[%value_in]; } set.u32.eq.u64 %r224,%r222,0; neg.s32 %r225,%r224; set.u32.ne.u64 %r227,%r71,0; neg.s32 %r228,%r227; cvt.u16.u32 %r230,%r225; cvt.u16.u32 %r231,%r228; and.b16 %r229,%r230,%r231; cvt.u32.u16 %r232,%r229; cvt.u16.u8 %r233,%r232; setp.ne.u16 %r234,%r233,0; @ %r234 bra $L78; bra $L79; $L111: .loc 1 252 0 sub.u64 %r236,%r48,%r181; max.u64 %r235,%r236,%r181; add.u64 %r237,%r235,1; st.u64 [%frame],%r237; .loc 1 253 0 mov.u64 %r80,0; .loc 1 264 0 add.u64 %r295,%r181,-1; .loc 1 265 0 setp.ne.u64 %r296,%r295,-1; add.u64 %r297,%r181,-2; add.u64 %r298,%r147,-1; add.u64 %r299,%r181,1; bra $L80; $L87: add.u64 %r137,%r147,%r299; add.u64 %r238,%r80,%r299; add.u64 %r140,%r163,%r238; .loc 1 258 0 mov.u64 %r78,%r181; $L82: .loc 1 260 0 add.u64 %r78,%r78,1; .loc 1 258 0 setp.eq.u64 %r239,%r48,%r78; @ %r239 bra $L81; ld.u8 %r79,[%r137]; .loc 1 259 0 ld.u8 %r81,[%r140]; add.u64 %r137,%r137,1; add.u64 %r140,%r140,1; .loc 1 258 0 cvt.u16.u32 %r240,%r79; cvt.u16.u32 %r241,%r81; setp.eq.u16 %r242,%r240,%r241; @ %r242 bra $L82; bra $L83; $L90: .loc 1 266 0 add.u64 %r292,%r163,%r80; add.u64 %r244,%r292,%r295; .loc 1 265 0 add.u64 %r245,%r147,%r295; ld.u8 %r246,[%r244]; ld.u8 %r247,[%r245]; setp.ne.u16 %r248,%r246,%r247; @ %r248 bra $L84; add.u64 %r127,%r147,%r297; add.u64 %r249,%r80,%r297; add.u64 %r130,%r163,%r249; $L86: setp.eq.u64 %r250,%r127,%r298; @ %r250 bra $L85; ld.u8 %r83,[%r127]; .loc 1 266 0 ld.u8 %r85,[%r130]; add.u64 %r127,%r127,-1; add.u64 %r130,%r130,-1; .loc 1 265 0 cvt.u16.u32 %r251,%r83; cvt.u16.u32 %r252,%r85; setp.eq.u16 %r253,%r251,%r252; @ %r253 bra $L86; bra $L84; $L88: .loc 1 258 0 mov.u64 %r43,%r88; $L80: .loc 1 254 0 add.u64 %r88,%r48,%r80; sub.u64 %r257,%r88,%r43; add.u64 %r258,%r163,%r43; mov.u32 %r255,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r258; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r255; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r257; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r259,[%value_in]; } set.u32.ne.u64 %r261,%r88,0; neg.s32 %r262,%r261; set.u32.eq.u64 %r264,%r259,0; neg.s32 %r265,%r264; cvt.u16.u32 %r267,%r262; cvt.u16.u32 %r268,%r265; and.b16 %r266,%r267,%r268; cvt.u32.u16 %r269,%r266; cvt.u16.u8 %r270,%r269; setp.eq.u16 %r271,%r270,0; @ %r271 bra $L79; .loc 1 258 0 setp.le.u64 %r272,%r48,%r181; @ %r272 bra $L81; add.u64 %r273,%r147,%r181; .loc 1 259 0 add.u64 %r274,%r163,%r181; add.u64 %r275,%r274,%r80; .loc 1 258 0 ld.u8 %r276,[%r273]; ld.u8 %r277,[%r275]; setp.eq.u16 %r278,%r276,%r277; @ %r278 bra $L87; mov.u64 %r78,%r181; bra $L83; $L79: .loc 1 276 0 mov.u64 %r146,0; .loc 2 115 0 bra $L101; $L68: .loc 2 118 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r163; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r147; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r48; call (%value_in),two_way_long_needle,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r283,[%value_in]; } mov.u64 %r146,%r283; bra $L101; $L91: .loc 2 100 0 mov.u64 %r146,0; bra $L101; $L92: .loc 2 107 0 mov.u64 %r146,%r163; bra $L101; $L85: .loc 1 269 0 mov.u64 %r146,%r292; bra $L101; $L84: .loc 1 270 0 ld.u64 %r285,[%frame]; add.u64 %r80,%r80,%r285; bra $L88; $L72: sub.u64 %r286,%r59,%r181; add.u64 %r50,%r286,1; .loc 1 243 0 add.u64 %r59,%r57,%r50; .loc 1 244 0 mov.u64 %r56,0; bra $L89; $L81: .loc 1 265 0 @ %r296 bra $L90; add.u64 %r292,%r163,%r80; bra $L85; $L83: sub.u64 %r289,%r80,%r181; add.u64 %r108,%r289,1; .loc 1 273 0 add.u64 %r80,%r78,%r108; bra $L88; $L101: .loc 2 121 0 mov.u64 %value,%r146; st.param.u64 [%value_out],%value; ret; } lib_a-strtod.o/ 0 0 0 644 59429 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: sulp .func (.param .f64 %value_out) sulp (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/strtod.c" // BEGIN GLOBAL FUNCTION DECL: _strtod_r .visible .func (.param .f64 %value_out) _strtod_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strtod .visible .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtof .visible .func (.param .f32 %value_out) strtof (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __mprec_bigtens .extern .const .align 8 .u64 __mprec_bigtens[5]; // BEGIN GLOBAL VAR DECL: __mprec_tens .extern .const .align 8 .u64 __mprec_tens[25]; // BEGIN GLOBAL FUNCTION DECL: __ulp .extern .func (.param .f64 %value_out) __ulp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __gethex .extern .func (.param .u32 %value_out) __gethex (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DECL: __copybits .extern .func __copybits (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strncmp .extern .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __hexnan .extern .func (.param .u32 %value_out) __hexnan (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __s2b .extern .func (.param .u64 %value_out) __s2b (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __d2b .extern .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __i2b .extern .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __pow5mult .extern .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __multiply .extern .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __lshift .extern .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mdiff .extern .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mcmp .extern .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ratio .extern .func (.param .f64 %value_out) __ratio (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nanf .extern .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[3] = {97,110,0 }; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {110,102,0 }; // BEGIN VAR DEF: fpinan$2587 .const .align 4 .u32 fpinan$2587[5] = {52,4294966222,971,1,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {105,110,105,116,121,0 }; // BEGIN VAR DEF: fpi$2551 .const .align 4 .u32 fpi$2551[5] = {53,4294966222,971,1,0 }; // BEGIN VAR DEF: tinytens .const .align 8 .u64 tinytens[5] = {4367597403136100796,4128101167230658355,3649340653511681853,2691949749288605597,1254259266780163907 }; // BEGIN FUNCTION DEF: sulp .func (.param .f64 %value_out) sulp (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r31; .reg .f64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .pred %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u64 %r52; .reg .f64 %r53; mov.u64 %r34,%ar0; ld.u64 %r35,[%r34]; mov.u32 %r36,%ar1; .loc 1 163 0 mov.b64 %r37,%r35; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),__ulp,(%out_arg1); ld.param.f64 %r38,[%value_in]; } mov.f64 %r33,%r38; .loc 1 164 0 setp.eq.u32 %r39,%r36,0; @ %r39 bra $L1; shr.u64 %r40,%r35,32; cvt.u32.u64 %r42,%r40; shr.u32 %r41,%r42,20; and.b32 %r43,%r41,2047; mov.u32 %r44,107; sub.u32 %r31,%r44,%r43; setp.le.s32 %r45,%r31,0; @ %r45 bra $L1; .loc 1 166 0 shl.b32 %r46,%r31,20; add.u32 %r47,%r46,1072693248; cvt.u64.u32 %r48,%r47; .loc 1 168 0 shl.b64 %r52,%r48,32; .loc 1 170 0 mov.b64 %r53,%r52; mul.f64 %r33,%r33,%r53; $L1: .loc 1 171 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _strtod_r .visible .func (.param .f64 %value_out) _strtod_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .local .align 8 .b8 %frame_ar[40]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .f64 %r131; .reg .u32 %r132; .reg .u64 %r133; .reg .u32 %r136; .reg .u32 %r146; .reg .u64 %r157; .reg .u32 %r168; .reg .u32 %r170; .reg .f64 %r174; .reg .u32 %r181; .reg .u32 %r191; .reg .u32 %r192; .reg .u64 %r193; .reg .f64 %r208; .reg .f64 %r233; .reg .u32 %r240; .reg .f64 %r258; .reg .u32 %r259; .reg .u32 %r260; .reg .u32 %r273; .reg .u32 %r275; .reg .u64 %r289; .reg .u32 %r290; .reg .u32 %r292; .reg .u32 %r293; .reg .f64 %r295; .reg .f64 %r296; .reg .u64 %r298; .reg .f64 %r299; .reg .f64 %r306; .reg .f64 %r309; .reg .f64 %r314; .reg .u32 %r316; .reg .u32 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r327; .reg .u32 %r328; .reg .u32 %r329; .reg .f64 %r331; .reg .u32 %r332; .reg .u32 %r333; .reg .u64 %r335; .reg .u64 %r336; .reg .u64 %r337; .reg .u64 %r338; .reg .u32 %r339; .reg .u32 %r340; .reg .u32 %r341; .reg .f64 %r342; .reg .f64 %r343; .reg .u64 %r344; .reg .u32 %r345; .reg .u32 %r351; .reg .u64 %r354; .reg .u32 %r355; .reg .u32 %r356; .reg .u64 %r357; .reg .u64 %r358; .reg .u64 %r360; .reg .u32 %r361; .reg .u32 %r362; .reg .u32 %r363; .reg .u32 %r364; .reg .u32 %r366; .reg .u32 %r367; .reg .u32 %r368; .reg .u32 %r369; .reg .u32 %r370; .reg .u32 %r371; .reg .u32 %r372; .reg .u32 %r373; .reg .u64 %r374; .reg .u64 %r375; .reg .u32 %r376; .reg .u32 %r377; .reg .u32 %r381; .reg .u32 %r382; .reg .u32 %r383; .reg .u32 %r385; .reg .u32 %r388; .reg .u32 %r389; .reg .u64 %r390; .reg .f64 %r393; .reg .u32 %r394; .reg .u64 %r398; .reg .u32 %r400; .reg .u32 %r401; .reg .u32 %r405; .reg .u32 %r406; .reg .u64 %r409; .reg .u32 %r411; .reg .u32 %r412; .reg .u32 %r415; .reg .u32 %r416; .reg .u64 %r435; .reg .u32 %r441; .reg .u32 %r445; .reg .u32 %r446; .reg .f64 %r447; .reg .u64 %r452; .reg .u64 %r454; .reg .u32 %r455; .reg .u64 %r456; .reg .u32 %r457; .reg .u64 %r458; .reg .u64 %r467; .reg .u64 %r468; .reg .f64 %r470; .reg .u64 %r471; .reg .u64 %r472; .reg .u64 %r473; .reg .u64 %r474; .reg .u16 %r475; .reg .pred %r476; .reg .pred %r478; .reg .pred %r480; .reg .pred %r482; .reg .pred %r484; .reg .pred %r486; .reg .pred %r487; .reg .u16 %r488; .reg .pred %r489; .reg .u16 %r490; .reg .u32 %r491; .reg .pred %r492; .reg .pred %r493; .reg .u64 %r496; .reg .u64 %r500; .reg .u64 %r501; .reg .u64 %r502; .reg .u32 %r503; .reg .pred %r504; .reg .pred %r505; .reg .pred %r506; .reg .pred %r507; .reg .u32 %r509; .reg .u64 %r513; .reg .pred %r514; .reg .pred %r515; .reg .pred %r516; .reg .pred %r517; .reg .pred %r518; .reg .pred %r519; .reg .u64 %r523; .reg .u64 %r524; .reg .u64 %r525; .reg .u32 %r530; .reg .u32 %r531; .reg .u32 %r532; .reg .u32 %r533; .reg .u32 %r534; .reg .u64 %r535; .reg .u64 %r536; .reg .u64 %r537; .reg .u32 %r541; .reg .pred %r542; .reg .u64 %r543; .reg .u32 %r544; .reg .u32 %r545; .reg .u64 %r546; .reg .u64 %r547; .reg .u64 %r548; .reg .u16 %r550; .reg .pred %r551; .reg .pred %r552; .reg .pred %r554; .reg .pred %r555; .reg .u32 %r557; .reg .u32 %r558; .reg .u32 %r559; .reg .u32 %r562; .reg .u32 %r563; .reg .u32 %r564; .reg .pred %r567; .reg .u64 %r569; .reg .u64 %r570; .reg .u64 %r571; .reg .u64 %r573; .reg .u64 %r575; .reg .u64 %r577; .reg .u32 %r578; .reg .pred %r579; .reg .u64 %r581; .reg .u64 %r582; .reg .u64 %r583; .reg .u64 %r584; .reg .pred %r585; .reg .pred %r586; .reg .pred %r587; .reg .pred %r588; .reg .pred %r589; .reg .pred %r590; .reg .u32 %r592; .reg .u32 %r593; .reg .pred %r596; .reg .u32 %r598; .reg .u32 %r599; .reg .pred %r601; .reg .pred %r602; .reg .u32 %r604; .reg .u32 %r605; .reg .u32 %r606; .reg .pred %r607; .reg .u32 %r609; .reg .u32 %r610; .reg .u32 %r611; .reg .u64 %r612; .reg .u32 %r613; .reg .pred %r614; .reg .u32 %r615; .reg .pred %r616; .reg .u32 %r617; .reg .u32 %r618; .reg .pred %r619; .reg .u64 %r620; .reg .u16 %r621; .reg .pred %r622; .reg .pred %r624; .reg .u64 %r625; .reg .u32 %r626; .reg .pred %r627; .reg .pred %r628; .reg .u64 %r629; .reg .pred %r630; .reg .u32 %r631; .reg .pred %r632; .reg .u32 %r633; .reg .pred %r634; .reg .u32 %r636; .reg .u32 %r637; .reg .u32 %r638; .reg .u32 %r639; .reg .pred %r640; .reg .u64 %r641; .reg .u32 %r643; .reg .u32 %r644; .reg .u32 %r646; .reg .u32 %r647; .reg .u16 %r648; .reg .u16 %r649; .reg .u16 %r650; .reg .u32 %r651; .reg .u16 %r652; .reg .pred %r653; .reg .pred %r654; .reg .pred %r655; .reg .u32 %r656; .reg .pred %r657; .reg .pred %r658; .reg .pred %r659; .reg .pred %r660; .reg .pred %r661; .reg .pred %r662; .reg .pred %r663; .reg .u32 %r664; .reg .pred %r665; .reg .pred %r666; .reg .pred %r667; .reg .u32 %r668; .reg .pred %r669; .reg .pred %r670; .reg .pred %r671; .reg .u64 %r672; .reg .u64 %r673; .reg .u32 %r674; .reg .pred %r675; .reg .pred %r676; .reg .pred %r677; .reg .u64 %r678; .reg .u16 %r679; .reg .u32 %r680; .reg .pred %r681; .reg .u64 %r683; .reg .u64 %r685; .reg .u32 %r686; .reg .pred %r687; .reg .u32 %r688; .reg .u32 %r689; .reg .u64 %r690; .reg .u64 %r694; .reg .u64 %r695; .reg .pred %r697; .reg .pred %r698; .reg .pred %r699; .reg .pred %r700; .reg .f64 %r701; .reg .u64 %r702; .reg .u32 %r703; .reg .u64 %r704; .reg .u64 %r705; .reg .u64 %r706; .reg .f64 %r707; .reg .f64 %r708; .reg .pred %r709; .reg .pred %r710; .reg .pred %r711; .reg .u64 %r712; .reg .u64 %r713; .reg .u64 %r714; .reg .u64 %r715; .reg .f64 %r716; .reg .f64 %r717; .reg .u32 %r718; .reg .u32 %r719; .reg .pred %r720; .reg .u32 %r721; .reg .u64 %r722; .reg .u64 %r723; .reg .u64 %r724; .reg .u64 %r725; .reg .f64 %r726; .reg .f64 %r727; .reg .f64 %r728; .reg .u32 %r730; .reg .u64 %r731; .reg .u64 %r732; .reg .u64 %r733; .reg .f64 %r734; .reg .pred %r735; .reg .u64 %r736; .reg .u32 %r737; .reg .u64 %r738; .reg .u64 %r739; .reg .u64 %r740; .reg .f64 %r741; .reg .f64 %r742; .reg .u32 %r743; .reg .pred %r744; .reg .pred %r745; .reg .u64 %r746; .reg .u64 %r747; .reg .u64 %r748; .reg .u64 %r749; .reg .f64 %r750; .reg .f64 %r751; .reg .f64 %r752; .reg .pred %r753; .reg .pred %r754; .reg .u32 %r755; .reg .u32 %r756; .reg .pred %r757; .reg .u32 %r758; .reg .pred %r759; .reg .f64 %r760; .reg .pred %r761; .reg .pred %r762; .reg .u64 %r763; .reg .u32 %r764; .reg .u32 %r765; .reg .u64 %r766; .reg .u64 %r767; .reg .u64 %r768; .reg .u64 %r771; .reg .u64 %r772; .reg .u64 %r773; .reg .f64 %r774; .reg .f64 %r775; .reg .u64 %r777; .reg .pred %r778; .reg .pred %r779; .reg .u32 %r780; .reg .u64 %r781; .reg .u64 %r782; .reg .u64 %r783; .reg .pred %r785; .reg .pred %r786; .reg .u64 %r787; .reg .u64 %r788; .reg .u64 %r789; .reg .u64 %r790; .reg .f64 %r791; .reg .f64 %r792; .reg .f64 %r793; .reg .pred %r794; .reg .pred %r795; .reg .pred %r796; .reg .pred %r797; .reg .pred %r798; .reg .u32 %r799; .reg .pred %r800; .reg .f64 %r801; .reg .pred %r802; .reg .pred %r803; .reg .pred %r804; .reg .u32 %r806; .reg .u32 %r807; .reg .u32 %r808; .reg .pred %r809; .reg .pred %r810; .reg .pred %r812; .reg .u32 %r815; .reg .u32 %r816; .reg .u32 %r817; .reg .u32 %r818; .reg .u64 %r819; .reg .u64 %r820; .reg .u64 %r821; .reg .u32 %r823; .reg .u32 %r824; .reg .u32 %r825; .reg .u32 %r826; .reg .u64 %r827; .reg .u64 %r828; .reg .f64 %r830; .reg .pred %r831; .reg .u32 %r832; .reg .u64 %r838; .reg .pred %r839; .reg .u32 %r840; .reg .pred %r841; .reg .u32 %r844; .reg .u64 %r845; .reg .pred %r846; .reg .u64 %r850; .reg .u64 %r851; .reg .u64 %r852; .reg .u64 %r854; .reg .u64 %r855; .reg .u64 %r861; .reg .pred %r862; .reg .u32 %r864; .reg .u64 %r865; .reg .pred %r866; .reg .pred %r867; .reg .u32 %r868; .reg .u32 %r869; .reg .u32 %r870; .reg .pred %r871; .reg .u32 %r872; .reg .pred %r873; .reg .u32 %r874; .reg .u32 %r875; .reg .u32 %r876; .reg .u32 %r877; .reg .u32 %r878; .reg .pred %r879; .reg .u64 %r884; .reg .pred %r885; .reg .u64 %r889; .reg .u64 %r890; .reg .pred %r891; .reg .u64 %r894; .reg .pred %r895; .reg .u64 %r900; .reg .u64 %r901; .reg .pred %r902; .reg .u64 %r906; .reg .pred %r907; .reg .pred %r908; .reg .u64 %r912; .reg .pred %r913; .reg .pred %r914; .reg .u64 %r918; .reg .pred %r919; .reg .u64 %r923; .reg .u64 %r924; .reg .pred %r925; .reg .u32 %r926; .reg .u32 %r929; .reg .pred %r930; .reg .pred %r931; .reg .u64 %r932; .reg .u64 %r933; .reg .pred %r934; .reg .u32 %r936; .reg .u32 %r937; .reg .pred %r938; .reg .u32 %r939; .reg .pred %r940; .reg .u32 %r941; .reg .pred %r942; .reg .u32 %r945; .reg .u64 %r946; .reg .u32 %r949; .reg .pred %r950; .reg .pred %r951; .reg .u64 %r953; .reg .u32 %r954; .reg .pred %r955; .reg .pred %r956; .reg .pred %r957; .reg .u32 %r958; .reg .u32 %r959; .reg .u32 %r960; .reg .u32 %r961; .reg .pred %r962; .reg .u64 %r963; .reg .pred %r964; .reg .u32 %r965; .reg .u32 %r966; .reg .u64 %r967; .reg .u64 %r972; .reg .u64 %r973; .reg .pred %r974; .reg .pred %r976; .reg .pred %r977; .reg .pred %r978; .reg .u32 %r980; .reg .u32 %r981; .reg .u64 %r982; .reg .u64 %r983; .reg .pred %r987; .reg .u64 %r988; .reg .u32 %r989; .reg .u32 %r990; .reg .pred %r991; .reg .u32 %r992; .reg .u32 %r993; .reg .pred %r994; .reg .u64 %r998; .reg .f64 %r999; .reg .u64 %r1002; .reg .f64 %r1003; .reg .pred %r1004; .reg .f64 %r1007; .reg .pred %r1008; .reg .pred %r1009; .reg .u64 %r1010; .reg .pred %r1011; .reg .pred %r1012; .reg .pred %r1013; .reg .pred %r1014; .reg .u64 %r1015; .reg .pred %r1016; .reg .u32 %r1017; .reg .u64 %r1018; .reg .u64 %r1019; .reg .u64 %r1020; .reg .f64 %r1023; .reg .u64 %r1025; .reg .u32 %r1026; .reg .pred %r1027; .reg .u64 %r1028; .reg .pred %r1029; .reg .u64 %r1030; .reg .u64 %r1031; .reg .u64 %r1032; .reg .u32 %r1038; .reg .u32 %r1039; .reg .u16 %r1040; .reg .u16 %r1042; .reg .u32 %r1043; .reg .u16 %r1044; .reg .pred %r1045; .reg .pred %r1046; .reg .pred %r1047; .reg .pred %r1048; .reg .u64 %r1049; .reg .u32 %r1050; .reg .u32 %r1051; .reg .u32 %r1052; .reg .u64 %r1053; .reg .u64 %r1054; .reg .u64 %r1055; .reg .f64 %r1058; .reg .f64 %r1059; .reg .u32 %r1061; .reg .u32 %r1063; .reg .u32 %r1064; .reg .u16 %r1068; .reg .u16 %r1069; .reg .u32 %r1071; .reg .u16 %r1072; .reg .pred %r1073; .reg .u32 %r1074; .reg .pred %r1075; .reg .u64 %r1076; .reg .pred %r1077; .reg .pred %r1078; .reg .pred %r1079; .reg .pred %r1080; .reg .u64 %r1083; .reg .pred %r1090; .reg .pred %r1093; .reg .u32 %r1094; .reg .pred %r1105; .reg .u64 %r1106; .reg .pred %r1107; .reg .u32 %r1109; .reg .u32 %r1110; .reg .u32 %r1111; .reg .u32 %r1112; .reg .pred %r1113; .reg .u64 %r1114; .reg .u64 %r1115; .reg .u32 %r1116; .reg .u32 %r1117; .reg .pred %r1118; .reg .u32 %r1119; .reg .u64 %r1120; .reg .u64 %r1121; .reg .pred %r1122; .reg .pred %r1123; .reg .u32 %r1124; .reg .u32 %r1125; .reg .u16 %r1126; .reg .u32 %r1127; .reg .u32 %r1128; .reg .u16 %r1129; .reg .u32 %r1130; .reg .u32 %r1131; mov.u64 %r471,%ar0; mov.u64 %r472,%ar1; mov.u64 %r473,%ar2; .loc 1 252 0 mov.u64 %r474,0; st.u64 [%frame+8],%r474; .loc 1 265 0 mov.u64 %r468,%r474; .loc 1 266 0 st.u64 [%frame+16],%r472; mov.u64 %r128,%r472; $L13: ld.s8 %r457,[%r128]; cvt.u16.u32 %r475,%r457; setp.gt.s16 %r476,%r475,13; @ %r476 bra $L8; setp.ge.s16 %r478,%r475,9; @ %r478 bra $L9; setp.eq.u16 %r480,%r475,0; @ %r480 bra $L10; bra $L173; $L8: setp.eq.u16 %r482,%r475,43; @ %r482 bra $L174; setp.eq.u16 %r484,%r475,45; @ %r484 bra $L12; setp.eq.u16 %r486,%r475,32; @ ! %r486 bra $L173; bra $L9; $L12: .loc 1 268 0 mov.u32 %r329,1; bra $L11; $L174: .loc 1 264 0 mov.u32 %r329,0; $L11: .loc 1 271 0 add.u64 %r458,%r128,1; st.u64 [%frame+16],%r458; ld.s8 %r457,[%r128+1]; setp.ne.u32 %r487,%r457,0; @ %r487 bra $L7; bra $L10; $L9: .loc 1 266 0 add.u64 %r128,%r128,1; st.u64 [%frame+16],%r128; bra $L13; $L173: mov.u64 %r458,%r128; .loc 1 264 0 mov.u32 %r329,0; $L7: .loc 1 287 0 cvt.u16.u32 %r488,%r457; setp.ne.u16 %r489,%r488,48; @ %r489 bra $L175; .loc 1 293 0 ld.s8 %r491,[%r458+1]; cvt.u16.u32 %r490,%r491; setp.eq.u16 %r492,%r490,88; @ %r492 bra $L16; setp.eq.u16 %r493,%r490,120; @ ! %r493 bra $L317; $L16: .loc 1 310 0 add.u64 %r500,%frame,8; add.u64 %r501,%frame,24; add.u64 %r502,%frame,16; cvta.const.u64 %r496,fpi$2551; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r502; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r496; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r501; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r500; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r329; call (%value_in),__gethex,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u32 %r503,[%value_in]; } and.b32 %r132,%r503,7; setp.eq.u32 %r504,%r132,0; @ %r504 bra $L176; setp.eq.u32 %r505,%r132,6; @ ! %r505 bra $L318; add.u64 %r435,%r458,1; .loc 1 1249 0 setp.eq.u64 %r506,%r473,0; @ %r506 bra $L177; .loc 1 1250 0 st.u64 [%r473],%r435; mov.f64 %r470,0d0000000000000000; bra $L6; $L318: .loc 1 318 0 ld.u64 %r133,[%frame+8]; setp.eq.u64 %r507,%r133,0; @ %r507 bra $L21; .loc 1 319 0 mov.u32 %r509,53; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r509; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r133; call __copybits,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 320 0 ld.u64 %r513,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r513; call _Bfree,(%out_arg1,%out_arg2); } $L21: .loc 1 184 0 setp.eq.u32 %r514,%r132,3; @ %r514 bra $L23; setp.gt.s32 %r515,%r132,3; @ %r515 bra $L24; setp.eq.u32 %r516,%r132,1; @ %r516 bra $L25; setp.eq.u32 %r517,%r132,2; @ %r517 bra $L26; bra $L22; $L24: setp.eq.u32 %r518,%r132,4; @ %r518 bra $L27; setp.eq.u32 %r519,%r132,5; @ ! %r519 bra $L22; bra $L25; $L26: .loc 1 192 0 ld.u32 %r523,[%frame+4]; shl.b64 %r524,%r523,32; ld.u32 %r525,[%frame]; or.b64 %r468,%r525,%r524; bra $L22; $L25: .loc 1 322 0 ld.u32 %r136,[%frame+24]; .loc 1 198 0 ld.u32 %r531,[%frame+4]; and.b32 %r530,%r531,-1048577; add.u32 %r532,%r136,1075; shl.b32 %r533,%r532,20; or.b32 %r534,%r530,%r533; cvt.u64.u32 %r535,%r534; shl.b64 %r536,%r535,32; ld.u32 %r537,[%frame]; or.b64 %r468,%r537,%r536; bra $L22; $L23: .loc 1 202 0 mov.u64 %r468,9218868437227405312; bra $L22; $L27: .loc 1 208 0 mov.u64 %r468,9223372036854775807; $L22: .loc 1 210 0 and.b32 %r541,%r503,8; setp.ne.u32 %r542,%r541,0; @ %r542 bra $L28; mov.b64 %r470,%r468; bra $L30; $L28: .loc 1 211 0 shr.u64 %r543,%r468,32; cvt.u32.u64 %r545,%r543; or.b32 %r544,%r545,-2147483648; cvt.u64.u32 %r546,%r544; shl.b64 %r547,%r546,32; and.b64 %r548,%r468,4294967295; or.b64 %r468,%r548,%r547; mov.b64 %r470,%r468; bra $L30; $L317: add.u64 %r452,%r458,1; .loc 1 329 0 bra $L29; $L176: .loc 1 310 0 mov.f64 %r470,0d0000000000000000; bra $L30; $L29: .loc 1 329 0 mov.u64 %r458,%r452; st.u64 [%frame+16],%r458; add.u64 %r452,%r458,1; ld.s8 %r457,[%r458]; cvt.u16.u32 %r550,%r457; setp.eq.u16 %r551,%r550,48; @ %r551 bra $L29; .loc 1 330 0 setp.eq.u32 %r552,%r457,0; @ %r552 bra $L178; .loc 1 328 0 mov.u32 %r328,1; bra $L14; $L175: .loc 1 264 0 mov.u32 %r328,0; $L14: .loc 1 335 0 add.u32 %r1117,%r457,-48; setp.gt.u32 %r554,%r1117,9; @ %r554 bra $L31; add.u64 %r357,%r458,1; .loc 1 334 0 mov.u32 %r333,0; mov.u32 %r332,%r333; .loc 1 335 0 mov.u32 %r290,%r333; $L34: .loc 1 336 0 setp.gt.s32 %r555,%r290,8; @ %r555 bra $L32; .loc 1 337 0 shl.b32 %r557,%r332,2; add.u32 %r558,%r557,%r332; add.u32 %r559,%r558,%r558; add.u32 %r332,%r1117,%r559; bra $L33; $L32: .loc 1 339 0 shl.b32 %r562,%r333,2; add.u32 %r563,%r562,%r333; add.u32 %r564,%r563,%r563; add.u32 %r333,%r1117,%r564; $L33: .loc 1 335 0 add.u32 %r290,%r290,1; st.u64 [%frame+16],%r357; ld.s8 %r457,[%r357]; add.u64 %r357,%r357,1; add.u32 %r1117,%r457,-48; setp.le.u32 %r567,%r1117,9; @ %r567 bra $L34; mov.u32 %r322,%r457; bra $L35; $L31: mov.u32 %r322,%r457; .loc 1 334 0 mov.u32 %r333,0; mov.u32 %r332,%r333; .loc 1 335 0 mov.u32 %r290,%r333; $L35: .loc 1 342 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r569,[%value_in]; } .loc 1 341 0 ld.u64 %r570,[%r569]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r570; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r571,[%value_in]; } { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r573,[%value_in]; } ld.u64 %r577,[%frame+16]; ld.u64 %r575,[%r573]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r577; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r575; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r571; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r578,[%value_in]; } setp.ne.u32 %r579,%r578,0; @ %r579 bra $L179; .loc 1 345 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r581,[%value_in]; } ld.u64 %r582,[%r581]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r582; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r583,[%value_in]; } ld.u64 %r584,[%frame+16]; add.u64 %r157,%r584,%r583; st.u64 [%frame+16],%r157; ld.s8 %r322,[%r157]; .loc 1 346 0 setp.ne.u32 %r585,%r290,0; @ %r585 bra $L180; .loc 1 347 0 setp.ne.u32 %r586,%r322,48; @ %r586 bra $L181; add.u64 %r336,%r157,1; .loc 1 264 0 mov.u32 %r345,%r290; $L39: .loc 1 348 0 add.u32 %r345,%r345,1; .loc 1 347 0 st.u64 [%frame+16],%r336; ld.s8 %r322,[%r336]; add.u64 %r336,%r336,1; setp.eq.u32 %r587,%r322,48; @ %r587 bra $L39; bra $L38; $L40: .loc 1 359 0 add.u32 %r356,%r345,1; .loc 1 360 0 mov.u32 %r192,%r613; ld.u64 %r358,[%frame+16]; setp.eq.u32 %r588,%r613,0; @ %r588 bra $L182; .loc 1 361 0 add.u32 %r327,%r327,%r356; .loc 1 362 0 setp.eq.u32 %r589,%r356,1; @ %r589 bra $L42; mov.u32 %r445,%r293; add.u32 %r441,%r345,%r445; $L45: .loc 1 363 0 setp.gt.s32 %r590,%r445,8; @ %r590 bra $L43; .loc 1 364 0 shl.b32 %r592,%r332,2; add.u32 %r593,%r592,%r332; add.u32 %r332,%r593,%r593; add.u32 %r1119,%r445,1; bra $L44; $L43: .loc 1 365 0 add.u32 %r1119,%r445,1; setp.gt.s32 %r596,%r1119,16; @ %r596 bra $L44; .loc 1 366 0 shl.b32 %r598,%r333,2; add.u32 %r599,%r598,%r333; add.u32 %r333,%r599,%r599; $L44: mov.u32 %r445,%r1119; .loc 1 362 0 setp.ne.u32 %r601,%r441,%r1119; @ %r601 bra $L45; mov.u32 %r416,%r441; add.u32 %r293,%r416,1; bra $L46; $L42: mov.u32 %r416,%r293; add.u32 %r293,%r293,1; $L46: .loc 1 367 0 setp.gt.s32 %r602,%r416,8; @ %r602 bra $L47; $L171: .loc 1 368 0 shl.b32 %r604,%r332,2; add.u32 %r605,%r604,%r332; add.u32 %r606,%r605,%r605; add.u32 %r332,%r192,%r606; .loc 1 371 0 mov.u32 %r345,%r578; bra $L41; $L47: mov.u32 %r345,%r578; .loc 1 369 0 setp.gt.s32 %r607,%r293,16; @ %r607 bra $L41; .loc 1 370 0 shl.b32 %r609,%r333,2; add.u32 %r610,%r609,%r333; add.u32 %r611,%r610,%r610; add.u32 %r333,%r613,%r611; .loc 1 371 0 mov.u32 %r345,%r578; bra $L41; $L182: .loc 1 359 0 mov.u32 %r345,%r356; $L41: .loc 1 357 0 add.u64 %r612,%r358,1; st.u64 [%frame+16],%r612; ld.s8 %r322,[%r358+1]; bra $L37; $L180: .loc 1 264 0 mov.u32 %r345,%r578; .loc 1 335 0 mov.u32 %r327,%r578; mov.u32 %r293,%r290; $L37: .loc 1 357 0 add.u32 %r613,%r322,-48; setp.le.u32 %r614,%r613,9; @ %r614 bra $L40; .loc 1 344 0 mov.u32 %r323,1; .loc 1 375 0 bra $L36; $L179: mov.u32 %r293,%r290; .loc 1 264 0 mov.u32 %r345,0; .loc 1 335 0 mov.u32 %r327,%r345; .loc 1 264 0 mov.u32 %r323,%r345; $L36: .loc 1 377 0 and.b32 %r615,%r322,-33; setp.ne.u32 %r616,%r615,69; @ %r616 bra $L183; .loc 1 378 0 or.b32 %r617,%r293,%r345; or.b32 %r618,%r617,%r328; setp.eq.u32 %r619,%r618,0; @ %r619 bra $L10; .loc 1 381 0 ld.u64 %r472,[%frame+16]; .loc 1 383 0 add.u64 %r620,%r472,1; st.u64 [%frame+16],%r620; ld.s8 %r181,[%r472+1]; cvt.u16.u32 %r621,%r181; setp.eq.u16 %r622,%r621,43; @ %r622 bra $L184; setp.eq.u16 %r624,%r621,45; @ %r624 bra $L52; mov.u32 %r322,%r181; .loc 1 382 0 mov.u32 %r325,0; bra $L53; $L52: .loc 1 385 0 mov.u32 %r325,1; bra $L51; $L184: .loc 1 382 0 mov.u32 %r325,0; $L51: .loc 1 387 0 add.u64 %r625,%r472,2; st.u64 [%frame+16],%r625; ld.s8 %r322,[%r472+2]; $L53: .loc 1 389 0 add.u32 %r626,%r322,-48; setp.gt.u32 %r627,%r626,9; @ %r627 bra $L54; .loc 1 390 0 setp.ne.u32 %r628,%r322,48; @ %r628 bra $L55; ld.u64 %r629,[%frame+16]; add.u64 %r129,%r629,1; $L56: .loc 1 391 0 st.u64 [%frame+16],%r129; ld.s8 %r322,[%r129]; add.u64 %r129,%r129,1; .loc 1 390 0 setp.eq.u32 %r630,%r322,48; @ %r630 bra $L56; $L55: .loc 1 392 0 add.u32 %r631,%r322,-49; setp.gt.u32 %r632,%r631,8; @ %r632 bra $L185; .loc 1 393 0 add.u32 %r361,%r322,-48; .loc 1 394 0 ld.u64 %r360,[%frame+16]; .loc 1 395 0 add.u64 %r193,%r360,1; st.u64 [%frame+16],%r193; ld.s8 %r322,[%r360+1]; add.u32 %r633,%r322,-48; setp.gt.u32 %r634,%r633,9; @ %r634 bra $L57; add.u64 %r127,%r360,2; $L58: .loc 1 396 0 shl.b32 %r636,%r361,2; add.u32 %r637,%r636,%r361; add.u32 %r638,%r637,%r637; add.u32 %r191,%r638,%r322; add.u32 %r361,%r191,-48; .loc 1 395 0 mov.u64 %r193,%r127; st.u64 [%frame+16],%r127; ld.s8 %r322,[%r127]; add.u64 %r127,%r127,1; add.u32 %r639,%r322,-48; setp.le.u32 %r640,%r639,9; @ %r640 bra $L58; $L57: .loc 1 397 0 sub.u64 %r641,%r193,%r360; set.u32.gt.s64 %r643,%r641,8; neg.s32 %r644,%r643; set.u32.gt.s32 %r646,%r361,19999; neg.s32 %r647,%r646; cvt.u16.u32 %r649,%r644; cvt.u16.u32 %r650,%r647; or.b16 %r648,%r649,%r650; cvt.u32.u16 %r651,%r648; cvt.u16.u8 %r652,%r651; setp.eq.u16 %r653,%r652,0; .loc 1 401 0 selp.u32 %r361,%r361,19999,%r653; .loc 1 404 0 setp.eq.u32 %r654,%r325,0; @ %r654 bra $L48; .loc 1 405 0 neg.s32 %r361,%r361; bra $L48; $L54: .loc 1 411 0 st.u64 [%frame+16],%r472; .loc 1 376 0 mov.u32 %r361,0; bra $L48; $L183: mov.u32 %r361,0; bra $L48; $L185: .loc 1 408 0 mov.u32 %r361,0; $L48: .loc 1 413 0 setp.ne.u32 %r655,%r293,0; @ %r655 bra $L60; .loc 1 414 0 or.b32 %r656,%r345,%r328; setp.eq.u32 %r657,%r656,0; @ %r657 bra $L61; mov.f64 %r470,0d0000000000000000; bra $L30; $L61: .loc 1 420 0 setp.ne.u32 %r658,%r323,0; @ %r658 bra $L10; .loc 1 421 0 setp.eq.u32 %r659,%r322,78; @ %r659 bra $L62; setp.gt.s32 %r660,%r322,78; @ %r660 bra $L63; setp.eq.u32 %r661,%r322,73; @ %r661 bra $L64; bra $L10; $L63: setp.eq.u32 %r662,%r322,105; @ %r662 bra $L64; setp.eq.u32 %r663,%r322,110; @ %r663 bra $L62; bra $L10; $L64: .loc 1 222 0 ld.u64 %r398,[%frame+16]; cvta.const.u64 %r344,$LC0+1; .loc 1 224 0 mov.u32 %r401,110; bra $L66; $L186: mov.u64 %r398,%r390; $L66: .loc 1 225 0 add.u64 %r390,%r398,1; ld.s8 %r400,[%r390]; add.u32 %r664,%r400,-65; setp.gt.u32 %r665,%r664,25; @ %r665 bra $L65; .loc 1 226 0 add.u32 %r400,%r400,32; $L65: .loc 1 227 0 setp.ne.u32 %r666,%r400,%r401; @ %r666 bra $L10; .loc 1 224 0 ld.s8 %r401,[%r344]; add.u64 %r344,%r344,1; setp.ne.u32 %r667,%r401,0; @ %r667 bra $L186; .loc 1 425 0 st.u64 [%frame+16],%r390; cvta.const.u64 %r375,$LC1+1; .loc 1 224 0 mov.u32 %r406,105; bra $L69; $L187: mov.u64 %r390,%r374; $L69: .loc 1 225 0 add.u64 %r374,%r390,1; ld.s8 %r405,[%r374]; add.u32 %r668,%r405,-65; setp.gt.u32 %r669,%r668,25; @ %r669 bra $L67; .loc 1 226 0 add.u32 %r405,%r405,32; $L67: .loc 1 227 0 setp.ne.u32 %r670,%r405,%r406; @ %r670 bra $L68; .loc 1 224 0 ld.s8 %r406,[%r375]; add.u64 %r375,%r375,1; setp.ne.u32 %r671,%r406,0; @ %r671 bra $L187; .loc 1 230 0 add.u64 %r672,%r390,2; st.u64 [%frame+16],%r672; bra $L70; $L68: add.u64 %r673,%r398,2; .loc 1 427 0 st.u64 [%frame+16],%r673; $L70: .loc 1 430 0 mov.u64 %r468,9218868437227405312; .loc 1 432 0 bra $L71; $L62: .loc 1 222 0 ld.u64 %r409,[%frame+16]; cvta.const.u64 %r324,$LC2+1; .loc 1 224 0 mov.u32 %r412,97; bra $L73; $L188: mov.u64 %r409,%r289; $L73: .loc 1 225 0 add.u64 %r289,%r409,1; ld.s8 %r411,[%r289]; add.u32 %r674,%r411,-65; setp.gt.u32 %r675,%r674,25; @ %r675 bra $L72; .loc 1 226 0 add.u32 %r411,%r411,32; $L72: .loc 1 227 0 setp.ne.u32 %r676,%r411,%r412; @ %r676 bra $L10; .loc 1 224 0 ld.s8 %r412,[%r324]; add.u64 %r324,%r324,1; setp.ne.u32 %r677,%r412,0; @ %r677 bra $L188; .loc 1 230 0 add.u64 %r678,%r409,2; st.u64 [%frame+16],%r678; .loc 1 439 0 ld.s8 %r680,[%r289+1]; cvt.u16.u32 %r679,%r680; setp.ne.u16 %r681,%r679,40; @ %r681 bra $L74; .loc 1 440 0 add.u64 %r685,%frame,16; cvta.const.u64 %r683,fpinan$2587; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r685; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r683; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),__hexnan,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r686,[%value_in]; } setp.ne.u32 %r687,%r686,5; @ %r687 bra $L74; .loc 1 442 0 ld.u32 %r689,[%frame+4]; or.b32 %r688,%r689,2146435072; cvt.u64.u32 %r690,%r688; .loc 1 444 0 ld.u32 %r694,[%frame]; shl.b64 %r695,%r690,32; or.b64 %r468,%r695,%r694; bra $L71; $L74: .loc 1 451 0 mov.u64 %r468,-2251799813685248; bra $L71; $L10: .loc 1 1249 0 setp.ne.u64 %r697,%r473,0; @ %r697 bra $L75; mov.f64 %r470,0d0000000000000000; bra $L6; $L75: .loc 1 1250 0 st.u64 [%r473],%r472; mov.f64 %r470,0d0000000000000000; bra $L6; $L71: mov.b64 %r470,%r468; bra $L30; $L60: .loc 1 466 0 sub.u32 %r362,%r361,%r327; .loc 1 473 0 setp.eq.u32 %r698,%r290,0; selp.u32 %r290,%r293,%r290,%r698; .loc 1 475 0 min.s32 %r363,%r293,16; .loc 1 476 0 cvt.rn.f64.u32 %r208,%r332; mov.b64 %r468,%r208; .loc 1 477 0 setp.gt.s32 %r699,%r293,9; @ %r699 bra $L77; $L80: .loc 1 492 0 setp.eq.u32 %r700,%r362,0; @ %r700 bra $L78; bra $L319; $L77: .loc 1 482 0 cvt.rn.f64.u32 %r701,%r333; cvta.const.u64 %r702,__mprec_tens; add.u32 %r703,%r363,-9; cvt.s64.s32 %r704,%r703; shl.b64 %r705,%r704,3; add.u64 %r706,%r702,%r705; ld.f64 %r708,[%r706]; fma.rn.f64 %r707,%r208,%r708,%r701; mov.b64 %r468,%r707; .loc 1 485 0 setp.le.s32 %r709,%r293,15; @ ! %r709 bra $L81; bra $L80; $L78: mov.b64 %r470,%r468; bra $L30; $L319: .loc 1 494 0 setp.le.s32 %r710,%r362,0; @ %r710 bra $L82; .loc 1 495 0 setp.gt.s32 %r711,%r362,22; @ %r711 bra $L83; .loc 1 506 0 cvta.const.u64 %r712,__mprec_tens; cvt.s64.s32 %r713,%r362; shl.b64 %r714,%r713,3; add.u64 %r715,%r712,%r714; ld.f64 %r716,[%r715]; mov.b64 %r717,%r468; mul.f64 %r470,%r716,%r717; .loc 1 507 0 bra $L30; $L83: .loc 1 511 0 mov.u32 %r719,37; sub.u32 %r718,%r719,%r293; setp.lt.s32 %r720,%r718,%r362; @ %r720 bra $L81; .loc 1 510 0 mov.u32 %r721,15; sub.u32 %r364,%r721,%r293; .loc 1 523 0 cvta.const.u64 %r722,__mprec_tens; cvt.s64.s32 %r723,%r364; shl.b64 %r724,%r723,3; add.u64 %r725,%r722,%r724; ld.f64 %r727,[%r725]; mov.b64 %r728,%r468; mul.f64 %r726,%r727,%r728; .loc 1 522 0 sub.u32 %r730,%r362,%r364; .loc 1 536 0 cvt.s64.s32 %r731,%r730; shl.b64 %r732,%r731,3; add.u64 %r733,%r722,%r732; ld.f64 %r734,[%r733]; mul.f64 %r470,%r726,%r734; .loc 1 538 0 bra $L30; $L82: .loc 1 542 0 setp.lt.s32 %r735,%r362,-22; @ %r735 bra $L81; .loc 1 550 0 cvta.const.u64 %r736,__mprec_tens; neg.s32 %r737,%r362; cvt.s64.s32 %r738,%r737; shl.b64 %r739,%r738,3; add.u64 %r740,%r736,%r739; mov.b64 %r741,%r468; ld.f64 %r742,[%r740]; div.rn.f64 %r470,%r741,%r742; .loc 1 551 0 bra $L30; $L81: .loc 1 555 0 sub.u32 %r743,%r293,%r363; add.u32 %r366,%r743,%r362; .loc 1 579 0 setp.le.s32 %r744,%r366,0; @ %r744 bra $L84; .loc 1 580 0 and.b32 %r371,%r366,15; setp.eq.u32 %r745,%r371,0; @ %r745 bra $L85; .loc 1 581 0 cvta.const.u64 %r746,__mprec_tens; cvt.s64.s32 %r747,%r371; shl.b64 %r748,%r747,3; add.u64 %r749,%r746,%r748; ld.f64 %r751,[%r749]; mov.b64 %r752,%r468; mul.f64 %r750,%r751,%r752; mov.b64 %r468,%r750; $L85: .loc 1 582 0 and.b32 %r372,%r366,-16; setp.eq.u32 %r753,%r372,0; @ %r753 bra $L86; .loc 1 583 0 setp.le.s32 %r754,%r372,308; @ %r754 bra $L87; .loc 1 586 0 mov.u32 %r755,34; st.u32 [%r471],%r755; mov.f64 %r470,0d7ff0000000000000; bra $L30; $L92: mov.u32 %r756,34; st.u32 [%r471],%r756; mov.f64 %r470,0d7ff0000000000000; bra $L30; $L87: .loc 1 626 0 shr.s32 %r377,%r372,4; .loc 1 627 0 setp.le.s32 %r757,%r377,1; @ %r757 bra $L190; mov.b64 %r131,%r468; cvta.const.u64 %r1115,__mprec_bigtens; mov.u64 %r298,%r1115; mov.u32 %r146,0; mov.u32 %r376,%r146; .loc 1 629 0 mov.u32 %r1130,1; $L90: .loc 1 628 0 and.b32 %r758,%r377,1; setp.eq.u32 %r759,%r758,0; @ %r759 bra $L89; .loc 1 629 0 ld.f64 %r760,[%r298]; mul.f64 %r131,%r131,%r760; mov.u32 %r146,%r1130; $L89: .loc 1 627 0 add.u32 %r376,%r376,1; shr.s32 %r377,%r377,1; add.u64 %r298,%r298,8; setp.ne.u32 %r761,%r377,1; @ %r761 bra $L90; setp.eq.u32 %r762,%r146,0; @ %r762 bra $L88; mov.b64 %r468,%r131; bra $L88; $L190: mov.u32 %r376,0; cvta.const.u64 %r1115,__mprec_bigtens; $L88: .loc 1 631 0 shr.u64 %r763,%r468,32; cvt.u32.u64 %r765,%r763; add.u32 %r764,%r765,-55574528; cvt.u64.u32 %r766,%r764; shl.b64 %r767,%r766,32; and.b64 %r768,%r468,4294967295; or.b64 %r468,%r768,%r767; .loc 1 632 0 cvt.s64.s32 %r771,%r376; shl.b64 %r772,%r771,3; add.u64 %r773,%r1115,%r772; ld.f64 %r774,[%r773]; mov.b64 %r775,%r468; mul.f64 %r233,%r774,%r775; mov.b64 %r468,%r233; shr.u64 %r777,%r468,32; cvt.u32.u64 %r351,%r777; .loc 1 633 0 and.b32 %r373,%r351,2146435072; setp.gt.u32 %r778,%r373,2090860544; @ %r778 bra $L92; .loc 1 636 0 setp.le.u32 %r779,%r373,2089811968; @ %r779 bra $L93; .loc 1 641 0 mov.u64 %r468,9218868437227405311; .loc 1 564 0 mov.u32 %r316,0; bra $L94; $L93: .loc 1 645 0 add.u32 %r780,%r351,55574528; cvt.u64.u32 %r781,%r780; shl.b64 %r782,%r781,32; and.b64 %r783,%r468,4294967295; or.b64 %r468,%r783,%r782; .loc 1 564 0 mov.u32 %r316,0; bra $L94; $L84: .loc 1 648 0 setp.eq.u32 %r785,%r366,0; @ %r785 bra $L86; .loc 1 649 0 neg.s32 %r367,%r366; .loc 1 650 0 and.b32 %r368,%r367,15; setp.eq.u32 %r786,%r368,0; @ %r786 bra $L95; .loc 1 651 0 cvta.const.u64 %r787,__mprec_tens; cvt.s64.s32 %r788,%r368; shl.b64 %r789,%r788,3; add.u64 %r790,%r787,%r789; mov.b64 %r792,%r468; ld.f64 %r793,[%r790]; div.rn.f64 %r791,%r792,%r793; mov.b64 %r468,%r791; $L95: .loc 1 652 0 shr.s32 %r370,%r367,4; setp.eq.u32 %r794,%r370,0; @ %r794 bra $L86; .loc 1 653 0 setp.gt.s32 %r795,%r370,31; @ %r795 bra $L96; .loc 1 656 0 and.b32 %r316,%r370,16; setp.ne.u32 %r796,%r316,0; @ %r796 bra $L97; .loc 1 658 0 setp.gt.s32 %r797,%r370,0; @ %r797 bra $L98; $L104: .loc 1 564 0 mov.u32 %r316,0; bra $L99; $L97: .loc 1 658 0 setp.le.s32 %r798,%r370,0; @ %r798 bra $L191; .loc 1 657 0 mov.u32 %r316,106; $L98: mov.b64 %r174,%r468; cvta.const.u64 %r454,tinytens; mov.u32 %r415,0; .loc 1 660 0 mov.u32 %r1131,1; $L102: .loc 1 659 0 and.b32 %r799,%r370,1; setp.eq.u32 %r800,%r799,0; @ %r800 bra $L101; .loc 1 660 0 ld.f64 %r801,[%r454]; mul.f64 %r174,%r174,%r801; mov.u32 %r415,%r1131; $L101: .loc 1 658 0 shr.s32 %r370,%r370,1; add.u64 %r454,%r454,8; setp.ne.u32 %r802,%r370,0; @ %r802 bra $L102; setp.eq.u32 %r803,%r415,0; @ %r803 bra $L103; mov.b64 %r468,%r174; $L103: .loc 1 661 0 setp.eq.u32 %r804,%r316,0; @ %r804 bra $L104; bra $L100; $L191: .loc 1 657 0 mov.u32 %r316,106; $L100: .loc 1 661 0 shr.u64 %r1114,%r468,32; cvt.u32.u64 %r240,%r1114; .loc 1 662 0 shr.u32 %r806,%r240,20; and.b32 %r807,%r806,2047; .loc 1 661 0 mov.u32 %r808,107; sub.u32 %r369,%r808,%r807; setp.le.s32 %r809,%r369,0; @ %r809 bra $L99; .loc 1 664 0 setp.le.s32 %r810,%r369,31; @ %r810 bra $L105; .loc 1 666 0 and.b64 %r468,%r468,-4294967296; .loc 1 668 0 setp.le.s32 %r812,%r369,52; @ %r812 bra $L106; .loc 1 669 0 mov.u64 %r468,247697979505377280; bra $L99; $L106: .loc 1 671 0 add.u32 %r815,%r369,-32; mov.u32 %r817,-1; shl.b32 %r816,%r817,%r815; and.b32 %r818,%r816,%r240; cvt.u64.u32 %r819,%r818; shl.b64 %r820,%r819,32; and.b64 %r821,%r468,4294967295; or.b64 %r468,%r821,%r820; bra $L99; $L105: .loc 1 675 0 mov.u32 %r824,-1; shl.b32 %r823,%r824,%r369; cvt.u32.u64 %r826,%r468; and.b32 %r825,%r823,%r826; cvt.u64.u32 %r827,%r825; and.b64 %r828,%r468,-4294967296; or.b64 %r468,%r828,%r827; $L99: .loc 1 689 0 mov.b64 %r830,%r468; setp.neu.f64 %r831,%r830,0d0000000000000000; @ %r831 bra $L94; $L96: .loc 1 693 0 mov.u32 %r832,34; st.u32 [%r471],%r832; mov.f64 %r470,0d0000000000000000; bra $L30; $L86: .loc 1 564 0 mov.u32 %r316,0; $L94: .loc 1 718 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r458; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r290; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r293; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r332; call (%value_in),__s2b,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r838,[%value_in]; } .loc 1 719 0 setp.eq.u64 %r839,%r838,0; @ %r839 bra $L107; setp.ge.s32 %r841,%r362,0; @ %r841 bra $L108; .loc 1 739 0 neg.s32 %r840,%r362; bra $L109; $L108: mov.u32 %r840,0; $L109: max.s32 %r168,%r362,0; .loc 1 263 0 mov.u64 %r338,0; mov.u64 %r337,%r338; .loc 1 726 0 add.u64 %r1120,%r838,16; .loc 1 727 0 add.u64 %r1121,%frame,24; .loc 1 794 0 setp.eq.u32 %r1122,%r840,0; .loc 1 809 0 setp.gt.s32 %r1123,%r362,0; .loc 1 1187 0 set.u32.eq.u32 %r1124,%r316,0; neg.s32 %r1125,%r1124; .loc 1 1189 0 cvt.u16.u32 %r1126,%r1125; .loc 1 1124 0 set.u32.ne.u32 %r1127,%r316,0; neg.s32 %r1128,%r1127; cvt.u16.u32 %r1129,%r1128; $L167: .loc 1 723 0 ld.u32 %r844,[%r838+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r844; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r845,[%value_in]; } mov.u64 %r335,%r845; .loc 1 724 0 setp.eq.u64 %r846,%r335,0; @ %r846 bra $L110; .loc 1 726 0 ld.s32 %r850,[%r838+20]; add.u64 %r851,%r850,2; shl.b64 %r852,%r851,2; add.u64 %r854,%r335,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r854; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1120; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r852; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r855,[%value_in]; } .loc 1 727 0 mov.b64 %r258,%r468; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r258; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1121; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call (%value_in),__d2b,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r861,[%value_in]; } mov.u64 %r456,%r861; st.u64 [%frame+8],%r456; .loc 1 728 0 setp.eq.u64 %r862,%r456,0; @ %r862 bra $L111; .loc 1 730 0 mov.u32 %r864,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r864; call (%value_in),__i2b,(%out_arg1,%out_arg2); ld.param.u64 %r865,[%value_in]; } mov.u64 %r337,%r865; .loc 1 731 0 setp.ne.u64 %r866,%r337,0; @ %r866 bra $L112; ld.u64 %r456,[%frame+8]; bra $L111; $L112: .loc 1 742 0 ld.u32 %r259,[%frame+24]; setp.lt.s32 %r867,%r259,0; @ %r867 bra $L113; .loc 1 743 0 add.u32 %r318,%r259,%r840; mov.u32 %r320,%r168; bra $L114; $L113: .loc 1 745 0 sub.u32 %r320,%r168,%r259; mov.u32 %r318,%r840; $L114: .loc 1 755 0 ld.u32 %r260,[%frame]; .loc 1 754 0 sub.u32 %r868,%r259,%r316; .loc 1 755 0 add.u32 %r869,%r868,%r260; add.u32 %r381,%r869,-1; .loc 1 756 0 mov.u32 %r870,54; sub.u32 %r326,%r870,%r260; .loc 1 757 0 setp.ge.s32 %r871,%r381,-1022; @ %r871 bra $L192; .loc 1 758 0 mov.u32 %r872,-1022; sub.u32 %r382,%r872,%r381; .loc 1 759 0 sub.u32 %r326,%r326,%r382; .loc 1 760 0 setp.gt.s32 %r873,%r382,31; @ %r873 bra $L116; .loc 1 761 0 mov.u32 %r874,1; shl.b32 %r339,%r874,%r382; .loc 1 753 0 mov.u32 %r340,0; bra $L115; $L116: .loc 1 763 0 mov.u32 %r876,-1054; sub.u32 %r875,%r876,%r381; mov.u32 %r877,1; shl.b32 %r340,%r877,%r875; .loc 1 752 0 mov.u32 %r339,%r877; bra $L115; $L192: .loc 1 753 0 mov.u32 %r340,0; .loc 1 752 0 mov.u32 %r339,1; $L115: .loc 1 781 0 add.u32 %r319,%r318,%r326; .loc 1 782 0 add.u32 %r383,%r320,%r326; .loc 1 784 0 add.u32 %r321,%r316,%r383; min.s32 %r878,%r318,%r319; min.s32 %r170,%r878,%r321; .loc 1 789 0 setp.le.s32 %r879,%r170,0; @ %r879 bra $L117; .loc 1 790 0 sub.u32 %r319,%r319,%r170; .loc 1 791 0 sub.u32 %r321,%r321,%r170; .loc 1 792 0 sub.u32 %r318,%r318,%r170; $L117: .loc 1 794 0 @ %r1122 bra $L118; .loc 1 795 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r865; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r840; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r884,[%value_in]; } mov.u64 %r337,%r884; .loc 1 796 0 setp.ne.u64 %r885,%r337,0; @ %r885 bra $L119; ld.u64 %r456,[%frame+8]; bra $L111; $L119: .loc 1 798 0 ld.u64 %r889,[%frame+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r889; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r890,[%value_in]; } .loc 1 799 0 setp.ne.u64 %r891,%r890,0; @ %r891 bra $L120; ld.u64 %r456,[%frame+8]; bra $L111; $L120: .loc 1 801 0 ld.u64 %r894,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r894; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 802 0 st.u64 [%frame+8],%r890; $L118: .loc 1 804 0 setp.gt.s32 %r895,%r319,0; @ %r895 bra $L121; $L124: .loc 1 809 0 @ ! %r1123 bra $L123; bra $L122; $L121: .loc 1 805 0 ld.u64 %r900,[%frame+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r900; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r319; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r901,[%value_in]; } mov.u64 %r456,%r901; st.u64 [%frame+8],%r456; .loc 1 806 0 setp.eq.u64 %r902,%r456,0; @ ! %r902 bra $L124; .loc 1 584 0 bra $L111; $L122: .loc 1 810 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r845; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r168; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r906,[%value_in]; } mov.u64 %r335,%r906; .loc 1 811 0 setp.ne.u64 %r907,%r335,0; @ %r907 bra $L123; ld.u64 %r456,[%frame+8]; bra $L111; $L123: .loc 1 814 0 setp.le.s32 %r908,%r321,0; @ %r908 bra $L125; .loc 1 815 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r335; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r321; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r912,[%value_in]; } mov.u64 %r335,%r912; .loc 1 816 0 setp.ne.u64 %r913,%r335,0; @ %r913 bra $L125; ld.u64 %r456,[%frame+8]; bra $L111; $L125: .loc 1 819 0 setp.le.s32 %r914,%r318,0; @ %r914 bra $L126; .loc 1 820 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r318; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r918,[%value_in]; } mov.u64 %r337,%r918; .loc 1 821 0 setp.ne.u64 %r919,%r337,0; @ %r919 bra $L126; ld.u64 %r456,[%frame+8]; bra $L111; $L126: .loc 1 824 0 ld.u64 %r923,[%frame+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r923; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r335; call (%value_in),__mdiff,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r924,[%value_in]; } mov.u64 %r338,%r924; .loc 1 825 0 setp.ne.u64 %r925,%r338,0; @ %r925 bra $L127; ld.u64 %r456,[%frame+8]; bra $L111; $L127: .loc 1 827 0 ld.u32 %r385,[%r924+16]; .loc 1 828 0 mov.u32 %r926,0; st.u32 [%r924+16],%r926; .loc 1 829 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r924; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r929,[%value_in]; } .loc 1 923 0 setp.ge.s32 %r930,%r929,0; @ %r930 bra $L128; .loc 1 927 0 setp.ne.u32 %r931,%r385,0; @ %r931 bra $L129; mov.b64 %r933,%r258; and.b64 %r932,%r933,4503599627370495; setp.ne.u64 %r934,%r932,0; @ %r934 bra $L129; .loc 1 930 0 shr.u64 %r1114,%r468,32; cvt.u32.u64 %r937,%r1114; and.b32 %r936,%r937,2146435072; setp.le.u32 %r938,%r936,112197632; @ %r938 bra $L129; .loc 1 942 0 ld.u32 %r939,[%r924+24]; setp.ne.u32 %r940,%r939,0; @ %r940 bra $L130; ld.u32 %r941,[%r924+20]; setp.le.s32 %r942,%r941,1; @ %r942 bra $L129; $L130: .loc 1 949 0 mov.u32 %r945,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r924; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r945; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r946,[%value_in]; } mov.u64 %r338,%r946; .loc 1 950 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r338; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r949,[%value_in]; } setp.gt.s32 %r950,%r949,0; @ %r950 bra $L131; bra $L129; $L128: .loc 1 954 0 setp.ne.u32 %r951,%r929,0; @ %r951 bra $L132; .loc 1 956 0 setp.eq.u32 %r1118,%r385,0; @ %r1118 bra $L133; .loc 1 957 0 shr.u64 %r953,%r468,32; cvt.u32.u64 %r273,%r953; and.b32 %r954,%r273,1048575; setp.ne.u32 %r955,%r954,1048575; @ %r955 bra $L134; .loc 1 958 0 cvt.u32.u64 %r275,%r468; .loc 1 961 0 setp.eq.u32 %r956,%r316,0; @ %r956 bra $L193; .loc 1 960 0 and.b32 %r394,%r273,2146435072; setp.gt.u32 %r957,%r394,111149056; @ %r957 bra $L194; .loc 1 961 0 shr.u32 %r958,%r394,20; mov.u32 %r960,107; sub.u32 %r959,%r960,%r958; mov.u32 %r961,-1; shl.b32 %r341,%r961,%r959; bra $L135; $L193: mov.u32 %r341,-1; bra $L135; $L194: mov.u32 %r341,-1; $L135: .loc 1 958 0 setp.ne.u32 %r962,%r275,%r341; @ %r962 bra $L134; .loc 1 965 0 mov.b64 %r963,%r258; setp.ne.u64 %r964,%r963,9218868437227405311; @ %r964 bra $L136; ld.u64 %r456,[%frame+8]; bra $L111; $L136: .loc 1 967 0 and.b32 %r965,%r273,2146435072; .loc 1 968 0 add.u32 %r966,%r965,1048576; .loc 1 967 0 cvt.u64.u32 %r967,%r966; .loc 1 974 0 shl.b64 %r468,%r967,32; mov.b64 %r258,%r468; .loc 1 979 0 bra $L129; $L133: .loc 1 982 0 mov.b64 %r973,%r258; and.b64 %r972,%r973,4503599627370495; setp.ne.u64 %r974,%r972,0; @ %r974 bra $L134; shr.u64 %r1114,%r468,32; $L131: cvt.u32.u64 %r446,%r1114; .loc 1 1000 0 setp.eq.u32 %r976,%r316,0; @ ! %r976 bra $L320; and.b32 %r1116,%r446,2146435072; bra $L137; $L320: .loc 1 1001 0 and.b32 %r1116,%r446,2146435072; .loc 1 1002 0 setp.gt.s32 %r977,%r1116,112197632; @ %r977 bra $L137; .loc 1 1003 0 setp.gt.s32 %r978,%r1116,57671680; @ %r978 bra $L138; bra $L139; $L137: .loc 1 1012 0 add.u32 %r980,%r1116,-1048576; .loc 1 1014 0 or.b32 %r981,%r980,1048575; cvt.u64.u32 %r982,%r981; shl.b64 %r983,%r982,32; .loc 1 1016 0 or.b64 %r468,%r983,4294967295; mov.b64 %r258,%r468; .loc 1 1021 0 bra $L129; $L134: .loc 1 1026 0 setp.eq.u32 %r987,%r340,0; @ %r987 bra $L140; .loc 1 1027 0 shr.u64 %r988,%r468,32; cvt.u32.u64 %r990,%r988; and.b32 %r989,%r340,%r990; setp.eq.u32 %r991,%r989,0; @ %r991 bra $L129; bra $L141; $L140: .loc 1 1030 0 cvt.u32.u64 %r993,%r468; and.b32 %r992,%r339,%r993; setp.eq.u32 %r994,%r992,0; @ %r994 bra $L129; $L141: .loc 1 1037 0 @ %r1118 bra $L142; .loc 1 1039 0 st.u64 [%frame+32],%r468; add.u64 %r998,%frame,32; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r998; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r316; call (%value_in),sulp,(%out_arg1,%out_arg2); ld.param.f64 %r999,[%value_in]; } add.f64 %r258,%r258,%r999; mov.b64 %r468,%r258; bra $L129; $L142: .loc 1 1046 0 st.u64 [%frame+32],%r468; add.u64 %r1002,%frame,32; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1002; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r316; call (%value_in),sulp,(%out_arg1,%out_arg2); ld.param.f64 %r1003,[%value_in]; } sub.f64 %r258,%r258,%r1003; mov.b64 %r468,%r258; .loc 1 1051 0 setp.eq.f64 %r1004,%r258,0d0000000000000000; @ %r1004 bra $L139; bra $L129; $L132: .loc 1 1061 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r924; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call (%value_in),__ratio,(%out_arg1,%out_arg2); ld.param.f64 %r1007,[%value_in]; } setp.le.f64 %r1008,%r1007,0d4000000000000000; @ ! %r1008 bra $L321; .loc 1 1062 0 setp.eq.u32 %r1009,%r385,0; @ %r1009 bra $L145; .loc 1 1063 0 mov.u64 %r467,4607182418800017408; mov.f64 %r331,0d3ff0000000000000; bra $L146; $L145: mov.b64 %r354,%r258; .loc 1 1064 0 and.b64 %r1010,%r354,4503599627370495; setp.eq.u64 %r1011,%r1010,0; @ %r1011 bra $L147; .loc 1 1066 0 setp.eq.u64 %r1012,%r354,1; @ %r1012 bra $L139; .loc 1 1070 0 mov.u64 %r467,-4616189618054758400; .loc 1 1069 0 mov.f64 %r331,0d3ff0000000000000; bra $L146; $L147: .loc 1 1076 0 setp.lt.f64 %r1013,%r1007,0d3ff0000000000000; @ %r1013 bra $L195; .loc 1 1079 0 mul.f64 %r331,%r1007,0d3fe0000000000000; neg.f64 %r447,%r331; bra $L148; $L195: mov.f64 %r447,0dbfe0000000000000; .loc 1 1077 0 mov.f64 %r331,0d3fe0000000000000; $L148: .loc 1 1080 0 mov.b64 %r467,%r447; bra $L146; $L321: .loc 1 1084 0 mul.f64 %r331,%r1007,0d3fe0000000000000; .loc 1 1085 0 setp.ne.u32 %r1014,%r385,0; @ %r1014 bra $L196; neg.f64 %r342,%r331; bra $L149; $L196: mov.f64 %r342,%r331; $L149: mov.b64 %r467,%r342; $L146: .loc 1 1100 0 shr.u64 %r1015,%r468,32; cvt.u32.u64 %r292,%r1015; and.b32 %r388,%r292,2146435072; .loc 1 1104 0 setp.ne.u32 %r1016,%r388,2145386496; @ %r1016 bra $L150; .loc 1 1106 0 add.u32 %r1017,%r292,-55574528; cvt.u64.u32 %r1018,%r1017; shl.b64 %r1019,%r1018,32; and.b64 %r1020,%r468,4294967295; or.b64 %r468,%r1020,%r1019; .loc 1 1107 0 mov.b64 %r295,%r467; mov.b64 %r296,%r468; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r296; call (%value_in),__ulp,(%out_arg1); ld.param.f64 %r1023,[%value_in]; } .loc 1 1108 0 fma.rn.f64 %r299,%r295,%r1023,%r296; mov.b64 %r468,%r299; shr.u64 %r1025,%r468,32; cvt.u32.u64 %r355,%r1025; .loc 1 1109 0 and.b32 %r1026,%r355,2146435072; setp.le.u32 %r1027,%r1026,2090860543; @ %r1027 bra $L151; .loc 1 1111 0 mov.b64 %r1028,%r258; setp.ne.u64 %r1029,%r1028,9218868437227405311; @ %r1029 bra $L152; ld.u64 %r456,[%frame+8]; bra $L111; $L152: .loc 1 1115 0 mov.u64 %r468,9218868437227405311; .loc 1 1117 0 bra $L153; $L151: .loc 1 1120 0 add.u32 %r455,%r355,55574528; cvt.u64.u32 %r1030,%r455; shl.b64 %r1031,%r1030,32; and.b64 %r1032,%r468,4294967295; or.b64 %r468,%r1032,%r1031; bra $L154; $L150: .loc 1 1124 0 set.u32.le.u32 %r1038,%r388,111149056; neg.s32 %r1039,%r1038; cvt.u16.u32 %r1042,%r1039; and.b16 %r1040,%r1129,%r1042; cvt.u32.u16 %r1043,%r1040; cvt.u16.u8 %r1044,%r1043; setp.eq.u16 %r1045,%r1044,0; @ %r1045 bra $L155; .loc 1 1125 0 setp.le.f64 %r1046,%r331,0d41dfffffffc00000; @ ! %r1046 bra $L156; .loc 1 1126 0 cvt.rzi.u32.f64 %r389,%r331; setp.eq.u32 %r1047,%r389,0; @ %r1047 bra $L197; cvt.rn.f64.u32 %r331,%r389; bra $L158; $L197: mov.f64 %r331,0d3ff0000000000000; $L158: .loc 1 1129 0 setp.ne.u32 %r1048,%r385,0; @ %r1048 bra $L198; neg.f64 %r343,%r331; bra $L159; $L198: mov.f64 %r343,%r331; $L159: mov.b64 %r467,%r343; $L156: .loc 1 1131 0 shr.u64 %r1049,%r467,32; cvt.u32.u64 %r1051,%r1049; add.u32 %r1050,%r1051,112197632; sub.u32 %r1052,%r1050,%r388; cvt.u64.u32 %r1053,%r1052; shl.b64 %r1054,%r1053,32; and.b64 %r1055,%r467,4294967295; or.b64 %r467,%r1055,%r1054; $L155: .loc 1 1133 0 mov.b64 %r306,%r467; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r258; call (%value_in),__ulp,(%out_arg1); ld.param.f64 %r1058,[%value_in]; } .loc 1 1134 0 fma.rn.f64 %r1059,%r306,%r1058,%r258; mov.b64 %r468,%r1059; shr.u64 %r1114,%r468,32; cvt.u32.u64 %r455,%r1114; $L154: .loc 1 1184 0 and.b32 %r1061,%r455,2146435072; .loc 1 1189 0 set.u32.eq.u32 %r1063,%r1061,%r388; neg.s32 %r1064,%r1063; cvt.u16.u32 %r1069,%r1064; and.b16 %r1068,%r1069,%r1126; cvt.u32.u16 %r1071,%r1068; cvt.u16.u8 %r1072,%r1071; setp.eq.u16 %r1073,%r1072,0; @ %r1073 bra $L153; .loc 1 1191 0 cvt.rzi.s32.f64 %r1074,%r331; .loc 1 1192 0 cvt.rn.f64.s32 %r309,%r1074; sub.f64 %r393,%r331,%r309; .loc 1 1194 0 setp.ne.u32 %r1075,%r385,0; @ %r1075 bra $L160; and.b64 %r1076,%r468,4503599627370495; setp.eq.u64 %r1077,%r1076,0; @ %r1077 bra $L161; $L160: .loc 1 1195 0 setp.lt.f64 %r1078,%r393,0d3fdfffff94a03595; @ ! %r1078 bra $L322; ld.u64 %r456,[%frame+8]; bra $L164; $L322: setp.gt.f64 %r1079,%r393,0d3fe0000035afe535; @ ! %r1079 bra $L153; ld.u64 %r456,[%frame+8]; bra $L164; $L161: .loc 1 1198 0 setp.lt.f64 %r1080,%r393,0d3fcfffff94a03595; @ ! %r1080 bra $L153; ld.u64 %r456,[%frame+8]; bra $L164; $L153: .loc 1 1203 0 ld.u64 %r1083,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1083; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1204 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r335; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1205 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1206 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r924; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 723 0 bra $L167; $L129: .loc 1 1222 0 setp.ne.u32 %r1090,%r316,0; @ %r1090 bra $L138; ld.u64 %r456,[%frame+8]; bra $L164; $L138: .loc 1 1227 0 mul.f64 %r314,%r258,0d3950000000000000; mov.b64 %r468,%r314; .loc 1 1230 0 setp.eq.u64 %r1093,%r468,0; @ %r1093 bra $L168; ld.u64 %r456,[%frame+8]; bra $L164; $L168: .loc 1 1231 0 mov.u32 %r1094,34; st.u32 [%r471],%r1094; ld.u64 %r456,[%frame+8]; $L164: .loc 1 1243 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r456; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1244 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r335; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1245 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1246 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r838; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1247 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r338; call _Bfree,(%out_arg1,%out_arg2); } mov.b64 %r470,%r468; bra $L30; $L178: .loc 1 1248 0 mov.f64 %r470,0d0000000000000000; $L30: .loc 1 1249 0 setp.eq.u64 %r1105,%r473,0; @ %r1105 bra $L169; .loc 1 1250 0 ld.u64 %r1106,[%frame+16]; st.u64 [%r473],%r1106; $L169: .loc 1 1251 0 setp.eq.u32 %r1107,%r329,0; @ %r1107 bra $L6; neg.f64 %r470,%r470; bra $L6; $L177: .loc 1 1249 0 mov.f64 %r470,0d0000000000000000; .loc 1 1251 0 bra $L6; $L107: .loc 1 586 0 mov.u32 %r1109,34; st.u32 [%r471],%r1109; mov.f64 %r470,0d7ff0000000000000; bra $L30; $L110: ld.u64 %r456,[%frame+8]; $L111: mov.u32 %r1110,34; st.u32 [%r471],%r1110; .loc 1 608 0 mov.u64 %r468,9218868437227405312; bra $L164; $L139: .loc 1 691 0 mov.u64 %r468,0; .loc 1 693 0 mov.u32 %r1111,34; st.u32 [%r471],%r1111; ld.u64 %r456,[%frame+8]; bra $L164; $L172: .loc 1 350 0 ld.u64 %r458,[%frame+16]; .loc 1 360 0 add.u32 %r192,%r322,-48; .loc 1 361 0 add.u32 %r327,%r345,1; .loc 1 350 0 mov.u64 %r358,%r458; .loc 1 361 0 mov.u32 %r293,1; bra $L171; $L181: .loc 1 264 0 mov.u32 %r345,%r290; $L38: .loc 1 349 0 add.u32 %r1112,%r322,-49; setp.le.u32 %r1113,%r1112,8; @ %r1113 bra $L172; .loc 1 335 0 mov.u32 %r327,%r290; .loc 1 349 0 mov.u32 %r293,%r290; .loc 1 344 0 mov.u32 %r323,1; bra $L36; $L6: .loc 1 1252 0 mov.f64 %value,%r470; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtod .visible .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r29; .reg .f64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 1260 0 ld.global.u64 %r29,[_impure_ptr]; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),_strtod_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r30,[%value_in]; } .loc 1 1261 0 mov.f64 %value,%r30; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtof .visible .func (.param .f32 %value_out) strtof (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r31; .reg .f64 %r32; .reg .u32 %r34; .reg .pred %r35; .reg .u64 %r36; .reg .f32 %r37; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 1268 0 ld.global.u64 %r31,[_impure_ptr]; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),_strtod_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r32,[%value_in]; } .loc 1 1269 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r34,[%value_in]; } setp.ne.u32 %r35,%r34,0; @ %r35 bra $L325; .loc 1 1270 0 mov.u64 %r36,0; { .param .f32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r36; call (%value_in),nanf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r25,%r37; bra $L324; $L325: .loc 1 1271 0 cvt.rn.f32.f64 %r25,%r32; $L324: .loc 1 1272 0 mov.f32 %value,%r25; st.param.f32 [%value_out],%value; ret; } lib_a-strtok.o/ 0 0 0 644 1399 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtok .visible .func (.param .u64 %value_out) strtok (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/string/strtok.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __strtok_r .extern .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strtok .visible .func (.param .u64 %value_out) strtok (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r25; .reg .u64 %r26; .reg .u32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; .loc 1 103 0 ld.global.u64 %r32,[_impure_ptr]; add.u64 %r31,%r32,152; mov.u32 %r30,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r31; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r30; call (%value_in),__strtok_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r33,[%value_in]; } .loc 1 104 0 mov.u64 %value,%r33; st.param.u64 [%value_out],%value; ret; } /752 0 0 0 644 3635 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __strtok_r .visible .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../newlib/libc/string/strtok_r.c" // BEGIN GLOBAL FUNCTION DECL: strtok_r .visible .func (.param .u64 %value_out) strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: __strtok_r .visible .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %r49; .reg .u32 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u64 %r61; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .u32 %r74; .reg .pred %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u16 %r78; .reg .u16 %r79; .reg .pred %r80; .reg .pred %r81; .reg .u32 %r82; .reg .pred %r83; .reg .pred %r85; mov.u64 %r66,%ar0; mov.u64 %r67,%ar1; mov.u64 %r68,%ar2; mov.u32 %r69,%ar3; .loc 1 44 0 setp.ne.u64 %r70,%r66,0; @ %r70 bra $L2; ld.u64 %r66,[%r68]; setp.eq.u64 %r71,%r66,0; @ %r71 bra $L11; $L2: mov.u64 %r56,%r66; .loc 1 54 0 setp.ne.u32 %r85,%r69,0; $L5: mov.u64 %r65,%r56; add.u64 %r56,%r56,1; .loc 1 51 0 ld.s8 %r57,[%r65]; .loc 1 52 0 mov.u64 %r61,%r67; bra $L4; $L6: add.u64 %r61,%r61,1; .loc 1 53 0 setp.ne.u32 %r72,%r57,%r58; @ %r72 bra $L4; .loc 1 54 0 @ %r85 bra $L5; .loc 1 58 0 st.u64 [%r68],%r56; .loc 1 59 0 mov.u32 %r74,0; st.u8 [%r65],%r74; .loc 1 60 0 bra $L1; $L4: .loc 1 52 0 ld.s8 %r58,[%r61]; setp.ne.u32 %r75,%r58,0; @ %r75 bra $L6; .loc 1 65 0 setp.ne.u32 %r76,%r57,0; @ %r76 bra $L7; .loc 1 66 0 mov.u64 %r77,0; st.u64 [%r68],%r77; .loc 1 67 0 mov.u64 %r65,%r77; bra $L1; $L7: mov.u64 %r54,%r56; add.u64 %r56,%r56,1; mov.u64 %r55,%r56; .loc 1 76 0 ld.s8 %r52,[%r54]; mov.u64 %r49,%r67; .loc 1 79 0 cvt.u16.u32 %r78,%r52; $L10: ld.s8 %r53,[%r49]; cvt.u16.u32 %r79,%r53; setp.ne.u16 %r80,%r78,%r79; @ %r80 bra $L8; .loc 1 80 0 setp.eq.u32 %r81,%r53,0; @ %r81 bra $L12; .loc 1 83 0 mov.u32 %r82,0; st.u8 [%r54],%r82; bra $L9; $L12: .loc 1 81 0 mov.u64 %r55,0; $L9: .loc 1 84 0 st.u64 [%r68],%r55; .loc 1 85 0 bra $L1; $L8: add.u64 %r49,%r49,1; .loc 1 87 0 setp.ne.u32 %r83,%r53,0; @ %r83 bra $L10; bra $L7; $L11: .loc 1 45 0 mov.u64 %r65,%r66; $L1: .loc 1 90 0 mov.u64 %value,%r65; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtok_r .visible .func (.param .u64 %value_out) strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r29; .reg .u64 %r30; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 98 0 mov.u32 %r29,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r29; call (%value_in),__strtok_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 99 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } lib_a-strtol.o/ 0 0 0 644 7498 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtol_r .visible .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../newlib/libc/stdlib/strtol.c" // BEGIN GLOBAL FUNCTION DECL: strtol .visible .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtol_r .visible .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r81; .reg .u32 %r82; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u16 %r127; .reg .u16 %r128; .reg .u32 %r129; .reg .u16 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .u16 %r133; .reg .u32 %r135; .reg .pred %r136; .reg .u16 %r137; .reg .pred %r138; .reg .pred %r139; .reg .u32 %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u16 %r146; .reg .u16 %r147; .reg .u16 %r148; .reg .u32 %r149; .reg .u16 %r150; .reg .pred %r151; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r156; .reg .u32 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u16 %r160; .reg .u32 %r161; .reg .u16 %r162; .reg .pred %r163; .reg .u64 %r164; .reg .pred %r165; .reg .u32 %r166; .reg .pred %r167; .reg .pred %r169; .reg .pred %r170; .reg .pred %r172; .reg .u32 %r173; .reg .pred %r174; .reg .pred %r175; .reg .u32 %r177; .reg .u32 %r178; .reg .u16 %r179; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 153 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r85,%r95; $L2: mov.u64 %r75,%r85; add.u64 %r62,%r85,1; mov.u64 %r85,%r62; .loc 1 152 0 ld.u8 %r49,[%r75]; .loc 1 153 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r179,[%r100+1]; mov.u16 %r104,%r179; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 154 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 156 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 155 0 mov.u32 %r91,1; bra $L4; $L3: .loc 1 157 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 152 0 mov.u32 %r78,%r49; .loc 1 144 0 mov.u32 %r91,0; bra $L4; $L5: .loc 1 158 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 144 0 mov.u32 %r91,0; bra $L4; $L21: .loc 1 159 0 setp.ne.u32 %r113,%r78,48; @ %r113 bra $L6; .loc 1 160 0 ld.u8 %r179,[%r62]; mov.u16 %r116,%r179; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 161 0 ld.u8 %r78,[%r62+1]; .loc 1 162 0 add.u64 %r62,%r62,2; mov.u64 %r90,16; .loc 1 163 0 cvt.u32.u64 %r97,%r90; bra $L8; $L7: .loc 1 165 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L23; cvt.s64.s32 %r90,%r97; bra $L8; $L41: cvt.s64.s32 %r90,%r97; bra $L8; $L23: mov.u64 %r90,8; .loc 1 166 0 cvt.u32.u64 %r97,%r90; bra $L8; $L28: .loc 1 165 0 mov.u64 %r90,10; .loc 1 166 0 cvt.u32.u64 %r97,%r90; $L8: .loc 1 185 0 setp.eq.u32 %r175,%r91,0; selp.u64 %r81,9223372036854775807,-9223372036854775808,%r175; .loc 1 186 0 rem.u64 %r123,%r81,%r90; cvt.u32.u64 %r86,%r123; .loc 1 187 0 div.u64 %r87,%r81,%r90; mov.u64 %r92,%r62; .loc 1 188 0 mov.u32 %r80,0; mov.u64 %r77,0; .loc 1 198 0 mov.u32 %r177,-1; .loc 1 200 0 mov.u32 %r178,1; $L15: .loc 1 189 0 cvt.s64.s32 %r124,%r78; add.u64 %r125,%r50,%r124; ld.s8 %r66,[%r125+1]; cvt.u16.u32 %r128,%r66; and.b16 %r127,%r128,4; cvt.u32.u16 %r129,%r127; cvt.s32.s8 %r131,%r129; cvt.u16.u32 %r130,%r131; setp.eq.u16 %r132,%r130,0; @ %r132 bra $L10; .loc 1 190 0 add.u32 %r79,%r78,-48; bra $L11; $L10: and.b16 %r133,%r128,3; cvt.u32.u16 %r135,%r133; cvt.s32.s8 %r56,%r135; .loc 1 191 0 setp.eq.u32 %r136,%r56,0; @ %r136 bra $L12; .loc 1 192 0 cvt.u16.u32 %r137,%r56; setp.ne.u16 %r138,%r137,1; selp.u32 %r82,87,55,%r138; sub.u32 %r79,%r78,%r82; $L11: .loc 1 195 0 setp.le.s32 %r139,%r97,%r79; @ %r139 bra $L12; .loc 1 197 0 shr.u32 %r141,%r80,31; set.u32.gt.u64 %r143,%r77,%r87; neg.s32 %r144,%r143; cvt.u16.u32 %r147,%r141; cvt.u16.u32 %r148,%r144; or.b16 %r146,%r147,%r148; cvt.u32.u16 %r149,%r146; cvt.u16.u8 %r150,%r149; setp.ne.u16 %r151,%r150,0; @ %r151 bra $L26; set.u32.eq.u64 %r153,%r77,%r87; neg.s32 %r154,%r153; set.u32.gt.s32 %r156,%r79,%r86; neg.s32 %r157,%r156; cvt.u16.u32 %r159,%r154; cvt.u16.u32 %r160,%r157; and.b16 %r158,%r159,%r160; cvt.u32.u16 %r161,%r158; cvt.u16.u8 %r162,%r161; setp.ne.u16 %r163,%r162,0; @ %r163 bra $L27; .loc 1 202 0 cvt.s64.s32 %r164,%r79; mad.lo.u64 %r77,%r77,%r90,%r164; .loc 1 200 0 mov.u32 %r80,%r178; bra $L14; $L26: .loc 1 198 0 mov.u32 %r80,%r177; bra $L14; $L27: mov.u32 %r80,%r177; $L14: .loc 1 188 0 ld.u8 %r78,[%r92]; add.u64 %r92,%r92,1; .loc 1 189 0 bra $L15; $L12: .loc 1 205 0 setp.ne.u32 %r165,%r80,-1; @ %r165 bra $L16; .loc 1 207 0 mov.u32 %r166,34; st.u32 [%r94],%r166; .loc 1 210 0 setp.ne.u64 %r167,%r96,0; @ %r167 bra $L17; .loc 1 206 0 mov.u64 %r77,%r81; bra $L33; $L16: .loc 1 208 0 @ %r175 bra $L19; .loc 1 209 0 neg.s64 %r77,%r77; $L19: .loc 1 210 0 setp.eq.u64 %r169,%r96,0; @ %r169 bra $L33; .loc 1 211 0 setp.eq.u32 %r170,%r80,0; @ %r170 bra $L20; mov.u64 %r81,%r77; $L17: add.u64 %r95,%r92,-1; mov.u64 %r77,%r81; $L20: st.u64 [%r96],%r95; .loc 1 212 0 bra $L33; $L6: .loc 1 165 0 setp.eq.u32 %r172,%r97,0; @ %r172 bra $L28; cvt.s64.s32 %r90,%r97; bra $L8; $L4: .loc 1 159 0 and.b32 %r173,%r97,-17; setp.eq.u32 %r174,%r173,0; @ %r174 bra $L21; bra $L41; $L33: .loc 1 213 0 mov.u64 %value,%r77; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtol .visible .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 223 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtol_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 224 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } lib_a-strtold.o/0 0 0 644 1015 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtold .visible .func (.param .f64 %value_out) strtold (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/strtold.c" // BEGIN GLOBAL FUNCTION DECL: strtod .extern .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strtold .visible .func (.param .f64 %value_out) strtold (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 42 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),strtod,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 46 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-strtoll.o/0 0 0 644 1455 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtoll .visible .func (.param .u64 %value_out) strtoll (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libc/stdlib/strtoll.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strtoll_r .extern .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strtoll .visible .func (.param .u64 %value_out) strtoll (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 135 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtoll_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 136 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } /770 0 0 0 644 6343 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtoll_r .visible .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../newlib/libc/stdlib/strtoll_r.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtoll_r .visible .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r81; .reg .u32 %r82; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u16 %r127; .reg .u16 %r128; .reg .u32 %r129; .reg .u16 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .u16 %r133; .reg .u32 %r135; .reg .pred %r136; .reg .u16 %r137; .reg .pred %r138; .reg .pred %r139; .reg .u32 %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u16 %r146; .reg .u16 %r147; .reg .u16 %r148; .reg .u32 %r149; .reg .u16 %r150; .reg .pred %r151; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r156; .reg .u32 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u16 %r160; .reg .u32 %r161; .reg .u16 %r162; .reg .pred %r163; .reg .u64 %r164; .reg .pred %r165; .reg .u32 %r166; .reg .pred %r167; .reg .pred %r169; .reg .pred %r170; .reg .pred %r172; .reg .u32 %r173; .reg .pred %r174; .reg .pred %r175; .reg .u32 %r177; .reg .u32 %r178; .reg .u16 %r179; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 78 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r85,%r95; $L2: mov.u64 %r75,%r85; add.u64 %r62,%r85,1; mov.u64 %r85,%r62; .loc 1 77 0 ld.u8 %r49,[%r75]; .loc 1 78 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r179,[%r100+1]; mov.u16 %r104,%r179; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 79 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 81 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 80 0 mov.u32 %r91,1; bra $L4; $L3: .loc 1 82 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 77 0 mov.u32 %r78,%r49; .loc 1 69 0 mov.u32 %r91,0; bra $L4; $L5: .loc 1 83 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 69 0 mov.u32 %r91,0; bra $L4; $L21: .loc 1 84 0 setp.ne.u32 %r113,%r78,48; @ %r113 bra $L6; .loc 1 85 0 ld.u8 %r179,[%r62]; mov.u16 %r116,%r179; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 86 0 ld.u8 %r78,[%r62+1]; .loc 1 87 0 add.u64 %r62,%r62,2; mov.u64 %r90,16; .loc 1 88 0 cvt.u32.u64 %r97,%r90; bra $L8; $L7: .loc 1 90 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L23; cvt.s64.s32 %r90,%r97; bra $L8; $L41: cvt.s64.s32 %r90,%r97; bra $L8; $L23: mov.u64 %r90,8; .loc 1 91 0 cvt.u32.u64 %r97,%r90; bra $L8; $L28: .loc 1 90 0 mov.u64 %r90,10; .loc 1 91 0 cvt.u32.u64 %r97,%r90; $L8: .loc 1 110 0 setp.eq.u32 %r175,%r91,0; selp.u64 %r81,9223372036854775807,-9223372036854775808,%r175; .loc 1 111 0 rem.u64 %r123,%r81,%r90; cvt.u32.u64 %r86,%r123; .loc 1 112 0 div.u64 %r87,%r81,%r90; mov.u64 %r92,%r62; .loc 1 113 0 mov.u32 %r80,0; mov.u64 %r77,0; .loc 1 123 0 mov.u32 %r177,-1; .loc 1 125 0 mov.u32 %r178,1; $L15: .loc 1 114 0 cvt.s64.s32 %r124,%r78; add.u64 %r125,%r50,%r124; ld.s8 %r66,[%r125+1]; cvt.u16.u32 %r128,%r66; and.b16 %r127,%r128,4; cvt.u32.u16 %r129,%r127; cvt.s32.s8 %r131,%r129; cvt.u16.u32 %r130,%r131; setp.eq.u16 %r132,%r130,0; @ %r132 bra $L10; .loc 1 115 0 add.u32 %r79,%r78,-48; bra $L11; $L10: and.b16 %r133,%r128,3; cvt.u32.u16 %r135,%r133; cvt.s32.s8 %r56,%r135; .loc 1 116 0 setp.eq.u32 %r136,%r56,0; @ %r136 bra $L12; .loc 1 117 0 cvt.u16.u32 %r137,%r56; setp.ne.u16 %r138,%r137,1; selp.u32 %r82,87,55,%r138; sub.u32 %r79,%r78,%r82; $L11: .loc 1 120 0 setp.le.s32 %r139,%r97,%r79; @ %r139 bra $L12; .loc 1 122 0 shr.u32 %r141,%r80,31; set.u32.gt.u64 %r143,%r77,%r87; neg.s32 %r144,%r143; cvt.u16.u32 %r147,%r141; cvt.u16.u32 %r148,%r144; or.b16 %r146,%r147,%r148; cvt.u32.u16 %r149,%r146; cvt.u16.u8 %r150,%r149; setp.ne.u16 %r151,%r150,0; @ %r151 bra $L26; set.u32.eq.u64 %r153,%r77,%r87; neg.s32 %r154,%r153; set.u32.gt.s32 %r156,%r79,%r86; neg.s32 %r157,%r156; cvt.u16.u32 %r159,%r154; cvt.u16.u32 %r160,%r157; and.b16 %r158,%r159,%r160; cvt.u32.u16 %r161,%r158; cvt.u16.u8 %r162,%r161; setp.ne.u16 %r163,%r162,0; @ %r163 bra $L27; .loc 1 127 0 cvt.s64.s32 %r164,%r79; mad.lo.u64 %r77,%r77,%r90,%r164; .loc 1 125 0 mov.u32 %r80,%r178; bra $L14; $L26: .loc 1 123 0 mov.u32 %r80,%r177; bra $L14; $L27: mov.u32 %r80,%r177; $L14: .loc 1 113 0 ld.u8 %r78,[%r92]; add.u64 %r92,%r92,1; .loc 1 114 0 bra $L15; $L12: .loc 1 130 0 setp.ne.u32 %r165,%r80,-1; @ %r165 bra $L16; .loc 1 132 0 mov.u32 %r166,34; st.u32 [%r94],%r166; .loc 1 135 0 setp.ne.u64 %r167,%r96,0; @ %r167 bra $L17; .loc 1 131 0 mov.u64 %r77,%r81; bra $L33; $L16: .loc 1 133 0 @ %r175 bra $L19; .loc 1 134 0 neg.s64 %r77,%r77; $L19: .loc 1 135 0 setp.eq.u64 %r169,%r96,0; @ %r169 bra $L33; .loc 1 136 0 setp.eq.u32 %r170,%r80,0; @ %r170 bra $L20; mov.u64 %r81,%r77; $L17: add.u64 %r95,%r92,-1; mov.u64 %r77,%r81; $L20: st.u64 [%r96],%r95; .loc 1 137 0 bra $L33; $L6: .loc 1 90 0 setp.eq.u32 %r172,%r97,0; @ %r172 bra $L28; cvt.s64.s32 %r90,%r97; bra $L8; $L4: .loc 1 84 0 and.b32 %r173,%r97,-17; setp.eq.u32 %r174,%r173,0; @ %r174 bra $L21; bra $L41; $L33: .loc 1 138 0 mov.u64 %value,%r77; st.param.u64 [%value_out],%value; ret; } lib_a-strtoul.o/0 0 0 644 7845 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtoul_r .visible .func (.param .u64 %value_out) _strtoul_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../newlib/libc/stdlib/strtoul.c" // BEGIN GLOBAL FUNCTION DECL: strtoul .visible .func (.param .u64 %value_out) strtoul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtoul_r .visible .func (.param .u64 %value_out) _strtoul_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u32 %r59; .reg .u32 %r61; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r83; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r121; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u16 %r132; .reg .u16 %r133; .reg .u32 %r134; .reg .u16 %r135; .reg .u32 %r136; .reg .pred %r137; .reg .u16 %r138; .reg .u32 %r140; .reg .pred %r141; .reg .u16 %r142; .reg .pred %r143; .reg .pred %r144; .reg .u32 %r146; .reg .u32 %r148; .reg .u32 %r149; .reg .u16 %r151; .reg .u16 %r152; .reg .u16 %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .pred %r156; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r161; .reg .u32 %r162; .reg .u16 %r163; .reg .u16 %r164; .reg .u16 %r165; .reg .u32 %r166; .reg .u16 %r167; .reg .pred %r168; .reg .u64 %r169; .reg .pred %r170; .reg .u32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .pred %r174; .reg .pred %r175; .reg .pred %r177; .reg .u64 %r178; .reg .u64 %r181; .reg .u32 %r182; .reg .pred %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .u16 %r186; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 152 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r83,%r95; $L2: mov.u64 %r75,%r83; add.u64 %r62,%r83,1; mov.u64 %r83,%r62; .loc 1 151 0 ld.u8 %r49,[%r75]; .loc 1 152 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r186,[%r100+1]; mov.u16 %r104,%r186; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 153 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 155 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 154 0 mov.u32 %r59,1; bra $L4; $L3: .loc 1 156 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 151 0 mov.u32 %r77,%r49; .loc 1 145 0 mov.u32 %r59,0; bra $L4; $L5: .loc 1 157 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 145 0 mov.u32 %r59,0; bra $L4; $L20: .loc 1 158 0 setp.ne.u32 %r113,%r77,48; @ %r113 bra $L6; .loc 1 159 0 ld.u8 %r186,[%r62]; mov.u16 %r116,%r186; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 160 0 ld.u8 %r77,[%r62+1]; .loc 1 161 0 add.u64 %r62,%r62,2; mov.u32 %r61,15; mov.u64 %r87,1152921504606846975; mov.u64 %r86,16; .loc 1 162 0 cvt.u32.u64 %r97,%r86; bra $L8; $L7: .loc 1 164 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L22; cvt.s64.s32 %r86,%r97; mov.u64 %r121,-1; div.u64 %r87,%r121,%r86; rem.u64 %r124,%r121,%r86; cvt.u32.u64 %r61,%r124; bra $L8; $L41: cvt.s64.s32 %r86,%r97; mov.u64 %r125,-1; div.u64 %r87,%r125,%r86; rem.u64 %r128,%r125,%r86; cvt.u32.u64 %r61,%r128; bra $L8; $L22: mov.u32 %r61,7; mov.u64 %r87,2305843009213693951; mov.u64 %r86,8; .loc 1 165 0 cvt.u32.u64 %r97,%r86; bra $L8; $L27: .loc 1 164 0 mov.u32 %r61,5; mov.u64 %r87,1844674407370955161; mov.u64 %r86,10; .loc 1 165 0 cvt.u32.u64 %r97,%r86; $L8: mov.u64 %r91,%r62; .loc 1 168 0 mov.u32 %r79,0; mov.u64 %r93,0; .loc 1 178 0 mov.u32 %r184,-1; .loc 1 180 0 mov.u32 %r185,1; $L14: .loc 1 169 0 cvt.s64.s32 %r129,%r77; add.u64 %r130,%r50,%r129; ld.s8 %r66,[%r130+1]; cvt.u16.u32 %r133,%r66; and.b16 %r132,%r133,4; cvt.u32.u16 %r134,%r132; cvt.s32.s8 %r136,%r134; cvt.u16.u32 %r135,%r136; setp.eq.u16 %r137,%r135,0; @ %r137 bra $L9; .loc 1 170 0 add.u32 %r78,%r77,-48; bra $L10; $L9: and.b16 %r138,%r133,3; cvt.u32.u16 %r140,%r138; cvt.s32.s8 %r56,%r140; .loc 1 171 0 setp.eq.u32 %r141,%r56,0; @ %r141 bra $L11; .loc 1 172 0 cvt.u16.u32 %r142,%r56; setp.ne.u16 %r143,%r142,1; selp.u32 %r80,87,55,%r143; sub.u32 %r78,%r77,%r80; $L10: .loc 1 175 0 setp.le.s32 %r144,%r97,%r78; @ %r144 bra $L11; .loc 1 177 0 shr.u32 %r146,%r79,31; set.u32.gt.u64 %r148,%r93,%r87; neg.s32 %r149,%r148; cvt.u16.u32 %r152,%r146; cvt.u16.u32 %r153,%r149; or.b16 %r151,%r152,%r153; cvt.u32.u16 %r154,%r151; cvt.u16.u8 %r155,%r154; setp.ne.u16 %r156,%r155,0; @ %r156 bra $L24; set.u32.eq.u64 %r158,%r93,%r87; neg.s32 %r159,%r158; set.u32.lt.s32 %r161,%r61,%r78; neg.s32 %r162,%r161; cvt.u16.u32 %r164,%r159; cvt.u16.u32 %r165,%r162; and.b16 %r163,%r164,%r165; cvt.u32.u16 %r166,%r163; cvt.u16.u8 %r167,%r166; setp.ne.u16 %r168,%r167,0; @ %r168 bra $L25; .loc 1 182 0 cvt.s64.s32 %r169,%r78; mad.lo.u64 %r93,%r93,%r86,%r169; .loc 1 180 0 mov.u32 %r79,%r185; bra $L13; $L24: .loc 1 178 0 mov.u32 %r79,%r184; bra $L13; $L25: mov.u32 %r79,%r184; $L13: .loc 1 168 0 ld.u8 %r77,[%r91]; add.u64 %r91,%r91,1; .loc 1 169 0 bra $L14; $L11: .loc 1 185 0 setp.ge.s32 %r170,%r79,0; @ %r170 bra $L15; .loc 1 187 0 mov.u32 %r171,34; st.u32 [%r94],%r171; .loc 1 190 0 setp.ne.u64 %r172,%r96,0; @ %r172 bra $L26; .loc 1 186 0 mov.u64 %r93,-1; bra $L1; $L15: .loc 1 188 0 setp.eq.u32 %r173,%r59,0; @ %r173 bra $L18; .loc 1 189 0 neg.s64 %r93,%r93; $L18: .loc 1 190 0 setp.eq.u64 %r174,%r96,0; @ %r174 bra $L1; .loc 1 191 0 setp.eq.u32 %r175,%r79,0; @ %r175 bra $L19; bra $L16; $L26: .loc 1 186 0 mov.u64 %r93,-1; $L16: .loc 1 191 0 add.u64 %r95,%r91,-1; $L19: st.u64 [%r96],%r95; .loc 1 192 0 bra $L1; $L6: .loc 1 164 0 setp.eq.u32 %r177,%r97,0; @ %r177 bra $L27; cvt.s64.s32 %r86,%r97; mov.u64 %r178,-1; div.u64 %r87,%r178,%r86; rem.u64 %r181,%r178,%r86; cvt.u32.u64 %r61,%r181; bra $L8; $L4: .loc 1 158 0 and.b32 %r182,%r97,-17; setp.eq.u32 %r183,%r182,0; @ %r183 bra $L20; bra $L41; $L1: .loc 1 193 0 mov.u64 %value,%r93; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtoul .visible .func (.param .u64 %value_out) strtoul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 203 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtoul_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 204 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } /789 0 0 0 644 1463 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtoull .visible .func (.param .u64 %value_out) strtoull (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../newlib/libc/stdlib/strtoull.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strtoull_r .extern .func (.param .u64 %value_out) _strtoull_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strtoull .visible .func (.param .u64 %value_out) strtoull (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 136 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtoull_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 137 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } /807 0 0 0 644 6678 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtoull_r .visible .func (.param .u64 %value_out) _strtoull_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../newlib/libc/stdlib/strtoull_r.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtoull_r .visible .func (.param .u64 %value_out) _strtoull_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u32 %r59; .reg .u32 %r61; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r83; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r121; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u16 %r132; .reg .u16 %r133; .reg .u32 %r134; .reg .u16 %r135; .reg .u32 %r136; .reg .pred %r137; .reg .u16 %r138; .reg .u32 %r140; .reg .pred %r141; .reg .u16 %r142; .reg .pred %r143; .reg .pred %r144; .reg .u32 %r146; .reg .u32 %r148; .reg .u32 %r149; .reg .u16 %r151; .reg .u16 %r152; .reg .u16 %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .pred %r156; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r161; .reg .u32 %r162; .reg .u16 %r163; .reg .u16 %r164; .reg .u16 %r165; .reg .u32 %r166; .reg .u16 %r167; .reg .pred %r168; .reg .u64 %r169; .reg .pred %r170; .reg .u32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .pred %r174; .reg .pred %r175; .reg .pred %r177; .reg .u64 %r178; .reg .u64 %r181; .reg .u32 %r182; .reg .pred %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .u16 %r186; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 77 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r83,%r95; $L2: mov.u64 %r75,%r83; add.u64 %r62,%r83,1; mov.u64 %r83,%r62; .loc 1 76 0 ld.u8 %r49,[%r75]; .loc 1 77 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r186,[%r100+1]; mov.u16 %r104,%r186; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 78 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 80 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 79 0 mov.u32 %r59,1; bra $L4; $L3: .loc 1 81 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 76 0 mov.u32 %r77,%r49; .loc 1 70 0 mov.u32 %r59,0; bra $L4; $L5: .loc 1 82 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 70 0 mov.u32 %r59,0; bra $L4; $L20: .loc 1 83 0 setp.ne.u32 %r113,%r77,48; @ %r113 bra $L6; .loc 1 84 0 ld.u8 %r186,[%r62]; mov.u16 %r116,%r186; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 85 0 ld.u8 %r77,[%r62+1]; .loc 1 86 0 add.u64 %r62,%r62,2; mov.u32 %r61,15; mov.u64 %r87,1152921504606846975; mov.u64 %r86,16; .loc 1 87 0 cvt.u32.u64 %r97,%r86; bra $L8; $L7: .loc 1 89 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L22; cvt.s64.s32 %r86,%r97; mov.u64 %r121,-1; div.u64 %r87,%r121,%r86; rem.u64 %r124,%r121,%r86; cvt.u32.u64 %r61,%r124; bra $L8; $L41: cvt.s64.s32 %r86,%r97; mov.u64 %r125,-1; div.u64 %r87,%r125,%r86; rem.u64 %r128,%r125,%r86; cvt.u32.u64 %r61,%r128; bra $L8; $L22: mov.u32 %r61,7; mov.u64 %r87,2305843009213693951; mov.u64 %r86,8; .loc 1 90 0 cvt.u32.u64 %r97,%r86; bra $L8; $L27: .loc 1 89 0 mov.u32 %r61,5; mov.u64 %r87,1844674407370955161; mov.u64 %r86,10; .loc 1 90 0 cvt.u32.u64 %r97,%r86; $L8: mov.u64 %r91,%r62; .loc 1 93 0 mov.u32 %r79,0; mov.u64 %r93,0; .loc 1 103 0 mov.u32 %r184,-1; .loc 1 105 0 mov.u32 %r185,1; $L14: .loc 1 94 0 cvt.s64.s32 %r129,%r77; add.u64 %r130,%r50,%r129; ld.s8 %r66,[%r130+1]; cvt.u16.u32 %r133,%r66; and.b16 %r132,%r133,4; cvt.u32.u16 %r134,%r132; cvt.s32.s8 %r136,%r134; cvt.u16.u32 %r135,%r136; setp.eq.u16 %r137,%r135,0; @ %r137 bra $L9; .loc 1 95 0 add.u32 %r78,%r77,-48; bra $L10; $L9: and.b16 %r138,%r133,3; cvt.u32.u16 %r140,%r138; cvt.s32.s8 %r56,%r140; .loc 1 96 0 setp.eq.u32 %r141,%r56,0; @ %r141 bra $L11; .loc 1 97 0 cvt.u16.u32 %r142,%r56; setp.ne.u16 %r143,%r142,1; selp.u32 %r80,87,55,%r143; sub.u32 %r78,%r77,%r80; $L10: .loc 1 100 0 setp.le.s32 %r144,%r97,%r78; @ %r144 bra $L11; .loc 1 102 0 shr.u32 %r146,%r79,31; set.u32.gt.u64 %r148,%r93,%r87; neg.s32 %r149,%r148; cvt.u16.u32 %r152,%r146; cvt.u16.u32 %r153,%r149; or.b16 %r151,%r152,%r153; cvt.u32.u16 %r154,%r151; cvt.u16.u8 %r155,%r154; setp.ne.u16 %r156,%r155,0; @ %r156 bra $L24; set.u32.eq.u64 %r158,%r93,%r87; neg.s32 %r159,%r158; set.u32.lt.s32 %r161,%r61,%r78; neg.s32 %r162,%r161; cvt.u16.u32 %r164,%r159; cvt.u16.u32 %r165,%r162; and.b16 %r163,%r164,%r165; cvt.u32.u16 %r166,%r163; cvt.u16.u8 %r167,%r166; setp.ne.u16 %r168,%r167,0; @ %r168 bra $L25; .loc 1 107 0 cvt.s64.s32 %r169,%r78; mad.lo.u64 %r93,%r93,%r86,%r169; .loc 1 105 0 mov.u32 %r79,%r185; bra $L13; $L24: .loc 1 103 0 mov.u32 %r79,%r184; bra $L13; $L25: mov.u32 %r79,%r184; $L13: .loc 1 93 0 ld.u8 %r77,[%r91]; add.u64 %r91,%r91,1; .loc 1 94 0 bra $L14; $L11: .loc 1 110 0 setp.ge.s32 %r170,%r79,0; @ %r170 bra $L15; .loc 1 112 0 mov.u32 %r171,34; st.u32 [%r94],%r171; .loc 1 115 0 setp.ne.u64 %r172,%r96,0; @ %r172 bra $L26; .loc 1 111 0 mov.u64 %r93,-1; bra $L1; $L15: .loc 1 113 0 setp.eq.u32 %r173,%r59,0; @ %r173 bra $L18; .loc 1 114 0 neg.s64 %r93,%r93; $L18: .loc 1 115 0 setp.eq.u64 %r174,%r96,0; @ %r174 bra $L1; .loc 1 116 0 setp.eq.u32 %r175,%r79,0; @ %r175 bra $L19; bra $L16; $L26: .loc 1 111 0 mov.u64 %r93,-1; $L16: .loc 1 116 0 add.u64 %r95,%r91,-1; $L19: st.u64 [%r96],%r95; .loc 1 117 0 bra $L1; $L6: .loc 1 89 0 setp.eq.u32 %r177,%r97,0; @ %r177 bra $L27; cvt.s64.s32 %r86,%r97; mov.u64 %r178,-1; div.u64 %r87,%r178,%r86; rem.u64 %r181,%r178,%r86; cvt.u32.u64 %r61,%r181; bra $L8; $L4: .loc 1 83 0 and.b32 %r182,%r97,-17; setp.eq.u32 %r183,%r182,0; @ %r183 bra $L20; bra $L41; $L1: .loc 1 118 0 mov.u64 %value,%r93; st.param.u64 [%value_out],%value; ret; } lib_a-strupr.o/ 0 0 0 644 1413 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strupr .visible .func (.param .u64 %value_out) strupr (.param .u64 %in_ar0); .file 1 "../../../../../newlib/libc/string/strupr.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strupr .visible .func (.param .u64 %value_out) strupr (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r58; .reg .u64 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u16 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r76; mov.u64 %r60,%ar0; .loc 1 41 0 ld.u8 %r55,[%r60]; setp.eq.u32 %r61,%r55,0; @ %r61 bra $L2; mov.u64 %r58,%r60; $L4: mov.u32 %r56,%r55; .loc 1 43 0 cvt.u32.u32 %r63,%r56; cvt.u64.u8 %r62,%r63; ld.global.u64 %r64,[__ctype_ptr__]; add.u64 %r65,%r64,%r62; ld.u8 %r76,[%r65+1]; mov.u16 %r69,%r76; and.b16 %r68,%r69,3; cvt.u32.u16 %r72,%r68; cvt.s32.s8 %r71,%r72; cvt.u16.u32 %r70,%r71; setp.ne.u16 %r73,%r70,2; @ %r73 bra $L3; add.u32 %r56,%r56,-32; $L3: st.u8 [%r58],%r56; .loc 1 41 0 add.u64 %r58,%r58,1; ld.u8 %r55,[%r58]; setp.ne.u32 %r74,%r55,0; @ %r74 bra $L4; $L2: .loc 1 46 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } lib_a-strxfrm.o/0 0 0 644 1975 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strxfrm .visible .func (.param .u64 %value_out) strxfrm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/strxfrm.c" // BEGIN GLOBAL FUNCTION DEF: strxfrm .visible .func (.param .u64 %value_out) strxfrm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r60; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .pred %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u32 %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u16 %r74; .reg .u32 %r75; .reg .pred %r76; mov.u64 %r63,%ar0; mov.u64 %r64,%ar1; mov.u64 %r65,%ar2; ld.s8 %r52,[%r64]; .loc 1 62 0 setp.eq.u64 %r66,%r65,0; @ %r66 bra $L7; .loc 1 64 0 add.u64 %r54,%r64,1; add.u64 %r57,%r63,1; cvt.u32.u32 %r67,%r52; st.u8 [%r63],%r67; setp.eq.u32 %r68,%r52,0; @ %r68 bra $L8; mov.u64 %r56,%r57; add.u64 %r60,%r64,%r65; bra $L4; $L5: add.u64 %r54,%r54,1; cvt.u32.u32 %r69,%r52; st.u8 [%r56],%r69; add.u64 %r56,%r56,1; setp.eq.u32 %r70,%r52,0; @ %r70 bra $L9; $L4: sub.u64 %r65,%r54,%r64; ld.s8 %r52,[%r54]; .loc 1 62 0 setp.ne.u64 %r71,%r54,%r60; @ %r71 bra $L5; bra $L2; $L7: mov.u64 %r54,%r64; $L2: .loc 1 69 0 setp.eq.u32 %r72,%r52,0; @ %r72 bra $L10; mov.u64 %r53,%r54; $L6: .loc 1 71 0 add.u64 %r53,%r53,1; add.u64 %r73,%r53,%r65; sub.u64 %r62,%r73,%r54; .loc 1 69 0 ld.s8 %r75,[%r53]; cvt.u16.u32 %r74,%r75; setp.ne.u16 %r76,%r74,0; @ %r76 bra $L6; bra $L1; $L8: .loc 1 61 0 mov.u64 %r62,0; bra $L1; $L9: mov.u64 %r62,%r65; bra $L1; $L10: .loc 1 69 0 mov.u64 %r62,%r65; $L1: .loc 1 76 0 mov.u64 %value,%r62; st.param.u64 [%value_out],%value; ret; } /827 0 0 0 644 43805 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ssprint_r .visible .func (.param .u32 %value_out) __ssprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/stdio/vfprintf.c" // BEGIN GLOBAL FUNCTION DECL: _svfiprintf_r .visible .func (.param .u32 %value_out) _svfiprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _realloc_os_r .extern .func (.param .u64 %value_out) _realloc_os_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _free_r .extern .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memmove .extern .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN VAR DEF: blanks$4046 .const .align 1 .u8 blanks$4046[16] = {32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 }; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[17] = {48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[17] = {48,49,50,51,52,53,54,55,56,57,97,98,99,100,101,102,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[7] = {40,110,117,108,108,41,0 }; // BEGIN VAR DEF: zeroes$4047 .const .align 1 .u8 zeroes$4047[16] = {48,48,48,48,48,48,48,48,48,48,48,48,48,48,48,48 }; // BEGIN GLOBAL FUNCTION DEF: __ssprint_r .visible .func (.param .u32 %value_out) __ssprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r23; .reg .u64 %r25; .reg .u64 %r27; .reg .u32 %r28; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r36; .reg .u64 %r41; .reg .u64 %r43; .reg .u64 %r49; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r60; .reg .u64 %r62; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r72; .reg .u16 %r73; .reg .u16 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .u64 %r83; .reg .u64 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u16 %r89; .reg .u16 %r90; .reg .pred %r91; .reg .u64 %r94; .reg .pred %r95; .reg .u32 %r96; .reg .u64 %r100; .reg .u64 %r101; .reg .u16 %r102; .reg .u16 %r103; .reg .u16 %r104; .reg .u64 %r109; .reg .u64 %r110; .reg .pred %r111; .reg .u64 %r114; .reg .u32 %r115; .reg .u32 %r116; .reg .pred %r117; .reg .u64 %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .pred %r125; .reg .u16 %r126; .reg .u16 %r127; .reg .u64 %r128; .reg .u32 %r129; mov.u64 %r65,%ar0; mov.u64 %r66,%ar1; mov.u64 %r67,%ar2; .loc 1 283 0 ld.u64 %r68,[%r67+16]; setp.eq.u64 %r69,%r68,0; @ %r69 bra $L2; .loc 1 280 0 ld.u64 %r41,[%r67]; ld.u64 %r62,[%r66]; ld.u32 %r52,[%r66+12]; .loc 1 278 0 mov.u64 %r36,0; .loc 1 281 0 mov.u64 %r43,%r36; bra $L3; $L2: .loc 1 284 0 mov.u32 %r70,0; st.u32 [%r67+8],%r70; .loc 1 285 0 mov.u32 %r64,%r70; bra $L1; $L5: .loc 1 290 0 ld.u64 %r36,[%r41]; .loc 1 291 0 ld.u64 %r43,[%r41+8]; .loc 1 292 0 add.u64 %r41,%r41,16; $L3: .loc 1 289 0 setp.eq.u64 %r71,%r43,0; @ %r71 bra $L5; cvt.s64.s32 %r60,%r52; .loc 1 295 0 setp.lt.u64 %r72,%r43,%r60; @ %r72 bra $L6; ld.s16 %r23,[%r66+16]; cvt.u16.u32 %r74,%r23; and.b16 %r73,%r74,1152; setp.ne.u16 %r75,%r73,0; @ %r75 bra $L7; cvt.u32.u64 %r76,%r43; cvt.s64.s32 %r58,%r76; bra $L8; $L7: .loc 1 298 0 ld.u64 %r25,[%r66+24]; sub.u64 %r27,%r62,%r25; cvt.u32.u64 %r57,%r27; .loc 1 306 0 ld.u32 %r28,[%r66+32]; add.u32 %r78,%r28,%r28; add.u32 %r79,%r78,%r28; shr.u32 %r80,%r79,31; add.u32 %r81,%r80,%r79; shr.s32 %r54,%r81,1; .loc 1 307 0 cvt.s64.s32 %r30,%r54; cvt.s64.s32 %r31,%r57; add.u64 %r83,%r43,1; add.u64 %r84,%r83,%r31; setp.ge.u64 %r85,%r30,%r84; @ %r85 bra $L9; .loc 1 308 0 cvt.u32.u64 %r87,%r43; add.u32 %r86,%r87,1; add.u32 %r54,%r86,%r57; cvt.s64.s32 %r30,%r54; $L9: .loc 1 309 0 cvt.u16.u32 %r90,%r23; and.b16 %r89,%r90,1024; setp.eq.u16 %r91,%r89,0; @ %r91 bra $L10; .loc 1 312 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r65; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r30; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r94,[%value_in]; } mov.u64 %r53,%r94; .loc 1 313 0 setp.ne.u64 %r95,%r94,0; @ %r95 bra $L11; .loc 1 315 0 mov.u32 %r96,12; st.u32 [%r65],%r96; .loc 1 316 0 bra $L12; $L11: .loc 1 318 0 ld.u64 %r100,[%r66+24]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r53; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r100; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r31; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r101,[%value_in]; } .loc 1 319 0 ld.u16 %r103,[%r66+16]; and.b16 %r102,%r103,-1153; or.b16 %r104,%r102,128; st.u16 [%r66+16],%r104; bra $L13; $L10: .loc 1 323 0 cvt.s64.s32 %r109,%r28; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r65; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r109; call (%value_in),_realloc_os_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r110,[%value_in]; } mov.u64 %r53,%r110; .loc 1 325 0 setp.ne.u64 %r111,%r110,0; @ %r111 bra $L13; .loc 1 327 0 ld.u64 %r114,[%r66+24]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r65; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r114; call _free_r,(%out_arg1,%out_arg2); } .loc 1 330 0 mov.u32 %r115,12; st.u32 [%r65],%r115; .loc 1 331 0 bra $L12; $L13: .loc 1 334 0 st.u64 [%r66+24],%r53; .loc 1 335 0 add.u64 %r62,%r53,%r31; st.u64 [%r66],%r62; .loc 1 336 0 st.u32 [%r66+32],%r54; .loc 1 337 0 cvt.u32.u64 %r52,%r43; .loc 1 338 0 sub.u32 %r116,%r54,%r57; st.u32 [%r66+12],%r116; .loc 1 340 0 cvt.s64.s32 %r60,%r52; setp.le.u64 %r117,%r60,%r43; @ %r117 bra $L15; $L6: .loc 1 341 0 cvt.u32.u64 %r52,%r43; cvt.s64.s32 %r60,%r52; mov.u64 %r58,%r60; bra $L8; $L15: mov.u64 %r58,%r60; $L8: .loc 1 342 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r62; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r36; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r60; call (%value_in),memmove,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r121,[%value_in]; } .loc 1 343 0 ld.u32 %r122,[%r66+12]; sub.u32 %r52,%r122,%r52; st.u32 [%r66+12],%r52; .loc 1 344 0 ld.u64 %r123,[%r66]; add.u64 %r62,%r123,%r60; st.u64 [%r66],%r62; .loc 1 346 0 add.u64 %r36,%r36,%r58; .loc 1 347 0 sub.u64 %r43,%r43,%r58; .loc 1 348 0 ld.u64 %r124,[%r67+16]; sub.u64 %r49,%r124,%r58; st.u64 [%r67+16],%r49; setp.ne.u64 %r125,%r49,0; @ %r125 bra $L3; bra $L2; $L12: .loc 1 355 0 ld.u16 %r127,[%r66+16]; or.b16 %r126,%r127,64; st.u16 [%r66+16],%r126; .loc 1 356 0 mov.u64 %r128,0; st.u64 [%r67+16],%r128; .loc 1 357 0 cvt.u32.u64 %r129,%r128; st.u32 [%r67+8],%r129; .loc 1 358 0 mov.u32 %r64,-1; $L1: .loc 1 359 0 mov.u32 %value,%r64; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _svfiprintf_r .visible .func (.param .u32 %value_out) _svfiprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[200]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r80; .reg .u64 %r84; .reg .u32 %r88; .reg .u32 %r145; .reg .u32 %r157; .reg .u32 %r158; .reg .u64 %r160; .reg .u64 %r167; .reg .u32 %r168; .reg .u64 %r171; .reg .u64 %r173; .reg .u64 %r177; .reg .u32 %r178; .reg .u64 %r183; .reg .u32 %r185; .reg .u64 %r186; .reg .u64 %r187; .reg .u32 %r188; .reg .u64 %r189; .reg .u32 %r190; .reg .u32 %r191; .reg .u64 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .u32 %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u32 %r198; .reg .u32 %r200; .reg .u32 %r203; .reg .u32 %r204; .reg .u32 %r205; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u32 %r214; .reg .u64 %r219; .reg .u32 %r220; .reg .u32 %r221; .reg .u64 %r223; .reg .u64 %r224; .reg .u64 %r226; .reg .u64 %r227; .reg .u64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u64 %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .u64 %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .u32 %r250; .reg .u64 %r252; .reg .u64 %r253; .reg .u64 %r255; .reg .u32 %r256; .reg .u32 %r257; .reg .u64 %r258; .reg .u32 %r259; .reg .u64 %r260; .reg .u64 %r264; .reg .u32 %r265; .reg .u64 %r266; .reg .u64 %r267; .reg .u32 %r276; .reg .u32 %r277; .reg .u32 %r278; .reg .u32 %r279; .reg .u32 %r280; .reg .u32 %r281; .reg .u32 %r284; .reg .u64 %r285; .reg .u64 %r286; .reg .u64 %r287; .reg .u64 %r288; .reg .u16 %r296; .reg .u16 %r297; .reg .pred %r298; .reg .u64 %r299; .reg .pred %r300; .reg .u64 %r302; .reg .u64 %r303; .reg .pred %r304; .reg .u32 %r305; .reg .u32 %r306; .reg .u64 %r307; .reg .u32 %r308; .reg .u16 %r310; .reg .u32 %r311; .reg .u32 %r312; .reg .u32 %r315; .reg .u32 %r316; .reg .u16 %r317; .reg .u16 %r318; .reg .u16 %r319; .reg .u32 %r320; .reg .u16 %r321; .reg .pred %r322; .reg .u16 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r329; .reg .u32 %r330; .reg .u16 %r331; .reg .u16 %r332; .reg .u16 %r333; .reg .u32 %r334; .reg .u16 %r335; .reg .pred %r336; .reg .u64 %r337; .reg .pred %r338; .reg .u64 %r339; .reg .u64 %r340; .reg .u32 %r341; .reg .pred %r342; .reg .u32 %r347; .reg .pred %r348; .reg .u16 %r349; .reg .u32 %r350; .reg .pred %r351; .reg .u32 %r352; .reg .pred %r353; .reg .pred %r354; .reg .pred %r355; .reg .pred %r356; .reg .pred %r357; .reg .pred %r358; .reg .pred %r359; .reg .pred %r360; .reg .pred %r361; .reg .pred %r362; .reg .pred %r363; .reg .pred %r364; .reg .pred %r365; .reg .pred %r366; .reg .pred %r367; .reg .pred %r368; .reg .pred %r369; .reg .pred %r370; .reg .pred %r371; .reg .pred %r372; .reg .pred %r373; .reg .pred %r374; .reg .pred %r375; .reg .pred %r376; .reg .pred %r377; .reg .pred %r378; .reg .pred %r379; .reg .pred %r380; .reg .pred %r381; .reg .pred %r382; .reg .pred %r383; .reg .pred %r384; .reg .u32 %r385; .reg .pred %r386; .reg .u32 %r387; .reg .pred %r388; .reg .pred %r389; .reg .pred %r390; .reg .pred %r391; .reg .u32 %r392; .reg .u32 %r394; .reg .u32 %r395; .reg .u32 %r396; .reg .pred %r397; .reg .u32 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .pred %r404; .reg .u16 %r405; .reg .pred %r406; .reg .u32 %r407; .reg .u32 %r408; .reg .pred %r409; .reg .u32 %r410; .reg .u32 %r411; .reg .pred %r412; .reg .u32 %r413; .reg .pred %r414; .reg .u32 %r415; .reg .pred %r416; .reg .u16 %r417; .reg .pred %r418; .reg .u32 %r419; .reg .pred %r420; .reg .u32 %r421; .reg .u64 %r422; .reg .u32 %r423; .reg .pred %r424; .reg .u64 %r425; .reg .u32 %r426; .reg .pred %r427; .reg .u64 %r428; .reg .u32 %r429; .reg .pred %r430; .reg .u32 %r431; .reg .pred %r432; .reg .u32 %r433; .reg .pred %r434; .reg .u32 %r435; .reg .pred %r436; .reg .u16 %r437; .reg .u32 %r438; .reg .u32 %r439; .reg .u32 %r440; .reg .pred %r441; .reg .pred %r442; .reg .u32 %r444; .reg .u64 %r446; .reg .u64 %r447; .reg .pred %r448; .reg .u64 %r449; .reg .u32 %r450; .reg .u64 %r452; .reg .u32 %r453; .reg .pred %r454; .reg .u32 %r455; .reg .pred %r456; .reg .u32 %r457; .reg .pred %r458; .reg .u16 %r459; .reg .pred %r460; .reg .u32 %r461; .reg .u32 %r462; .reg .pred %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u32 %r466; .reg .pred %r467; .reg .u16 %r468; .reg .u32 %r469; .reg .pred %r470; .reg .pred %r471; .reg .u32 %r472; .reg .u32 %r473; .reg .pred %r475; .reg .u32 %r477; .reg .u32 %r478; .reg .u32 %r480; .reg .u32 %r481; .reg .u16 %r482; .reg .u16 %r483; .reg .u16 %r484; .reg .u32 %r485; .reg .u16 %r486; .reg .pred %r487; .reg .u16 %r488; .reg .pred %r489; .reg .pred %r491; .reg .u16 %r493; .reg .u16 %r494; .reg .u16 %r496; .reg .u32 %r498; .reg .pred %r500; .reg .u16 %r502; .reg .u32 %r503; .reg .u32 %r504; .reg .u16 %r506; .reg .u16 %r507; .reg .u16 %r509; .reg .u16 %r510; .reg .u32 %r512; .reg .u16 %r513; .reg .pred %r514; .reg .u64 %r515; .reg .u32 %r516; .reg .u64 %r517; .reg .pred %r518; .reg .u16 %r520; .reg .u16 %r521; .reg .u32 %r522; .reg .u64 %r524; .reg .u16 %r526; .reg .u16 %r527; .reg .u32 %r528; .reg .pred %r531; .reg .u64 %r532; .reg .u64 %r533; .reg .u64 %r534; .reg .u32 %r535; .reg .pred %r536; .reg .u64 %r537; .reg .pred %r538; .reg .pred %r539; .reg .u32 %r540; .reg .pred %r541; .reg .u32 %r542; .reg .pred %r543; .reg .u32 %r544; .reg .pred %r545; .reg .pred %r547; .reg .pred %r548; .reg .pred %r549; .reg .u64 %r551; .reg .pred %r552; .reg .u32 %r557; .reg .pred %r558; .reg .pred %r559; .reg .pred %r561; .reg .u32 %r566; .reg .pred %r567; .reg .u16 %r568; .reg .u32 %r569; .reg .pred %r570; .reg .u64 %r572; .reg .pred %r573; .reg .u32 %r578; .reg .pred %r579; .reg .u64 %r582; .reg .pred %r583; .reg .u32 %r588; .reg .pred %r589; .reg .pred %r590; .reg .pred %r591; .reg .pred %r592; .reg .u64 %r594; .reg .pred %r595; .reg .u32 %r600; .reg .pred %r601; .reg .pred %r602; .reg .pred %r604; .reg .u32 %r609; .reg .pred %r610; .reg .pred %r611; .reg .pred %r612; .reg .u64 %r614; .reg .pred %r615; .reg .u32 %r620; .reg .pred %r621; .reg .pred %r622; .reg .pred %r624; .reg .u32 %r629; .reg .pred %r630; .reg .u32 %r631; .reg .pred %r632; .reg .u32 %r637; .reg .pred %r638; .reg .u32 %r639; .reg .pred %r640; .reg .pred %r641; .reg .pred %r642; .reg .u64 %r644; .reg .pred %r645; .reg .u32 %r650; .reg .pred %r651; .reg .pred %r652; .reg .pred %r654; .reg .u32 %r659; .reg .pred %r660; .reg .u32 %r661; .reg .pred %r662; .reg .u32 %r663; .reg .u32 %r668; .reg .pred %r669; .reg .u64 %r670; .reg .pred %r671; .reg .u64 %r675; .reg .u32 %r676; .reg .u16 %r677; .reg .u16 %r678; .reg .pred %r679; .reg .pred %r682; .reg .u32 %r684; .reg .u32 %r685; .reg .u32 %r687; .reg .u32 %r688; .reg .u16 %r689; .reg .u16 %r690; .reg .u16 %r691; .reg .u32 %r692; .reg .u16 %r693; .reg .pred %r694; .reg .u32 %r695; .reg .u64 %r697; .reg .pred %r698; .reg .u64 %r699; .reg .u32 %r717; .reg .u64 %r718; .reg .u64 %r719; .reg .u64 %r720; mov.u64 %r285,%ar0; mov.u64 %r286,%ar1; mov.u64 %r287,%ar2; mov.u64 %r288,%ar3; .loc 1 880 0 ld.u16 %r297,[%r286+16]; and.b16 %r296,%r297,128; setp.eq.u16 %r298,%r296,0; @ %r298 bra $L20; ld.u64 %r299,[%r286+24]; setp.ne.u64 %r300,%r299,0; @ %r300 bra $L20; .loc 1 882 0 mov.u64 %r302,64; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r302; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r303,[%value_in]; } st.u64 [%r286],%r303; st.u64 [%r286+24],%r303; .loc 1 883 0 setp.ne.u64 %r304,%r303,0; @ %r304 bra $L21; .loc 1 885 0 mov.u32 %r305,12; st.u32 [%r285],%r305; .loc 1 886 0 mov.u32 %r284,-1; bra $L19; $L21: .loc 1 888 0 cvt.u32.u64 %r306,%r302; st.u32 [%r286+32],%r306; $L20: .loc 1 894 0 st.u64 [%frame+168],%frame; .loc 1 895 0 mov.u64 %r307,0; st.u64 [%frame+184],%r307; .loc 1 896 0 cvt.u32.u64 %r308,%r307; st.u32 [%frame+176],%r308; .loc 1 894 0 mov.u64 %r196,%frame; .loc 1 718 0 mov.u64 %r80,%r307; .loc 1 898 0 cvt.u32.u64 %r284,%r80; .loc 1 929 0 add.u64 %r718,%frame,168; .loc 1 1694 0 add.u64 %r719,%frame,192; .loc 1 1692 0 add.u64 %r720,%frame,194; $L23: .loc 1 925 0 ld.s8 %r221,[%r287]; cvt.u16.u32 %r310,%r221; set.u32.ne.u16 %r311,%r310,0; neg.s32 %r312,%r311; set.u32.ne.u16 %r315,%r310,37; neg.s32 %r316,%r315; cvt.u16.u32 %r318,%r312; cvt.u16.u32 %r319,%r316; and.b16 %r317,%r318,%r319; cvt.u32.u16 %r320,%r317; cvt.u16.u8 %r321,%r320; setp.eq.u16 %r322,%r321,0; @ %r322 bra $L149; mov.u64 %r219,%r287; $L25: .loc 1 926 0 add.u64 %r219,%r219,1; .loc 1 925 0 ld.s8 %r200,[%r219]; cvt.u16.u32 %r324,%r200; set.u32.ne.u16 %r325,%r324,0; neg.s32 %r326,%r325; set.u32.ne.u16 %r329,%r324,37; neg.s32 %r330,%r329; cvt.u16.u32 %r332,%r326; cvt.u16.u32 %r333,%r330; and.b16 %r331,%r332,%r333; cvt.u32.u16 %r334,%r331; cvt.u16.u8 %r335,%r334; setp.ne.u16 %r336,%r335,0; @ %r336 bra $L25; sub.u64 %r337,%r219,%r287; cvt.u32.u64 %r250,%r337; .loc 1 928 0 setp.eq.u32 %r338,%r250,0; @ %r338 bra $L24; .loc 1 929 0 st.u64 [%r196],%r287; cvt.s64.s32 %r84,%r250; st.u64 [%r196+8],%r84; ld.u64 %r340,[%frame+184]; add.u64 %r339,%r340,%r84; st.u64 [%frame+184],%r339; ld.u32 %r341,[%frame+176]; add.u32 %r88,%r341,1; st.u32 [%frame+176],%r88; setp.gt.s32 %r342,%r88,7; @ %r342 bra $L26; add.u64 %r196,%r196,16; bra $L27; $L26: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r347,[%value_in]; } setp.ne.u32 %r348,%r347,0; @ %r348 bra $L28; mov.u64 %r196,%frame; $L27: .loc 1 930 0 add.u32 %r284,%r284,%r250; bra $L24; $L149: .loc 1 925 0 mov.u64 %r219,%r287; $L24: .loc 1 936 0 ld.s8 %r350,[%r219]; cvt.u16.u32 %r349,%r350; setp.eq.u16 %r351,%r349,0; @ %r351 bra $L29; .loc 1 940 0 add.u64 %r287,%r219,1; .loc 1 946 0 mov.u32 %r352,0; st.u8 [%frame+194],%r352; ld.s8 %r280,[%r219+1]; mov.u32 %r220,0; mov.u32 %r203,%r220; .loc 1 945 0 mov.u32 %r191,-1; .loc 1 944 0 mov.u32 %r190,%r220; .loc 1 942 0 mov.u32 %r188,%r220; .loc 1 1071 0 mov.u32 %r717,%r220; bra $L30; $L150: .loc 1 1018 0 mov.u64 %r288,%r234; $L30: .loc 1 958 0 add.u64 %r287,%r287,1; mov.u32 %r185,%r280; $L31: .loc 1 959 0 setp.eq.u32 %r353,%r185,88; @ %r353 bra $L33; setp.gt.s32 %r354,%r185,88; @ %r354 bra $L34; setp.eq.u32 %r355,%r185,46; @ %r355 bra $L35; setp.gt.s32 %r356,%r185,46; @ %r356 bra $L36; setp.eq.u32 %r357,%r185,42; @ %r357 bra $L37; setp.gt.s32 %r358,%r185,42; @ %r358 bra $L38; setp.eq.u32 %r359,%r185,32; @ %r359 bra $L39; setp.eq.u32 %r360,%r185,35; @ %r360 bra $L40; bra $L32; $L38: setp.eq.u32 %r361,%r185,43; @ %r361 bra $L41; setp.eq.u32 %r362,%r185,45; @ %r362 bra $L42; bra $L32; $L36: setp.gt.s32 %r363,%r185,57; @ %r363 bra $L43; setp.ge.s32 %r364,%r185,49; @ %r364 bra $L44; setp.eq.u32 %r365,%r185,48; @ %r365 bra $L45; bra $L32; $L43: setp.eq.u32 %r366,%r185,79; @ %r366 bra $L46; setp.eq.u32 %r367,%r185,85; @ %r367 bra $L47; setp.eq.u32 %r368,%r185,68; @ ! %r368 bra $L32; bra $L48; $L34: setp.eq.u32 %r369,%r185,110; @ %r369 bra $L49; setp.gt.s32 %r370,%r185,110; @ %r370 bra $L50; setp.eq.u32 %r371,%r185,104; @ %r371 bra $L51; setp.gt.s32 %r372,%r185,104; @ %r372 bra $L52; setp.eq.u32 %r373,%r185,99; @ %r373 bra $L53; setp.eq.u32 %r374,%r185,100; @ %r374 bra $L54; bra $L32; $L52: setp.eq.u32 %r375,%r185,105; @ %r375 bra $L54; setp.eq.u32 %r376,%r185,108; @ %r376 bra $L55; bra $L32; $L50: setp.eq.u32 %r377,%r185,113; @ %r377 bra $L56; setp.gt.s32 %r378,%r185,113; @ %r378 bra $L57; setp.eq.u32 %r379,%r185,111; @ %r379 bra $L58; setp.eq.u32 %r380,%r185,112; @ %r380 bra $L59; bra $L32; $L57: setp.eq.u32 %r381,%r185,117; @ %r381 bra $L60; setp.eq.u32 %r382,%r185,120; @ %r382 bra $L61; setp.eq.u32 %r383,%r185,115; @ ! %r383 bra $L32; bra $L62; $L42: ld.s8 %r280,[%r287]; bra $L63; $L33: setp.eq.u32 %r384,%r220,0; @ %r384 bra $L64; cvt.u32.u32 %r385,%r203; st.u8 [%frame+194],%r385; $L64: .loc 1 1542 0 cvta.const.u64 %r80,$LC0; bra $L65; $L54: setp.eq.u32 %r386,%r220,0; @ %r386 bra $L67; cvt.u32.u32 %r387,%r203; st.u8 [%frame+194],%r387; bra $L67; $L39: ld.s8 %r280,[%r287]; .loc 1 975 0 setp.ne.u32 %r388,%r203,0; selp.u32 %r220,%r220,1,%r388; selp.u32 %r203,%r203,32,%r388; bra $L30; $L40: .loc 1 979 0 or.b32 %r188,%r188,1; ld.s8 %r280,[%r287]; .loc 1 980 0 bra $L30; $L37: .loc 1 1018 0 add.u64 %r234,%r288,4; ld.u32 %r190,[%r288]; ld.s8 %r280,[%r287]; .loc 1 1022 0 setp.ge.s32 %r389,%r190,0; @ %r389 bra $L150; .loc 1 1024 0 neg.s32 %r190,%r190; .loc 1 1018 0 mov.u64 %r288,%r234; $L63: .loc 1 1027 0 or.b32 %r188,%r188,4; .loc 1 1028 0 bra $L30; $L41: ld.s8 %r280,[%r287]; .loc 1 1031 0 mov.u32 %r220,1; .loc 1 1030 0 mov.u32 %r203,%r185; .loc 1 1031 0 bra $L30; $L35: .loc 1 1033 0 add.u64 %r210,%r287,1; ld.s8 %r185,[%r287]; setp.eq.u32 %r390,%r185,42; @ %r390 bra $L69; .loc 1 1072 0 add.u32 %r695,%r185,-48; setp.le.u32 %r391,%r695,9; @ %r391 bra $L70; .loc 1 1033 0 mov.u64 %r287,%r210; .loc 1 1071 0 mov.u32 %r191,%r717; bra $L31; $L69: ld.u32 %r392,[%r288]; max.s32 %r191,%r392,-1; ld.s8 %r280,[%r287+1]; .loc 1 1063 0 add.u64 %r288,%r288,4; .loc 1 1033 0 mov.u64 %r287,%r210; bra $L30; $L70: mov.u64 %r197,%r210; .loc 1 1071 0 mov.u32 %r191,%r717; $L72: .loc 1 1073 0 shl.b32 %r394,%r191,2; add.u32 %r395,%r394,%r191; add.u32 %r396,%r395,%r395; add.u32 %r191,%r396,%r695; add.u64 %r287,%r197,1; .loc 1 1074 0 ld.s8 %r185,[%r197]; .loc 1 1072 0 add.u32 %r695,%r185,-48; mov.u64 %r197,%r287; setp.le.u32 %r397,%r695,9; @ %r397 bra $L72; bra $L31; $L45: .loc 1 1084 0 or.b32 %r188,%r188,128; ld.s8 %r280,[%r287]; .loc 1 1085 0 bra $L30; $L44: mov.u64 %r189,%r287; .loc 1 1088 0 mov.u32 %r190,0; add.u32 %r695,%r185,-48; $L73: .loc 1 1090 0 shl.b32 %r399,%r190,2; add.u32 %r400,%r399,%r190; add.u32 %r401,%r400,%r400; add.u32 %r190,%r695,%r401; add.u64 %r287,%r287,1; .loc 1 1091 0 ld.s8 %r185,[%r189]; mov.u64 %r189,%r287; .loc 1 1092 0 add.u32 %r695,%r185,-48; setp.le.u32 %r404,%r695,9; @ %r404 bra $L73; bra $L31; $L51: .loc 1 1118 0 or.b32 %r188,%r188,64; ld.s8 %r280,[%r287]; .loc 1 1119 0 bra $L30; $L55: .loc 1 1122 0 ld.s8 %r280,[%r287]; cvt.u16.u32 %r405,%r280; setp.ne.u16 %r406,%r405,108; @ %r406 bra $L74; .loc 1 1124 0 or.b32 %r188,%r188,32; ld.s8 %r280,[%r287+1]; .loc 1 1123 0 add.u64 %r287,%r287,1; bra $L30; $L74: .loc 1 1127 0 or.b32 %r188,%r188,16; bra $L30; $L56: .loc 1 1130 0 or.b32 %r188,%r188,32; ld.s8 %r280,[%r287]; .loc 1 1131 0 bra $L30; $L53: .loc 1 1189 0 ld.u32 %r407,[%r288]; st.u8 [%frame+128],%r407; .loc 1 1192 0 mov.u32 %r408,0; st.u8 [%frame+194],%r408; .loc 1 1189 0 add.u64 %r288,%r288,4; .loc 1 1193 0 mov.u32 %r194,1; .loc 1 1190 0 mov.u32 %r195,%r194; .loc 1 1173 0 add.u64 %r187,%frame,128; .loc 1 1193 0 bra $L75; $L48: setp.eq.u32 %r409,%r220,0; @ %r409 bra $L76; cvt.u32.u32 %r410,%r203; st.u8 [%frame+194],%r410; $L76: .loc 1 1195 0 or.b32 %r188,%r188,16; $L67: .loc 1 1199 0 and.b32 %r411,%r188,32; setp.eq.u32 %r412,%r411,0; @ %r412 bra $L77; add.u64 %r227,%r288,7; and.b64 %r226,%r227,-8; add.u64 %r288,%r226,8; ld.u64 %r192,[%r226]; bra $L78; $L77: and.b32 %r413,%r188,16; setp.eq.u32 %r414,%r413,0; @ %r414 bra $L79; add.u64 %r223,%r288,7; and.b64 %r228,%r223,-8; add.u64 %r288,%r228,8; ld.u64 %r192,[%r228]; bra $L78; $L79: ld.u32 %r279,[%r288]; add.u64 %r288,%r288,4; and.b32 %r415,%r188,64; setp.eq.u32 %r416,%r415,0; @ %r416 bra $L80; cvt.u16.u32 %r417,%r279; cvt.s64.s16 %r192,%r417; bra $L78; $L80: cvt.s64.s32 %r192,%r279; $L78: .loc 1 1201 0 setp.ge.s64 %r418,%r192,0; @ %r418 bra $L81; .loc 1 1207 0 neg.s64 %r192,%r192; .loc 1 1208 0 mov.u32 %r419,45; st.u8 [%frame+194],%r419; bra $L81; $L49: setp.eq.u32 %r420,%r220,0; @ %r420 bra $L82; cvt.u32.u32 %r421,%r203; st.u8 [%frame+194],%r421; $L82: add.u64 %r422,%r288,7; and.b64 %r252,%r422,-8; ld.u64 %r253,[%r252]; add.u64 %r288,%r252,8; .loc 1 1392 0 and.b32 %r423,%r188,32; setp.eq.u32 %r424,%r423,0; @ %r424 bra $L83; .loc 1 1393 0 cvt.s64.s32 %r425,%r284; st.u64 [%r253],%r425; bra $L23; $L83: .loc 1 1396 0 and.b32 %r426,%r188,16; setp.eq.u32 %r427,%r426,0; @ %r427 bra $L85; .loc 1 1397 0 cvt.s64.s32 %r428,%r284; st.u64 [%r253],%r428; bra $L23; $L85: .loc 1 1398 0 and.b32 %r429,%r188,64; setp.eq.u32 %r430,%r429,0; @ %r430 bra $L86; .loc 1 1399 0 st.u16 [%r253],%r284; bra $L23; $L86: .loc 1 1405 0 st.u32 [%r253],%r284; bra $L23; $L46: .loc 1 1408 0 or.b32 %r188,%r188,16; $L58: .loc 1 1411 0 and.b32 %r431,%r188,32; setp.eq.u32 %r432,%r431,0; @ %r432 bra $L87; add.u64 %r238,%r288,7; and.b64 %r239,%r238,-8; add.u64 %r288,%r239,8; ld.u64 %r192,[%r239]; .loc 1 1412 0 mov.u32 %r193,0; bra $L88; $L87: .loc 1 1411 0 and.b32 %r433,%r188,16; setp.eq.u32 %r434,%r433,0; @ %r434 bra $L89; add.u64 %r240,%r288,7; and.b64 %r241,%r240,-8; add.u64 %r288,%r241,8; ld.u64 %r192,[%r241]; .loc 1 1412 0 mov.u32 %r193,%r431; bra $L88; $L89: ld.u32 %r278,[%r288]; add.u64 %r288,%r288,4; .loc 1 1411 0 and.b32 %r435,%r188,64; setp.eq.u32 %r436,%r435,0; @ %r436 bra $L90; cvt.u16.u32 %r437,%r278; cvt.u64.u16 %r192,%r437; .loc 1 1412 0 mov.u32 %r193,%r433; bra $L88; $L90: .loc 1 1411 0 cvt.u64.u32 %r192,%r278; .loc 1 1412 0 mov.u32 %r193,%r435; bra $L88; $L59: .loc 1 1426 0 add.u64 %r208,%r288,7; and.b64 %r209,%r208,-8; add.u64 %r288,%r209,8; ld.u64 %r192,[%r209]; .loc 1 1429 0 or.b32 %r188,%r188,2; .loc 1 1430 0 mov.u32 %r438,48; st.u8 [%frame+192],%r438; .loc 1 1431 0 mov.u32 %r439,120; st.u8 [%frame+193],%r439; .loc 1 1428 0 cvta.const.u64 %r80,$LC1; .loc 1 1427 0 mov.u32 %r193,2; .loc 1 1432 0 bra $L88; $L62: .loc 1 1437 0 add.u64 %r183,%r288,7; and.b64 %r242,%r183,-8; add.u64 %r288,%r242,8; ld.u64 %r187,[%r242]; .loc 1 1441 0 mov.u32 %r440,0; st.u8 [%frame+194],%r440; .loc 1 1447 0 setp.ne.u64 %r441,%r187,0; @ %r441 bra $L91; .loc 1 1449 0 min.u32 %r195,%r191,6; mov.u32 %r194,%r195; .loc 1 1448 0 cvta.const.u64 %r187,$LC2; bra $L75; $L91: .loc 1 1516 0 setp.eq.u32 %r442,%r191,-1; @ %r442 bra $L92; .loc 1 1522 0 cvt.s64.s32 %r446,%r191; mov.u32 %r444,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r187; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r444; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r446; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r447,[%value_in]; } .loc 1 1524 0 setp.eq.u64 %r448,%r447,0; @ %r448 bra $L93; .loc 1 1525 0 sub.u64 %r449,%r447,%r187; cvt.u32.u64 %r450,%r449; min.s32 %r195,%r191,%r450; ld.s8 %r281,[%frame+194]; .loc 1 943 0 mov.u32 %r191,%r444; bra $L94; $L92: .loc 1 1531 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r187; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r452,[%value_in]; } cvt.u32.u64 %r195,%r452; ld.s8 %r281,[%frame+194]; .loc 1 943 0 mov.u32 %r191,0; bra $L94; $L47: .loc 1 1535 0 or.b32 %r188,%r188,16; $L60: .loc 1 1538 0 and.b32 %r453,%r188,32; setp.eq.u32 %r454,%r453,0; @ %r454 bra $L95; add.u64 %r235,%r288,7; and.b64 %r236,%r235,-8; add.u64 %r288,%r236,8; ld.u64 %r192,[%r236]; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L95: .loc 1 1538 0 and.b32 %r455,%r188,16; setp.eq.u32 %r456,%r455,0; @ %r456 bra $L96; add.u64 %r230,%r288,7; and.b64 %r229,%r230,-8; add.u64 %r288,%r229,8; ld.u64 %r192,[%r229]; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L96: ld.u32 %r277,[%r288]; add.u64 %r288,%r288,4; .loc 1 1538 0 and.b32 %r457,%r188,64; setp.eq.u32 %r458,%r457,0; @ %r458 bra $L97; cvt.u16.u32 %r459,%r277; cvt.u64.u16 %r192,%r459; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L97: .loc 1 1538 0 cvt.u64.u32 %r192,%r277; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L61: setp.eq.u32 %r460,%r220,0; @ %r460 bra $L98; cvt.u32.u32 %r461,%r203; st.u8 [%frame+194],%r461; $L98: .loc 1 1545 0 cvta.const.u64 %r80,$LC1; $L65: .loc 1 1546 0 and.b32 %r462,%r188,32; setp.eq.u32 %r463,%r462,0; @ %r463 bra $L99; add.u64 %r237,%r288,7; and.b64 %r224,%r237,-8; add.u64 %r288,%r224,8; ld.u64 %r192,[%r224]; bra $L100; $L99: and.b32 %r464,%r188,16; setp.eq.u32 %r465,%r464,0; @ %r465 bra $L101; add.u64 %r232,%r288,7; and.b64 %r231,%r232,-8; add.u64 %r288,%r231,8; ld.u64 %r192,[%r231]; bra $L100; $L101: ld.u32 %r276,[%r288]; add.u64 %r288,%r288,4; and.b32 %r466,%r188,64; setp.eq.u32 %r467,%r466,0; @ %r467 bra $L102; cvt.u16.u32 %r468,%r276; cvt.u64.u16 %r192,%r468; bra $L100; $L102: cvt.u64.u32 %r192,%r276; $L100: .loc 1 1549 0 and.b32 %r469,%r188,1; setp.eq.u32 %r470,%r469,0; @ %r470 bra $L151; setp.eq.u64 %r471,%r192,0; @ %r471 bra $L152; .loc 1 1550 0 mov.u32 %r472,48; st.u8 [%frame+192],%r472; .loc 1 1551 0 st.u8 [%frame+193],%r185; .loc 1 1552 0 or.b32 %r188,%r188,2; .loc 1 1547 0 mov.u32 %r193,2; bra $L88; $L151: mov.u32 %r193,2; bra $L88; $L152: mov.u32 %r193,2; $L88: .loc 1 1559 0 mov.u32 %r473,0; st.u8 [%frame+194],%r473; .loc 1 1565 0 setp.eq.u32 %r475,%r191,-1; @ %r475 bra $L153; .loc 1 1566 0 and.b32 %r204,%r188,-129; .loc 1 1574 0 set.u32.ne.u64 %r477,%r192,0; neg.s32 %r478,%r477; set.u32.ne.u32 %r480,%r191,0; neg.s32 %r481,%r480; cvt.u16.u32 %r483,%r478; cvt.u16.u32 %r484,%r481; or.b16 %r482,%r483,%r484; cvt.u32.u16 %r485,%r482; cvt.u16.u8 %r486,%r485; setp.eq.u16 %r487,%r486,0; @ %r487 bra $L104; bra $L147; $L161: mov.u32 %r193,1; $L147: ld.s8 %r281,[%frame+194]; mov.u32 %r188,%r204; bra $L103; $L153: mov.u32 %r281,0; $L103: .loc 1 1580 0 cvt.u16.u32 %r488,%r193; setp.eq.u16 %r489,%r488,1; @ %r489 bra $L106; setp.eq.u16 %r491,%r488,2; @ %r491 bra $L154; .loc 1 1573 0 mov.u64 %r186,%r718; bra $L105; $L156: .loc 1 1581 0 mov.u64 %r186,%r187; $L105: .loc 1 1583 0 add.u64 %r187,%r186,-1; cvt.u16.u64 %r494,%r192; and.b16 %r493,%r494,7; add.u16 %r496,%r493,48; cvt.u32.u16 %r498,%r496; cvt.s32.s8 %r145,%r498; st.u8 [%r187],%r498; .loc 1 1584 0 shr.u64 %r192,%r192,3; .loc 1 1585 0 setp.ne.u64 %r500,%r192,0; @ %r500 bra $L156; .loc 1 1587 0 cvt.u16.u32 %r502,%r145; set.u32.ne.u16 %r503,%r502,48; neg.s32 %r504,%r503; cvt.u16.u32 %r507,%r188; and.b16 %r506,%r507,1; cvt.u16.u32 %r510,%r504; and.b16 %r509,%r510,%r506; cvt.u32.u16 %r512,%r509; cvt.u16.u8 %r513,%r512; setp.ne.u16 %r514,%r513,0; @ %r514 bra $L108; sub.u64 %r515,%r718,%r187; cvt.u32.u64 %r195,%r515; bra $L94; $L108: .loc 1 1588 0 add.u64 %r207,%r186,-2; mov.u32 %r516,48; st.u8 [%r187+-1],%r516; sub.u64 %r517,%r718,%r207; cvt.u32.u64 %r195,%r517; mov.u64 %r187,%r207; bra $L94; $L106: .loc 1 1593 0 setp.gt.u64 %r518,%r192,9; @ %r518 bra $L157; .loc 1 1594 0 cvt.u16.u64 %r521,%r192; add.u16 %r520,%r521,48; cvt.u32.u16 %r522,%r520; st.u8 [%frame+167],%r522; .loc 1 1595 0 mov.u32 %r195,1; .loc 1 1594 0 add.u64 %r187,%frame,167; .loc 1 1595 0 bra $L94; $L157: .loc 1 1573 0 mov.u64 %r187,%r718; $L110: .loc 1 1601 0 add.u64 %r187,%r187,-1; rem.u64 %r524,%r192,10; cvt.u16.u64 %r527,%r524; add.u16 %r526,%r527,48; cvt.u32.u16 %r528,%r526; st.u8 [%r187],%r528; .loc 1 1622 0 div.u64 %r192,%r192,10; .loc 1 1623 0 setp.ne.u64 %r531,%r192,0; @ %r531 bra $L110; sub.u64 %r532,%r718,%r187; cvt.u32.u64 %r195,%r532; bra $L94; $L154: .loc 1 1573 0 mov.u64 %r187,%r718; $L107: .loc 1 1628 0 add.u64 %r187,%r187,-1; and.b64 %r533,%r192,15; add.u64 %r534,%r80,%r533; ld.u8 %r535,[%r534]; st.u8 [%r187],%r535; .loc 1 1629 0 shr.u64 %r192,%r192,4; .loc 1 1630 0 setp.ne.u64 %r536,%r192,0; @ %r536 bra $L107; sub.u64 %r537,%r718,%r187; cvt.u32.u64 %r195,%r537; bra $L94; $L104: .loc 1 1648 0 setp.eq.u32 %r538,%r193,0; @ %r538 bra $L111; $L148: ld.s8 %r281,[%frame+194]; .loc 1 1594 0 mov.u32 %r188,%r204; mov.u32 %r191,0; mov.u32 %r195,%r191; .loc 1 1573 0 mov.u64 %r187,%r718; bra $L94; $L111: .loc 1 1648 0 and.b32 %r195,%r188,1; setp.ne.u32 %r539,%r195,0; @ %r539 bra $L112; mov.u32 %r191,%r193; mov.u32 %r281,%r191; .loc 1 1566 0 mov.u32 %r188,%r204; .loc 1 1573 0 mov.u64 %r187,%r718; bra $L94; $L112: .loc 1 1649 0 mov.u32 %r540,48; st.u8 [%frame+167],%r540; mov.u32 %r281,%r193; .loc 1 1566 0 mov.u32 %r188,%r204; .loc 1 1649 0 mov.u32 %r191,%r281; add.u64 %r187,%frame,167; bra $L94; $L32: setp.eq.u32 %r541,%r220,0; @ %r541 bra $L113; cvt.u32.u32 %r542,%r203; st.u8 [%frame+194],%r542; $L113: .loc 1 1655 0 setp.eq.u32 %r543,%r185,0; @ %r543 bra $L29; .loc 1 1659 0 st.u8 [%frame+128],%r185; .loc 1 1661 0 mov.u32 %r544,0; st.u8 [%frame+194],%r544; .loc 1 1662 0 mov.u32 %r194,1; .loc 1 1660 0 mov.u32 %r195,%r194; .loc 1 1658 0 add.u64 %r187,%frame,128; .loc 1 1662 0 bra $L75; $L93: ld.s8 %r281,[%frame+194]; .loc 1 1524 0 mov.u32 %r195,%r191; .loc 1 943 0 cvt.u32.u64 %r191,%r447; $L94: .loc 1 1680 0 max.s32 %r194,%r191,%r195; .loc 1 1681 0 setp.eq.u32 %r545,%r281,0; @ %r545 bra $L114; .loc 1 1682 0 add.u32 %r194,%r194,1; $L114: .loc 1 1683 0 and.b32 %r157,%r188,2; setp.eq.u32 %r698,%r157,0; @ %r698 bra $L115; .loc 1 1684 0 add.u32 %r194,%r194,2; $L115: .loc 1 1687 0 and.b32 %r158,%r188,132; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; setp.ne.u32 %r547,%r158,0; @ %r547 bra $L116; .loc 1 1688 0 sub.u32 %r205,%r190,%r194; setp.le.s32 %r548,%r205,0; @ %r548 bra $L116; setp.le.s32 %r549,%r205,16; @ ! %r549 bra $L234; cvta.const.u64 %r699,blanks$4046; bra $L117; $L234: cvta.const.u64 %r699,blanks$4046; $L120: st.u64 [%r196],%r699; mov.u64 %r551,16; st.u64 [%r196+8],%r551; add.u64 %r255,%r255,16; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r552,%r256,7; @ %r552 bra $L118; add.u64 %r196,%r196,16; bra $L119; $L118: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r557,[%value_in]; } setp.ne.u32 %r558,%r557,0; @ %r558 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L119: add.u32 %r205,%r205,-16; setp.gt.s32 %r559,%r205,16; @ %r559 bra $L120; $L117: st.u64 [%r196],%r699; cvt.s64.s32 %r160,%r205; st.u64 [%r196+8],%r160; add.u64 %r255,%r255,%r160; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r561,%r256,7; @ %r561 bra $L121; add.u64 %r196,%r196,16; bra $L116; $L121: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r566,[%value_in]; } setp.ne.u32 %r567,%r566,0; @ %r567 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L116: add.u32 %r257,%r256,1; add.u64 %r258,%r196,16; .loc 1 1691 0 ld.s8 %r569,[%frame+194]; cvt.u16.u32 %r568,%r569; setp.eq.u16 %r570,%r568,0; @ %r570 bra $L122; .loc 1 1692 0 st.u64 [%r196],%r720; mov.u64 %r572,1; st.u64 [%r196+8],%r572; add.u64 %r255,%r255,1; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r257; setp.gt.s32 %r573,%r257,7; @ %r573 bra $L123; add.u32 %r259,%r256,2; add.u64 %r260,%r196,32; mov.u32 %r256,%r257; mov.u32 %r257,%r259; mov.u64 %r196,%r258; mov.u64 %r258,%r260; bra $L122; $L123: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r578,[%value_in]; } setp.ne.u32 %r579,%r578,0; @ %r579 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; add.u32 %r257,%r256,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L122: .loc 1 1693 0 @ %r698 bra $L124; .loc 1 1694 0 st.u64 [%r196],%r719; mov.u64 %r582,2; st.u64 [%r196+8],%r582; add.u64 %r255,%r255,2; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r257; setp.gt.s32 %r583,%r257,7; @ %r583 bra $L125; mov.u32 %r256,%r257; add.u32 %r257,%r257,1; mov.u64 %r196,%r258; add.u64 %r258,%r258,16; bra $L124; $L125: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r588,[%value_in]; } setp.ne.u32 %r589,%r588,0; @ %r589 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; add.u32 %r257,%r256,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L124: .loc 1 1697 0 setp.ne.u32 %r590,%r158,128; @ %r590 bra $L126; .loc 1 1698 0 sub.u32 %r214,%r190,%r194; setp.le.s32 %r591,%r214,0; @ %r591 bra $L126; setp.le.s32 %r592,%r214,16; @ %r592 bra $L158; cvta.const.u64 %r697,zeroes$4047; $L130: st.u64 [%r196],%r697; mov.u64 %r594,16; st.u64 [%r196+8],%r594; add.u64 %r255,%r255,16; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r595,%r256,7; @ %r595 bra $L128; add.u64 %r196,%r196,16; bra $L129; $L128: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r600,[%value_in]; } setp.ne.u32 %r601,%r600,0; @ %r601 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L129: add.u32 %r214,%r214,-16; setp.gt.s32 %r602,%r214,16; @ %r602 bra $L130; add.u32 %r256,%r256,1; add.u64 %r267,%r196,16; bra $L127; $L158: mov.u64 %r267,%r258; mov.u32 %r256,%r257; cvta.const.u64 %r697,zeroes$4047; $L127: st.u64 [%r196],%r697; cvt.s64.s32 %r167,%r214; st.u64 [%r196+8],%r167; add.u64 %r255,%r255,%r167; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r256; setp.gt.s32 %r604,%r256,7; @ %r604 bra $L131; add.u32 %r257,%r256,1; add.u64 %r258,%r267,16; mov.u64 %r196,%r267; bra $L126; $L131: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r609,[%value_in]; } setp.ne.u32 %r610,%r609,0; @ %r610 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; add.u32 %r257,%r256,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L126: .loc 1 1701 0 sub.u32 %r198,%r191,%r195; setp.le.s32 %r611,%r198,0; @ %r611 bra $L132; setp.le.s32 %r612,%r198,16; @ %r612 bra $L159; cvta.const.u64 %r697,zeroes$4047; $L136: st.u64 [%r196],%r697; mov.u64 %r614,16; st.u64 [%r196+8],%r614; add.u64 %r255,%r255,16; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r615,%r256,7; @ %r615 bra $L134; add.u64 %r196,%r196,16; bra $L135; $L134: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r620,[%value_in]; } setp.ne.u32 %r621,%r620,0; @ %r621 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L135: add.u32 %r198,%r198,-16; setp.gt.s32 %r622,%r198,16; @ %r622 bra $L136; add.u32 %r257,%r256,1; add.u64 %r266,%r196,16; bra $L133; $L159: mov.u64 %r266,%r258; cvta.const.u64 %r697,zeroes$4047; $L133: st.u64 [%r196],%r697; cvt.s64.s32 %r171,%r198; st.u64 [%r196+8],%r171; add.u64 %r255,%r255,%r171; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r257; setp.gt.s32 %r624,%r257,7; @ %r624 bra $L137; add.u32 %r257,%r257,1; add.u64 %r258,%r266,16; mov.u64 %r196,%r266; bra $L132; $L137: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r629,[%value_in]; } setp.ne.u32 %r630,%r629,0; @ %r630 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r631,[%frame+176]; add.u32 %r257,%r631,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L132: .loc 1 1767 0 st.u64 [%r196],%r187; cvt.s64.s32 %r173,%r195; st.u64 [%r196+8],%r173; add.u64 %r264,%r173,%r255; st.u64 [%frame+184],%r264; st.u32 [%frame+176],%r257; setp.le.s32 %r632,%r257,7; @ %r632 bra $L138; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r637,[%value_in]; } setp.ne.u32 %r638,%r637,0; @ %r638 bra $L28; ld.u64 %r264,[%frame+184]; mov.u64 %r258,%frame; $L138: .loc 1 1770 0 and.b32 %r639,%r188,4; setp.eq.u32 %r640,%r639,0; @ %r640 bra $L139; .loc 1 1771 0 sub.u32 %r168,%r190,%r194; setp.le.s32 %r641,%r168,0; @ %r641 bra $L139; ld.u32 %r265,[%frame+176]; setp.le.s32 %r642,%r168,16; @ ! %r642 bra $L235; cvta.const.u64 %r699,blanks$4046; bra $L140; $L235: cvta.const.u64 %r699,blanks$4046; $L143: st.u64 [%r258],%r699; mov.u64 %r644,16; st.u64 [%r258+8],%r644; add.u64 %r264,%r264,16; st.u64 [%frame+184],%r264; add.u32 %r265,%r265,1; st.u32 [%frame+176],%r265; setp.gt.s32 %r645,%r265,7; @ %r645 bra $L141; add.u64 %r258,%r258,16; bra $L142; $L141: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r650,[%value_in]; } setp.ne.u32 %r651,%r650,0; @ %r651 bra $L28; ld.u64 %r264,[%frame+184]; ld.u32 %r265,[%frame+176]; mov.u64 %r258,%frame; $L142: add.u32 %r168,%r168,-16; setp.gt.s32 %r652,%r168,16; @ %r652 bra $L143; $L140: st.u64 [%r258],%r699; cvt.s64.s32 %r177,%r168; st.u64 [%r258+8],%r177; add.u64 %r264,%r264,%r177; st.u64 [%frame+184],%r264; add.u32 %r178,%r265,1; st.u32 [%frame+176],%r178; setp.le.s32 %r654,%r178,7; @ %r654 bra $L139; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r659,[%value_in]; } setp.ne.u32 %r660,%r659,0; @ %r660 bra $L28; ld.u64 %r264,[%frame+184]; $L139: .loc 1 1774 0 max.s32 %r661,%r190,%r194; add.u32 %r284,%r284,%r661; .loc 1 1776 0 setp.ne.u64 %r662,%r264,0; @ %r662 bra $L144; $L145: mov.u32 %r663,0; st.u32 [%frame+176],%r663; mov.u64 %r196,%frame; bra $L23; $L144: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r668,[%value_in]; } setp.ne.u32 %r669,%r668,0; @ ! %r669 bra $L145; .loc 1 1785 0 bra $L28; $L29: .loc 1 1784 0 ld.u64 %r670,[%frame+184]; setp.eq.u64 %r671,%r670,0; @ %r671 bra $L28; add.u64 %r675,%frame,168; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r675; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r676,[%value_in]; } $L28: .loc 1 1791 0 ld.u16 %r678,[%r286+16]; and.b16 %r677,%r678,64; setp.ne.u16 %r679,%r677,0; selp.u32 %r284,-1,%r284,%r679; bra $L19; $L81: .loc 1 1565 0 setp.ne.u32 %r682,%r191,-1; @ %r682 bra $L146; ld.s8 %r281,[%frame+194]; bra $L106; $L75: .loc 1 943 0 mov.u32 %r191,0; bra $L114; $L146: .loc 1 1566 0 and.b32 %r204,%r188,-129; .loc 1 1574 0 set.u32.ne.u32 %r684,%r191,0; neg.s32 %r685,%r684; set.u32.ne.u64 %r687,%r192,0; neg.s32 %r688,%r687; cvt.u16.u32 %r690,%r685; cvt.u16.u32 %r691,%r688; or.b16 %r689,%r690,%r691; cvt.u32.u16 %r692,%r689; cvt.u16.u8 %r693,%r692; setp.ne.u16 %r694,%r693,0; @ ! %r694 bra $L148; bra $L161; $L19: .loc 1 1793 0 mov.u32 %value,%r284; st.param.u32 [%value_out],%value; ret; } /847 0 0 0 644 74459 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .visible .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdio/vfprintf.c" // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ssprint_r .extern .func (.param .u32 %value_out) __ssprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN VAR DEF: blanks$4102 .const .align 1 .u8 blanks$4102[16] = {32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {73,78,70,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {105,110,102,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {110,97,110,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[17] = {48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[17] = {48,49,50,51,52,53,54,55,56,57,97,98,99,100,101,102,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[7] = {40,110,117,108,108,41,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[4] = {78,65,78,0 }; // BEGIN VAR DEF: zeroes$4103 .const .align 1 .u8 zeroes$4103[16] = {48,48,48,48,48,48,48,48,48,48,48,48,48,48,48,48 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[2] = {48,0 }; // BEGIN GLOBAL FUNCTION DEF: _svfprintf_r .visible .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[224]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r118; .reg .u64 %r122; .reg .u32 %r126; .reg .u32 %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r189; .reg .u64 %r201; .reg .u32 %r203; .reg .u32 %r204; .reg .u64 %r206; .reg .u32 %r207; .reg .u32 %r210; .reg .u32 %r214; .reg .u64 %r218; .reg .u32 %r219; .reg .u32 %r221; .reg .u64 %r223; .reg .u32 %r224; .reg .u64 %r227; .reg .u32 %r228; .reg .u32 %r230; .reg .u32 %r234; .reg .u32 %r240; .reg .u64 %r244; .reg .u32 %r245; .reg .u32 %r247; .reg .u32 %r249; .reg .u64 %r255; .reg .u32 %r256; .reg .u64 %r258; .reg .u32 %r259; .reg .u64 %r261; .reg .u32 %r263; .reg .u32 %r265; .reg .u64 %r267; .reg .u32 %r268; .reg .u32 %r271; .reg .u32 %r274; .reg .u32 %r277; .reg .u32 %r278; .reg .u64 %r279; .reg .u32 %r281; .reg .u32 %r283; .reg .u32 %r284; .reg .u64 %r286; .reg .u32 %r287; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r297; .reg .u64 %r300; .reg .u64 %r304; .reg .u32 %r305; .reg .u32 %r311; .reg .u64 %r312; .reg .u64 %r313; .reg .u32 %r314; .reg .u32 %r315; .reg .u32 %r316; .reg .u32 %r317; .reg .u64 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u64 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u64 %r327; .reg .u32 %r333; .reg .u32 %r334; .reg .f64 %r335; .reg .u32 %r340; .reg .u32 %r342; .reg .u64 %r343; .reg .u32 %r347; .reg .u32 %r350; .reg .u64 %r351; .reg .u64 %r352; .reg .u64 %r353; .reg .u32 %r354; .reg .u64 %r355; .reg .u32 %r356; .reg .u64 %r359; .reg .u32 %r361; .reg .f64 %r368; .reg .u64 %r369; .reg .u64 %r370; .reg .u32 %r371; .reg .u64 %r375; .reg .u32 %r381; .reg .u64 %r385; .reg .u32 %r390; .reg .u64 %r394; .reg .u64 %r398; .reg .u64 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .u64 %r402; .reg .u64 %r403; .reg .u64 %r404; .reg .u64 %r406; .reg .u64 %r407; .reg .u64 %r408; .reg .u64 %r409; .reg .u64 %r410; .reg .u64 %r411; .reg .u64 %r412; .reg .u64 %r415; .reg .u64 %r416; .reg .u64 %r418; .reg .u64 %r421; .reg .u64 %r422; .reg .u64 %r423; .reg .u64 %r424; .reg .u64 %r426; .reg .u64 %r434; .reg .u32 %r441; .reg .u64 %r443; .reg .u64 %r444; .reg .u64 %r447; .reg .u32 %r448; .reg .u32 %r450; .reg .u32 %r451; .reg .u32 %r452; .reg .u64 %r453; .reg .u32 %r454; .reg .u32 %r458; .reg .u32 %r459; .reg .u64 %r460; .reg .u32 %r461; .reg .u64 %r462; .reg .u32 %r464; .reg .u32 %r465; .reg .u64 %r466; .reg .u32 %r467; .reg .u32 %r468; .reg .u32 %r469; .reg .u32 %r470; .reg .u32 %r471; .reg .u32 %r480; .reg .u32 %r481; .reg .u32 %r482; .reg .u32 %r483; .reg .u32 %r484; .reg .u32 %r485; .reg .u64 %r486; .reg .u32 %r489; .reg .u64 %r490; .reg .u64 %r491; .reg .u64 %r492; .reg .u64 %r493; .reg .u64 %r505; .reg .u64 %r507; .reg .u16 %r508; .reg .u16 %r509; .reg .pred %r510; .reg .u64 %r511; .reg .pred %r512; .reg .u64 %r514; .reg .u64 %r515; .reg .pred %r516; .reg .u32 %r517; .reg .u32 %r518; .reg .u64 %r519; .reg .u32 %r520; .reg .u16 %r522; .reg .u32 %r523; .reg .u32 %r524; .reg .u32 %r527; .reg .u32 %r528; .reg .u16 %r529; .reg .u16 %r530; .reg .u16 %r531; .reg .u32 %r532; .reg .u16 %r533; .reg .pred %r534; .reg .u16 %r536; .reg .u32 %r537; .reg .u32 %r538; .reg .u32 %r541; .reg .u32 %r542; .reg .u16 %r543; .reg .u16 %r544; .reg .u16 %r545; .reg .u32 %r546; .reg .u16 %r547; .reg .pred %r548; .reg .u64 %r549; .reg .pred %r550; .reg .u64 %r551; .reg .u64 %r552; .reg .u32 %r553; .reg .pred %r554; .reg .u32 %r559; .reg .pred %r560; .reg .u16 %r561; .reg .u32 %r562; .reg .pred %r563; .reg .u32 %r564; .reg .pred %r565; .reg .pred %r566; .reg .pred %r567; .reg .pred %r568; .reg .pred %r569; .reg .pred %r570; .reg .pred %r571; .reg .pred %r572; .reg .pred %r573; .reg .pred %r574; .reg .pred %r575; .reg .pred %r576; .reg .pred %r577; .reg .pred %r578; .reg .pred %r579; .reg .pred %r580; .reg .pred %r581; .reg .pred %r582; .reg .pred %r583; .reg .pred %r584; .reg .pred %r585; .reg .pred %r586; .reg .pred %r587; .reg .pred %r588; .reg .pred %r589; .reg .pred %r590; .reg .pred %r591; .reg .pred %r592; .reg .pred %r593; .reg .pred %r594; .reg .pred %r595; .reg .pred %r596; .reg .pred %r597; .reg .pred %r598; .reg .pred %r599; .reg .pred %r600; .reg .u32 %r601; .reg .pred %r602; .reg .u32 %r603; .reg .pred %r604; .reg .pred %r605; .reg .pred %r606; .reg .pred %r607; .reg .u32 %r608; .reg .u32 %r610; .reg .u32 %r611; .reg .u32 %r612; .reg .pred %r613; .reg .u32 %r615; .reg .u32 %r616; .reg .u32 %r617; .reg .pred %r620; .reg .u16 %r621; .reg .pred %r622; .reg .u32 %r623; .reg .u32 %r624; .reg .pred %r625; .reg .u32 %r626; .reg .u32 %r627; .reg .pred %r628; .reg .u32 %r629; .reg .pred %r630; .reg .u32 %r631; .reg .pred %r632; .reg .u16 %r633; .reg .pred %r634; .reg .u32 %r635; .reg .pred %r636; .reg .u32 %r637; .reg .u64 %r638; .reg .u32 %r642; .reg .pred %r643; .reg .pred %r644; .reg .u32 %r645; .reg .pred %r646; .reg .u32 %r648; .reg .pred %r649; .reg .pred %r650; .reg .pred %r651; .reg .u32 %r653; .reg .u32 %r654; .reg .u32 %r656; .reg .u32 %r657; .reg .u16 %r658; .reg .u16 %r659; .reg .u16 %r660; .reg .u32 %r661; .reg .u16 %r662; .reg .pred %r663; .reg .u64 %r664; .reg .u64 %r665; .reg .u32 %r666; .reg .pred %r667; .reg .pred %r668; .reg .pred %r669; .reg .u32 %r672; .reg .u64 %r680; .reg .u32 %r681; .reg .u64 %r682; .reg .u64 %r683; .reg .pred %r684; .reg .u64 %r685; .reg .u32 %r686; .reg .pred %r687; .reg .pred %r688; .reg .u64 %r689; .reg .u32 %r692; .reg .u32 %r693; .reg .u32 %r695; .reg .u32 %r696; .reg .u16 %r697; .reg .u16 %r698; .reg .u16 %r699; .reg .u32 %r700; .reg .u16 %r701; .reg .pred %r702; .reg .pred %r703; .reg .pred %r704; .reg .u32 %r705; .reg .u32 %r706; .reg .u32 %r707; .reg .pred %r708; .reg .u32 %r712; .reg .u16 %r714; .reg .u16 %r715; .reg .u32 %r716; .reg .pred %r721; .reg .u16 %r723; .reg .u16 %r724; .reg .u32 %r725; .reg .pred %r729; .reg .u32 %r731; .reg .pred %r734; .reg .u64 %r741; .reg .u32 %r742; .reg .u16 %r744; .reg .u16 %r745; .reg .u32 %r746; .reg .u64 %r748; .reg .pred %r749; .reg .pred %r750; .reg .pred %r751; .reg .pred %r752; .reg .u32 %r753; .reg .pred %r754; .reg .u32 %r755; .reg .pred %r756; .reg .u32 %r757; .reg .pred %r758; .reg .pred %r759; .reg .u32 %r760; .reg .pred %r761; .reg .pred %r762; .reg .u32 %r763; .reg .pred %r764; .reg .u32 %r765; .reg .pred %r766; .reg .u32 %r767; .reg .u64 %r768; .reg .u32 %r769; .reg .pred %r770; .reg .u64 %r771; .reg .u32 %r772; .reg .pred %r773; .reg .u64 %r774; .reg .u32 %r775; .reg .pred %r776; .reg .u32 %r777; .reg .pred %r778; .reg .u32 %r779; .reg .pred %r780; .reg .u32 %r781; .reg .pred %r782; .reg .u16 %r783; .reg .u32 %r784; .reg .u32 %r785; .reg .u32 %r786; .reg .pred %r787; .reg .pred %r788; .reg .u32 %r790; .reg .u64 %r792; .reg .u64 %r793; .reg .pred %r794; .reg .u64 %r795; .reg .u32 %r796; .reg .u64 %r798; .reg .u32 %r799; .reg .pred %r800; .reg .u32 %r801; .reg .pred %r802; .reg .u32 %r803; .reg .pred %r804; .reg .u16 %r805; .reg .pred %r806; .reg .u32 %r807; .reg .u32 %r808; .reg .pred %r809; .reg .u32 %r810; .reg .pred %r811; .reg .u32 %r812; .reg .pred %r813; .reg .u16 %r814; .reg .u32 %r815; .reg .pred %r816; .reg .pred %r817; .reg .u32 %r818; .reg .u32 %r819; .reg .pred %r821; .reg .u32 %r823; .reg .u32 %r824; .reg .u32 %r826; .reg .u32 %r827; .reg .u16 %r828; .reg .u16 %r829; .reg .u16 %r830; .reg .u32 %r831; .reg .u16 %r832; .reg .pred %r833; .reg .u16 %r834; .reg .pred %r835; .reg .pred %r837; .reg .u16 %r839; .reg .u16 %r840; .reg .u16 %r842; .reg .u32 %r844; .reg .pred %r846; .reg .u16 %r848; .reg .u32 %r849; .reg .u32 %r850; .reg .u16 %r852; .reg .u16 %r853; .reg .u16 %r855; .reg .u16 %r856; .reg .u32 %r858; .reg .u16 %r859; .reg .pred %r860; .reg .u64 %r861; .reg .u32 %r862; .reg .u64 %r863; .reg .pred %r864; .reg .u16 %r866; .reg .u16 %r867; .reg .u32 %r868; .reg .u64 %r870; .reg .u16 %r872; .reg .u16 %r873; .reg .u32 %r874; .reg .pred %r877; .reg .u64 %r878; .reg .u64 %r879; .reg .u64 %r880; .reg .u32 %r881; .reg .pred %r882; .reg .u64 %r883; .reg .pred %r884; .reg .pred %r885; .reg .u32 %r886; .reg .pred %r887; .reg .u32 %r888; .reg .pred %r889; .reg .u32 %r890; .reg .pred %r893; .reg .pred %r894; .reg .pred %r895; .reg .u64 %r897; .reg .pred %r898; .reg .u32 %r903; .reg .pred %r904; .reg .pred %r905; .reg .pred %r907; .reg .u32 %r912; .reg .pred %r913; .reg .u64 %r916; .reg .u32 %r917; .reg .pred %r918; .reg .u32 %r923; .reg .pred %r924; .reg .u64 %r927; .reg .u32 %r928; .reg .pred %r929; .reg .u32 %r934; .reg .pred %r935; .reg .pred %r936; .reg .pred %r937; .reg .pred %r938; .reg .u64 %r940; .reg .pred %r941; .reg .u32 %r946; .reg .pred %r947; .reg .pred %r948; .reg .pred %r950; .reg .u32 %r955; .reg .pred %r956; .reg .pred %r957; .reg .pred %r958; .reg .u64 %r960; .reg .pred %r961; .reg .u32 %r966; .reg .pred %r967; .reg .pred %r968; .reg .pred %r970; .reg .u32 %r975; .reg .pred %r976; .reg .u32 %r977; .reg .pred %r978; .reg .u32 %r979; .reg .pred %r980; .reg .u32 %r985; .reg .pred %r986; .reg .pred %r987; .reg .pred %r988; .reg .u64 %r989; .reg .u64 %r990; .reg .u64 %r991; .reg .u32 %r992; .reg .pred %r993; .reg .u32 %r998; .reg .pred %r999; .reg .u32 %r1000; .reg .pred %r1001; .reg .u32 %r1002; .reg .pred %r1003; .reg .u64 %r1004; .reg .u32 %r1005; .reg .pred %r1006; .reg .u32 %r1011; .reg .pred %r1012; .reg .pred %r1013; .reg .pred %r1014; .reg .u64 %r1016; .reg .pred %r1017; .reg .u32 %r1022; .reg .pred %r1023; .reg .pred %r1024; .reg .pred %r1026; .reg .u32 %r1031; .reg .pred %r1032; .reg .pred %r1033; .reg .u64 %r1034; .reg .u64 %r1035; .reg .u32 %r1036; .reg .pred %r1037; .reg .u32 %r1042; .reg .pred %r1043; .reg .u32 %r1044; .reg .pred %r1045; .reg .u32 %r1046; .reg .pred %r1047; .reg .u32 %r1048; .reg .pred %r1049; .reg .u32 %r1054; .reg .pred %r1055; .reg .pred %r1056; .reg .pred %r1057; .reg .u64 %r1059; .reg .pred %r1060; .reg .u32 %r1065; .reg .pred %r1066; .reg .pred %r1067; .reg .pred %r1069; .reg .u32 %r1074; .reg .pred %r1075; .reg .pred %r1076; .reg .u32 %r1081; .reg .pred %r1082; .reg .pred %r1083; .reg .u32 %r1084; .reg .pred %r1085; .reg .u32 %r1090; .reg .pred %r1091; .reg .pred %r1092; .reg .pred %r1093; .reg .u64 %r1095; .reg .pred %r1096; .reg .u32 %r1101; .reg .pred %r1102; .reg .pred %r1103; .reg .pred %r1105; .reg .u32 %r1110; .reg .pred %r1111; .reg .pred %r1112; .reg .u32 %r1113; .reg .pred %r1114; .reg .u32 %r1115; .reg .pred %r1116; .reg .u32 %r1121; .reg .pred %r1122; .reg .pred %r1123; .reg .u64 %r1124; .reg .u64 %r1125; .reg .u32 %r1126; .reg .pred %r1127; .reg .u32 %r1132; .reg .pred %r1133; .reg .u32 %r1134; .reg .pred %r1135; .reg .pred %r1136; .reg .u64 %r1138; .reg .pred %r1139; .reg .u32 %r1144; .reg .pred %r1145; .reg .pred %r1146; .reg .pred %r1148; .reg .u32 %r1153; .reg .pred %r1154; .reg .pred %r1155; .reg .u32 %r1156; .reg .pred %r1157; .reg .u64 %r1158; .reg .pred %r1159; .reg .u32 %r1164; .reg .pred %r1165; .reg .pred %r1166; .reg .u32 %r1171; .reg .pred %r1172; .reg .pred %r1173; .reg .u64 %r1174; .reg .pred %r1175; .reg .u32 %r1180; .reg .pred %r1181; .reg .u32 %r1182; .reg .pred %r1183; .reg .pred %r1184; .reg .u64 %r1186; .reg .pred %r1187; .reg .u32 %r1192; .reg .pred %r1193; .reg .pred %r1194; .reg .pred %r1196; .reg .u32 %r1201; .reg .pred %r1202; .reg .u32 %r1203; .reg .u64 %r1204; .reg .pred %r1205; .reg .u32 %r1210; .reg .pred %r1211; .reg .u32 %r1212; .reg .pred %r1214; .reg .u32 %r1219; .reg .pred %r1220; .reg .u32 %r1221; .reg .pred %r1222; .reg .pred %r1223; .reg .pred %r1224; .reg .u64 %r1226; .reg .pred %r1227; .reg .u32 %r1232; .reg .pred %r1233; .reg .pred %r1234; .reg .pred %r1236; .reg .u32 %r1241; .reg .pred %r1242; .reg .u32 %r1243; .reg .pred %r1244; .reg .u32 %r1245; .reg .u32 %r1250; .reg .pred %r1251; .reg .u64 %r1252; .reg .pred %r1253; .reg .u64 %r1257; .reg .u32 %r1258; .reg .u16 %r1259; .reg .u16 %r1260; .reg .pred %r1261; .reg .u64 %r1263; .reg .u32 %r1266; .reg .u64 %r1274; .reg .u32 %r1278; .reg .u64 %r1286; .reg .u16 %r1288; .reg .u32 %r1289; .reg .u32 %r1290; .reg .u32 %r1291; .reg .u32 %r1293; .reg .u32 %r1294; .reg .u16 %r1295; .reg .u16 %r1296; .reg .u16 %r1297; .reg .u32 %r1298; .reg .u16 %r1299; .reg .pred %r1300; .reg .pred %r1302; .reg .u64 %r1303; .reg .u32 %r1304; .reg .pred %r1305; .reg .u32 %r1307; .reg .u32 %r1308; .reg .u32 %r1310; .reg .u32 %r1311; .reg .u16 %r1312; .reg .u16 %r1313; .reg .u16 %r1314; .reg .u32 %r1315; .reg .u16 %r1316; .reg .pred %r1317; .reg .u64 %r1318; .reg .u64 %r1319; .reg .pred %r1324; .reg .u32 %r1325; .reg .u64 %r1326; .reg .u32 %r1327; .reg .pred %r1328; .reg .pred %r1329; .reg .u64 %r1353; .reg .u64 %r1354; .reg .u64 %r1355; .reg .u64 %r1356; .reg .u64 %r1357; .reg .u64 %r1358; .reg .u64 %r1359; .reg .u64 %r1360; .reg .u64 %r1361; .reg .u64 %r1362; mov.u64 %r490,%ar0; mov.u64 %r491,%ar1; mov.u64 %r492,%ar2; mov.u64 %r493,%ar3; .loc 1 696 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r505,[%value_in]; } ld.u64 %r327,[%r505]; .loc 1 697 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r327; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r507,[%value_in]; } .loc 1 880 0 ld.u16 %r509,[%r491+16]; and.b16 %r508,%r509,128; setp.eq.u16 %r510,%r508,0; @ %r510 bra $L2; ld.u64 %r511,[%r491+24]; setp.ne.u64 %r512,%r511,0; @ %r512 bra $L2; .loc 1 882 0 mov.u64 %r514,64; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r514; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r515,[%value_in]; } st.u64 [%r491],%r515; st.u64 [%r491+24],%r515; .loc 1 883 0 setp.ne.u64 %r516,%r515,0; @ %r516 bra $L3; .loc 1 885 0 mov.u32 %r517,12; st.u32 [%r490],%r517; .loc 1 886 0 mov.u32 %r489,-1; bra $L1; $L3: .loc 1 888 0 cvt.u32.u64 %r518,%r514; st.u32 [%r491+32],%r518; $L2: .loc 1 894 0 st.u64 [%frame+168],%frame; .loc 1 895 0 mov.u64 %r519,0; st.u64 [%frame+184],%r519; .loc 1 896 0 cvt.u32.u64 %r520,%r519; st.u32 [%frame+176],%r520; .loc 1 707 0 cvt.u32.u64 %r401,%r519; .loc 1 699 0 mov.f64 %r335,0d0000000000000000; .loc 1 894 0 mov.u64 %r322,%frame; .loc 1 718 0 mov.u64 %r118,%r519; .loc 1 702 0 cvt.u32.u64 %r317,%r118; .loc 1 898 0 cvt.u32.u64 %r489,%r118; .loc 1 929 0 add.u64 %r1353,%frame,168; .loc 1 1763 0 add.u64 %r1354,%frame,200; .loc 1 1694 0 add.u64 %r1355,%frame,216; .loc 1 1692 0 add.u64 %r1356,%frame,218; .loc 1 1880 0 add.u64 %r1357,%frame,192; add.u64 %r1358,%frame,208; add.u64 %r1359,%frame,212; .loc 1 1928 0 add.u64 %r1360,%frame,204; .loc 1 1917 0 add.u64 %r1361,%frame,199; .loc 1 1923 0 add.u64 %r1362,%frame,202; $L5: .loc 1 925 0 ld.s8 %r278,[%r492]; cvt.u16.u32 %r522,%r278; set.u32.ne.u16 %r523,%r522,37; neg.s32 %r524,%r523; set.u32.ne.u16 %r527,%r522,0; neg.s32 %r528,%r527; cvt.u16.u32 %r530,%r524; cvt.u16.u32 %r531,%r528; and.b16 %r529,%r530,%r531; cvt.u32.u16 %r532,%r529; cvt.u16.u8 %r533,%r532; setp.eq.u16 %r534,%r533,0; @ %r534 bra $L236; mov.u64 %r359,%r492; $L7: .loc 1 926 0 add.u64 %r359,%r359,1; .loc 1 925 0 ld.s8 %r333,[%r359]; cvt.u16.u32 %r536,%r333; set.u32.ne.u16 %r537,%r536,0; neg.s32 %r538,%r537; set.u32.ne.u16 %r541,%r536,37; neg.s32 %r542,%r541; cvt.u16.u32 %r544,%r538; cvt.u16.u32 %r545,%r542; and.b16 %r543,%r544,%r545; cvt.u32.u16 %r546,%r543; cvt.u16.u8 %r547,%r546; setp.ne.u16 %r548,%r547,0; @ %r548 bra $L7; sub.u64 %r549,%r359,%r492; cvt.u32.u64 %r441,%r549; .loc 1 928 0 setp.eq.u32 %r550,%r441,0; @ %r550 bra $L6; .loc 1 929 0 st.u64 [%r322],%r492; cvt.s64.s32 %r122,%r441; st.u64 [%r322+8],%r122; ld.u64 %r552,[%frame+184]; add.u64 %r551,%r552,%r122; st.u64 [%frame+184],%r551; ld.u32 %r553,[%frame+176]; add.u32 %r126,%r553,1; st.u32 [%frame+176],%r126; setp.gt.s32 %r554,%r126,7; @ %r554 bra $L8; add.u64 %r322,%r322,16; bra $L9; $L8: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r559,[%value_in]; } setp.ne.u32 %r560,%r559,0; @ %r560 bra $L10; mov.u64 %r322,%frame; $L9: .loc 1 930 0 add.u32 %r489,%r489,%r441; bra $L6; $L236: .loc 1 925 0 mov.u64 %r359,%r492; $L6: .loc 1 936 0 ld.s8 %r562,[%r359]; cvt.u16.u32 %r561,%r562; setp.eq.u16 %r563,%r561,0; @ %r563 bra $L11; .loc 1 940 0 add.u64 %r492,%r359,1; .loc 1 946 0 mov.u32 %r564,0; st.u8 [%frame+218],%r564; ld.s8 %r484,[%r359+1]; mov.u32 %r323,0; mov.u32 %r390,%r323; .loc 1 945 0 mov.u32 %r316,-1; .loc 1 944 0 mov.u32 %r315,%r323; .loc 1 942 0 mov.u32 %r314,%r323; bra $L12; $L237: .loc 1 1018 0 mov.u64 %r493,%r406; $L12: .loc 1 958 0 add.u64 %r492,%r492,1; mov.u32 %r311,%r484; $L13: .loc 1 959 0 setp.eq.u32 %r565,%r311,85; @ %r565 bra $L15; setp.gt.s32 %r566,%r311,85; @ %r566 bra $L16; setp.eq.u32 %r567,%r311,48; @ %r567 bra $L17; setp.gt.s32 %r568,%r311,48; @ %r568 bra $L18; setp.eq.u32 %r569,%r311,42; @ %r569 bra $L19; setp.gt.s32 %r570,%r311,42; @ %r570 bra $L20; setp.eq.u32 %r571,%r311,32; @ %r571 bra $L21; setp.eq.u32 %r572,%r311,35; @ %r572 bra $L22; bra $L14; $L20: setp.eq.u32 %r573,%r311,45; @ %r573 bra $L23; setp.eq.u32 %r574,%r311,46; @ %r574 bra $L24; setp.eq.u32 %r575,%r311,43; @ ! %r575 bra $L14; bra $L25; $L18: setp.eq.u32 %r576,%r311,69; @ %r576 bra $L26; setp.gt.s32 %r577,%r311,69; @ %r577 bra $L27; setp.le.s32 %r578,%r311,57; @ %r578 bra $L28; setp.eq.u32 %r579,%r311,68; @ %r579 bra $L29; bra $L14; $L27: setp.eq.u32 %r580,%r311,76; @ %r580 bra $L30; setp.eq.u32 %r581,%r311,79; @ %r581 bra $L31; setp.eq.u32 %r582,%r311,71; @ ! %r582 bra $L14; bra $L26; $L16: setp.eq.u32 %r583,%r311,108; @ %r583 bra $L32; setp.gt.s32 %r584,%r311,108; @ %r584 bra $L33; setp.gt.s32 %r585,%r311,103; @ %r585 bra $L34; setp.ge.s32 %r586,%r311,101; @ %r586 bra $L26; setp.eq.u32 %r587,%r311,99; @ %r587 bra $L35; setp.gt.s32 %r588,%r311,99; @ %r588 bra $L36; setp.eq.u32 %r589,%r311,88; @ %r589 bra $L37; bra $L14; $L34: setp.eq.u32 %r590,%r311,104; @ %r590 bra $L38; setp.eq.u32 %r591,%r311,105; @ %r591 bra $L36; bra $L14; $L33: setp.eq.u32 %r592,%r311,113; @ %r592 bra $L39; setp.gt.s32 %r593,%r311,113; @ %r593 bra $L40; setp.eq.u32 %r594,%r311,111; @ %r594 bra $L41; setp.gt.s32 %r595,%r311,111; @ %r595 bra $L42; setp.eq.u32 %r596,%r311,110; @ %r596 bra $L43; bra $L14; $L40: setp.eq.u32 %r597,%r311,117; @ %r597 bra $L44; setp.eq.u32 %r598,%r311,120; @ %r598 bra $L45; setp.eq.u32 %r599,%r311,115; @ ! %r599 bra $L14; bra $L46; $L23: ld.s8 %r484,[%r492]; bra $L47; $L37: setp.eq.u32 %r600,%r323,0; @ %r600 bra $L48; cvt.u32.u32 %r601,%r390; st.u8 [%frame+218],%r601; $L48: .loc 1 1542 0 cvta.const.u64 %r118,$LC4; bra $L49; $L36: setp.eq.u32 %r602,%r323,0; @ %r602 bra $L51; cvt.u32.u32 %r603,%r390; st.u8 [%frame+218],%r603; bra $L51; $L21: ld.s8 %r484,[%r492]; .loc 1 975 0 setp.ne.u32 %r604,%r390,0; selp.u32 %r323,%r323,1,%r604; selp.u32 %r390,%r390,32,%r604; bra $L12; $L22: .loc 1 979 0 or.b32 %r314,%r314,1; ld.s8 %r484,[%r492]; .loc 1 980 0 bra $L12; $L19: .loc 1 1018 0 add.u64 %r406,%r493,4; ld.u32 %r315,[%r493]; ld.s8 %r484,[%r492]; .loc 1 1022 0 setp.ge.s32 %r605,%r315,0; @ %r605 bra $L237; .loc 1 1024 0 neg.s32 %r315,%r315; .loc 1 1018 0 mov.u64 %r493,%r406; $L47: .loc 1 1027 0 or.b32 %r314,%r314,4; .loc 1 1028 0 bra $L12; $L25: ld.s8 %r484,[%r492]; .loc 1 1031 0 mov.u32 %r323,1; .loc 1 1030 0 mov.u32 %r390,%r311; .loc 1 1031 0 bra $L12; $L24: .loc 1 1033 0 add.u64 %r355,%r492,1; ld.s8 %r311,[%r492]; setp.eq.u32 %r606,%r311,42; @ %r606 bra $L53; .loc 1 1072 0 add.u32 %r1325,%r311,-48; setp.le.u32 %r607,%r1325,9; @ %r607 bra $L54; .loc 1 1033 0 mov.u64 %r492,%r355; .loc 1 1071 0 mov.u32 %r316,0; bra $L13; $L53: ld.u32 %r608,[%r493]; max.s32 %r316,%r608,-1; ld.s8 %r484,[%r492+1]; .loc 1 1063 0 add.u64 %r493,%r493,4; .loc 1 1033 0 mov.u64 %r492,%r355; bra $L12; $L54: mov.u64 %r370,%r355; .loc 1 1071 0 mov.u32 %r316,0; $L56: .loc 1 1073 0 shl.b32 %r610,%r316,2; add.u32 %r611,%r610,%r316; add.u32 %r612,%r611,%r611; add.u32 %r316,%r612,%r1325; add.u64 %r492,%r370,1; .loc 1 1074 0 ld.s8 %r311,[%r370]; .loc 1 1072 0 add.u32 %r1325,%r311,-48; mov.u64 %r370,%r492; setp.le.u32 %r613,%r1325,9; @ %r613 bra $L56; bra $L13; $L17: .loc 1 1084 0 or.b32 %r314,%r314,128; ld.s8 %r484,[%r492]; .loc 1 1085 0 bra $L12; $L28: mov.u64 %r369,%r492; .loc 1 1088 0 mov.u32 %r315,0; add.u32 %r1325,%r311,-48; $L57: .loc 1 1090 0 shl.b32 %r615,%r315,2; add.u32 %r616,%r615,%r315; add.u32 %r617,%r616,%r616; add.u32 %r315,%r1325,%r617; add.u64 %r492,%r492,1; .loc 1 1091 0 ld.s8 %r311,[%r369]; mov.u64 %r369,%r492; .loc 1 1092 0 add.u32 %r1325,%r311,-48; setp.le.u32 %r620,%r1325,9; @ %r620 bra $L57; bra $L13; $L30: .loc 1 1108 0 or.b32 %r314,%r314,8; ld.s8 %r484,[%r492]; .loc 1 1109 0 bra $L12; $L38: .loc 1 1118 0 or.b32 %r314,%r314,64; ld.s8 %r484,[%r492]; .loc 1 1119 0 bra $L12; $L32: .loc 1 1122 0 ld.s8 %r484,[%r492]; cvt.u16.u32 %r621,%r484; setp.ne.u16 %r622,%r621,108; @ %r622 bra $L58; .loc 1 1124 0 or.b32 %r314,%r314,32; ld.s8 %r484,[%r492+1]; .loc 1 1123 0 add.u64 %r492,%r492,1; bra $L12; $L58: .loc 1 1127 0 or.b32 %r314,%r314,16; bra $L12; $L39: .loc 1 1130 0 or.b32 %r314,%r314,32; ld.s8 %r484,[%r492]; .loc 1 1131 0 bra $L12; $L35: .loc 1 1189 0 ld.u32 %r623,[%r493]; st.u8 [%frame+128],%r623; .loc 1 1192 0 mov.u32 %r624,0; st.u8 [%frame+218],%r624; .loc 1 1189 0 add.u64 %r493,%r493,4; .loc 1 1193 0 mov.u32 %r320,1; .loc 1 1190 0 mov.u32 %r321,%r320; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1173 0 add.u64 %r313,%frame,128; setp.eq.u32 %r1328,1,1; .loc 1 1193 0 bra $L136; $L29: setp.eq.u32 %r625,%r323,0; @ %r625 bra $L60; cvt.u32.u32 %r626,%r390; st.u8 [%frame+218],%r626; $L60: .loc 1 1195 0 or.b32 %r314,%r314,16; $L51: .loc 1 1199 0 and.b32 %r627,%r314,32; setp.eq.u32 %r628,%r627,0; @ %r628 bra $L61; add.u64 %r423,%r493,7; and.b64 %r402,%r423,-8; add.u64 %r493,%r402,8; ld.u64 %r318,[%r402]; bra $L62; $L61: and.b32 %r629,%r314,16; setp.eq.u32 %r630,%r629,0; @ %r630 bra $L63; add.u64 %r411,%r493,7; and.b64 %r407,%r411,-8; add.u64 %r493,%r407,8; ld.u64 %r318,[%r407]; bra $L62; $L63: ld.u32 %r483,[%r493]; add.u64 %r493,%r493,4; and.b32 %r631,%r314,64; setp.eq.u32 %r632,%r631,0; @ %r632 bra $L64; cvt.u16.u32 %r633,%r483; cvt.s64.s16 %r318,%r633; bra $L62; $L64: cvt.s64.s32 %r318,%r483; $L62: .loc 1 1201 0 setp.ge.s64 %r634,%r318,0; @ %r634 bra $L65; .loc 1 1207 0 neg.s64 %r318,%r318; .loc 1 1208 0 mov.u32 %r635,45; st.u8 [%frame+218],%r635; bra $L65; $L26: setp.eq.u32 %r636,%r323,0; @ %r636 bra $L66; cvt.u32.u32 %r637,%r390; st.u8 [%frame+218],%r637; $L66: add.u64 %r638,%r493,7; and.b64 %r447,%r638,-8; add.u64 %r493,%r447,8; .loc 1 1225 0 ld.f64 %r335,[%r447]; .loc 1 1236 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r335; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r642,[%value_in]; } setp.ne.u32 %r643,%r642,1; @ %r643 bra $L69; .loc 1 1237 0 setp.lt.f64 %r644,%r335,0d0000000000000000; @ %r644 bra $L70; ld.s8 %r452,[%frame+218]; bra $L71; $L70: .loc 1 1238 0 mov.u32 %r645,45; st.u8 [%frame+218],%r645; mov.u32 %r452,45; $L71: .loc 1 1239 0 setp.gt.s32 %r646,%r311,71; @ %r646 bra $L238; .loc 1 1240 0 cvta.const.u64 %r313,$LC0; bra $L72; $L238: .loc 1 1242 0 cvta.const.u64 %r313,$LC1; $L72: .loc 1 1244 0 and.b32 %r314,%r314,-129; .loc 1 1245 0 mov.u32 %r320,3; .loc 1 1243 0 mov.u32 %r321,%r320; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1245 0 bra $L59; $L69: .loc 1 1247 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r335; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r648,[%value_in]; } mov.u32 %r150,%r648; setp.ne.u32 %r649,%r648,0; @ %r649 bra $L73; .loc 1 1248 0 setp.gt.s32 %r650,%r311,71; @ %r650 bra $L239; .loc 1 1249 0 cvta.const.u64 %r313,$LC2; bra $L74; $L239: .loc 1 1251 0 cvta.const.u64 %r313,$LC3; $L74: .loc 1 1253 0 and.b32 %r314,%r314,-129; ld.s8 %r452,[%frame+218]; .loc 1 943 0 mov.u32 %r316,%r648; .loc 1 1254 0 mov.u32 %r320,3; .loc 1 1252 0 mov.u32 %r321,%r320; .loc 1 1254 0 bra $L59; $L73: and.b32 %r448,%r311,-33; .loc 1 1309 0 setp.eq.u32 %r651,%r316,-1; @ %r651 bra $L240; .loc 1 1311 0 set.u32.eq.u32 %r653,%r316,0; neg.s32 %r654,%r653; set.u32.eq.u32 %r656,%r448,71; neg.s32 %r657,%r656; cvt.u16.u32 %r659,%r654; cvt.u16.u32 %r660,%r657; and.b16 %r658,%r659,%r660; cvt.u32.u16 %r661,%r658; cvt.u16.u8 %r662,%r661; setp.ne.u16 %r663,%r662,0; .loc 1 1312 0 selp.u32 %r316,1,%r316,%r663; bra $L75; $L240: .loc 1 1310 0 mov.u32 %r316,6; $L75: .loc 1 1315 0 or.b32 %r342,%r314,256; .loc 1 1814 0 mov.b64 %r664,%r335; shr.u64 %r665,%r664,32; cvt.u32.u64 %r666,%r665; setp.ge.s32 %r667,%r666,0; @ %r667 bra $L242; .loc 1 1815 0 neg.f64 %r368,%r335; .loc 1 1816 0 mov.u32 %r400,45; bra $L76; $L242: .loc 1 1814 0 mov.f64 %r368,%r335; .loc 1 1818 0 mov.u32 %r400,0; $L76: .loc 1 1867 0 setp.eq.u32 %r668,%r448,70; @ %r668 bra $L77; .loc 1 1874 0 setp.ne.u32 %r669,%r448,69; @ %r669 bra $L78; .loc 1 1875 0 add.u32 %r371,%r316,1; .loc 1 1880 0 mov.u32 %r672,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r368; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r672; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r371; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1359; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1358; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1357; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r680,[%value_in]; } mov.u64 %r313,%r680; setp.eq.u32 %r1329,1,1; bra $L79; $L368: ld.u64 %r343,[%frame+192]; bra $L80; $L367: ld.u32 %r451,[%frame+212]; bra $L81; $L229: .loc 1 1886 0 mov.u32 %r681,1; sub.u32 %r451,%r681,%r316; st.u32 [%frame+212],%r451; $L81: .loc 1 1887 0 cvt.s64.s32 %r682,%r451; add.u64 %r683,%r682,%r353; add.u64 %r375,%r1286,%r683; setp.eq.u32 %r1329,1,1; $L227: .loc 1 1889 0 setp.eq.f64 %r684,%r368,0d0000000000000000; @ %r684 bra $L243; bra $L355; $L83: .loc 1 1892 0 add.u64 %r685,%r343,1; st.u64 [%frame+192],%r685; st.u8 [%r343],%r686; .loc 1 1891 0 ld.u64 %r343,[%frame+192]; setp.gt.u64 %r687,%r375,%r343; @ %r687 bra $L83; bra $L80; $L355: ld.u64 %r343,[%frame+192]; setp.lt.u64 %r688,%r343,%r375; @ ! %r688 bra $L80; .loc 1 1892 0 mov.u32 %r686,48; bra $L83; $L243: .loc 1 1889 0 mov.u64 %r343,%r375; $L80: .loc 1 1894 0 sub.u64 %r689,%r343,%r313; cvt.u32.u64 %r401,%r689; ld.u32 %r150,[%frame+212]; .loc 1 1320 0 @ %r1329 bra $L84; .loc 1 1321 0 set.u32.lt.s32 %r692,%r316,%r150; neg.s32 %r693,%r692; set.u32.lt.s32 %r695,%r150,-3; neg.s32 %r696,%r695; cvt.u16.u32 %r698,%r693; cvt.u16.u32 %r699,%r696; or.b16 %r697,%r698,%r699; cvt.u32.u16 %r700,%r697; cvt.u16.u8 %r701,%r700; setp.eq.u16 %r702,%r701,0; @ %r702 bra $L85; .loc 1 1322 0 add.u32 %r311,%r311,-2; bra $L86; $L84: .loc 1 1330 0 setp.eq.u32 %r703,%r311,102; @ %r703 bra $L87; $L86: .loc 1 1331 0 add.u32 %r381,%r150,-1; st.u32 [%frame+212],%r381; .loc 1 1910 0 st.u8 [%frame+200],%r311; .loc 1 1911 0 setp.ge.s32 %r704,%r381,0; @ %r704 bra $L88; .loc 1 1912 0 mov.u32 %r705,1; sub.u32 %r381,%r705,%r150; .loc 1 1913 0 mov.u32 %r706,45; st.u8 [%frame+201],%r706; bra $L89; $L88: .loc 1 1916 0 mov.u32 %r707,43; st.u8 [%frame+201],%r707; $L89: .loc 1 1918 0 setp.le.s32 %r708,%r381,9; @ %r708 bra $L90; .loc 1 1917 0 mov.u64 %r385,%r1361; bra $L91; $L244: .loc 1 1921 0 mov.u64 %r385,%r1326; $L91: .loc 1 1920 0 add.u64 %r1326,%r385,-1; rem.s32 %r712,%r381,10; cvt.u16.u32 %r715,%r712; add.u16 %r714,%r715,48; cvt.u32.u16 %r716,%r714; st.u8 [%r1326],%r716; .loc 1 1921 0 div.s32 %r381,%r381,10; setp.gt.s32 %r721,%r381,9; @ %r721 bra $L244; .loc 1 1922 0 add.u64 %r352,%r385,-2; cvt.u16.u32 %r724,%r381; add.u16 %r723,%r724,48; cvt.u32.u16 %r725,%r723; cvt.s32.s8 %r450,%r725; st.u8 [%r1326+-1],%r725; .loc 1 1923 0 setp.ge.u64 %r729,%r352,%r1361; @ %r729 bra $L245; mov.u64 %r434,%r1362; $L94: add.u64 %r352,%r352,1; cvt.u32.u32 %r731,%r450; st.u8 [%r434],%r731; add.u64 %r434,%r434,1; setp.ne.u64 %r734,%r352,%r1361; @ %r734 bra $L93; sub.u64 %r741,%r1354,%r1326; add.u64 %r394,%r1362,%r741; bra $L92; $L93: ld.s8 %r450,[%r352]; bra $L94; $L90: .loc 1 1927 0 mov.u32 %r742,48; st.u8 [%frame+202],%r742; .loc 1 1928 0 cvt.u16.u32 %r745,%r381; add.u16 %r744,%r745,48; cvt.u32.u16 %r746,%r744; st.u8 [%frame+203],%r746; mov.u64 %r394,%r1360; bra $L92; $L245: .loc 1 1923 0 mov.u64 %r394,%r1362; $L92: .loc 1 1930 0 sub.u64 %r748,%r394,%r1354; cvt.u32.u64 %r317,%r748; .loc 1 1333 0 add.u32 %r321,%r401,%r317; .loc 1 1334 0 setp.gt.s32 %r749,%r401,1; @ %r749 bra $L95; and.b32 %r150,%r314,1; setp.ne.u32 %r750,%r150,0; @ %r750 bra $L95; max.s32 %r320,%r321,0; bra $L96; $L95: .loc 1 1335 0 add.u32 %r321,%r321,1; max.s32 %r320,%r321,0; .loc 1 948 0 mov.u32 %r150,0; bra $L96; $L87: .loc 1 1341 0 setp.le.s32 %r751,%r150,0; @ %r751 bra $L97; .loc 1 1343 0 setp.ne.u32 %r752,%r316,0; @ %r752 bra $L98; and.b32 %r753,%r314,1; setp.eq.u32 %r754,%r753,0; @ %r754 bra $L246; $L98: .loc 1 1344 0 add.u32 %r755,%r316,1; add.u32 %r321,%r755,%r150; mov.u32 %r320,%r321; bra $L96; $L97: .loc 1 1348 0 setp.ne.u32 %r756,%r316,0; @ %r756 bra $L100; .loc 1 1346 0 and.b32 %r757,%r314,1; setp.eq.u32 %r758,%r757,0; @ %r758 bra $L247; $L100: .loc 1 1348 0 add.u32 %r321,%r316,2; mov.u32 %r320,%r321; bra $L96; $L85: .loc 1 1349 0 setp.gt.s32 %r759,%r401,%r150; @ %r759 bra $L101; .loc 1 1351 0 and.b32 %r760,%r314,1; setp.ne.u32 %r761,%r760,0; @ %r761 bra $L102; max.s32 %r320,%r150,0; mov.u32 %r321,%r150; mov.u32 %r311,103; bra $L96; $L102: .loc 1 1352 0 add.u32 %r321,%r150,1; max.s32 %r320,%r321,0; mov.u32 %r311,103; bra $L96; $L101: .loc 1 1355 0 setp.gt.s32 %r762,%r150,0; @ %r762 bra $L248; mov.u32 %r763,2; sub.u32 %r325,%r763,%r150; bra $L103; $L248: mov.u32 %r325,1; $L103: .loc 1 1354 0 add.u32 %r321,%r325,%r401; max.s32 %r320,%r321,0; mov.u32 %r311,103; bra $L96; $L246: mov.u32 %r320,%r150; mov.u32 %r321,%r150; bra $L96; $L247: mov.u32 %r320,1; .loc 1 1348 0 mov.u32 %r321,%r320; $L96: .loc 1 1377 0 setp.ne.u32 %r764,%r400,0; @ %r764 bra $L104; ld.s8 %r452,[%frame+218]; .loc 1 1315 0 mov.u32 %r314,%r342; .loc 1 943 0 mov.u32 %r316,%r400; bra $L59; $L104: .loc 1 1378 0 mov.u32 %r765,45; st.u8 [%frame+218],%r765; .loc 1 1315 0 mov.u32 %r314,%r342; .loc 1 943 0 mov.u32 %r316,0; setp.eq.u32 %r1328,1,0; bra $L356; $L43: setp.eq.u32 %r766,%r323,0; @ %r766 bra $L105; cvt.u32.u32 %r767,%r390; st.u8 [%frame+218],%r767; $L105: add.u64 %r768,%r493,7; and.b64 %r443,%r768,-8; add.u64 %r493,%r443,8; ld.u64 %r444,[%r443]; .loc 1 1392 0 and.b32 %r769,%r314,32; setp.eq.u32 %r770,%r769,0; @ %r770 bra $L106; .loc 1 1393 0 cvt.s64.s32 %r771,%r489; st.u64 [%r444],%r771; bra $L5; $L106: .loc 1 1396 0 and.b32 %r772,%r314,16; setp.eq.u32 %r773,%r772,0; @ %r773 bra $L108; .loc 1 1397 0 cvt.s64.s32 %r774,%r489; st.u64 [%r444],%r774; bra $L5; $L108: .loc 1 1398 0 and.b32 %r775,%r314,64; setp.eq.u32 %r776,%r775,0; @ %r776 bra $L109; .loc 1 1399 0 st.u16 [%r444],%r489; bra $L5; $L109: .loc 1 1405 0 st.u32 [%r444],%r489; bra $L5; $L31: .loc 1 1408 0 or.b32 %r314,%r314,16; $L41: .loc 1 1411 0 and.b32 %r777,%r314,32; setp.eq.u32 %r778,%r777,0; @ %r778 bra $L110; add.u64 %r412,%r493,7; and.b64 %r408,%r412,-8; add.u64 %r493,%r408,8; ld.u64 %r318,[%r408]; .loc 1 1412 0 mov.u32 %r319,0; bra $L111; $L110: .loc 1 1411 0 and.b32 %r779,%r314,16; setp.eq.u32 %r780,%r779,0; @ %r780 bra $L112; add.u64 %r415,%r493,7; and.b64 %r403,%r415,-8; add.u64 %r493,%r403,8; ld.u64 %r318,[%r403]; .loc 1 1412 0 mov.u32 %r319,%r777; bra $L111; $L112: ld.u32 %r482,[%r493]; add.u64 %r493,%r493,4; .loc 1 1411 0 and.b32 %r781,%r314,64; setp.eq.u32 %r782,%r781,0; @ %r782 bra $L113; cvt.u16.u32 %r783,%r482; cvt.u64.u16 %r318,%r783; .loc 1 1412 0 mov.u32 %r319,%r779; bra $L111; $L113: .loc 1 1411 0 cvt.u64.u32 %r318,%r482; .loc 1 1412 0 mov.u32 %r319,%r781; bra $L111; $L42: .loc 1 1426 0 add.u64 %r426,%r493,7; and.b64 %r201,%r426,-8; add.u64 %r493,%r201,8; ld.u64 %r318,[%r201]; .loc 1 1429 0 or.b32 %r314,%r314,2; .loc 1 1430 0 mov.u32 %r784,48; st.u8 [%frame+216],%r784; .loc 1 1431 0 mov.u32 %r785,120; st.u8 [%frame+217],%r785; .loc 1 1428 0 cvta.const.u64 %r118,$LC5; .loc 1 1427 0 mov.u32 %r319,2; .loc 1 1431 0 mov.u32 %r311,120; .loc 1 1432 0 bra $L111; $L46: .loc 1 1437 0 add.u64 %r424,%r493,7; and.b64 %r398,%r424,-8; add.u64 %r493,%r398,8; ld.u64 %r313,[%r398]; .loc 1 1441 0 mov.u32 %r786,0; st.u8 [%frame+218],%r786; .loc 1 1447 0 setp.ne.u64 %r787,%r313,0; @ %r787 bra $L114; .loc 1 1449 0 min.u32 %r320,%r316,6; mov.u32 %r321,%r320; mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1448 0 cvta.const.u64 %r313,$LC6; setp.eq.u32 %r1328,1,1; bra $L136; $L114: .loc 1 1516 0 setp.eq.u32 %r788,%r316,-1; @ %r788 bra $L115; .loc 1 1522 0 cvt.s64.s32 %r792,%r316; mov.u32 %r790,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r313; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r790; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r792; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r793,[%value_in]; } .loc 1 1524 0 setp.ne.u64 %r794,%r793,0; @ %r794 bra $L116; ld.s8 %r452,[%frame+218]; mov.u32 %r320,%r316; mov.u32 %r321,%r316; .loc 1 943 0 cvt.u32.u64 %r316,%r793; .loc 1 948 0 mov.u32 %r150,%r316; bra $L59; $L116: .loc 1 1525 0 sub.u64 %r795,%r793,%r313; cvt.u32.u64 %r796,%r795; min.s32 %r321,%r316,%r796; ld.s8 %r452,[%frame+218]; max.s32 %r320,%r321,0; .loc 1 943 0 mov.u32 %r316,%r790; .loc 1 948 0 mov.u32 %r150,%r316; bra $L59; $L115: .loc 1 1531 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r313; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r798,[%value_in]; } cvt.u32.u64 %r321,%r798; ld.s8 %r452,[%frame+218]; max.s32 %r320,%r321,0; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; bra $L59; $L15: .loc 1 1535 0 or.b32 %r314,%r314,16; $L44: .loc 1 1538 0 and.b32 %r799,%r314,32; setp.eq.u32 %r800,%r799,0; @ %r800 bra $L117; add.u64 %r418,%r493,7; and.b64 %r404,%r418,-8; add.u64 %r493,%r404,8; ld.u64 %r318,[%r404]; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L117: .loc 1 1538 0 and.b32 %r801,%r314,16; setp.eq.u32 %r802,%r801,0; @ %r802 bra $L118; add.u64 %r421,%r493,7; and.b64 %r410,%r421,-8; add.u64 %r493,%r410,8; ld.u64 %r318,[%r410]; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L118: ld.u32 %r481,[%r493]; add.u64 %r493,%r493,4; .loc 1 1538 0 and.b32 %r803,%r314,64; setp.eq.u32 %r804,%r803,0; @ %r804 bra $L119; cvt.u16.u32 %r805,%r481; cvt.u64.u16 %r318,%r805; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L119: .loc 1 1538 0 cvt.u64.u32 %r318,%r481; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L45: setp.eq.u32 %r806,%r323,0; @ %r806 bra $L120; cvt.u32.u32 %r807,%r390; st.u8 [%frame+218],%r807; $L120: .loc 1 1545 0 cvta.const.u64 %r118,$LC5; $L49: .loc 1 1546 0 and.b32 %r808,%r314,32; setp.eq.u32 %r809,%r808,0; @ %r809 bra $L121; add.u64 %r409,%r493,7; and.b64 %r422,%r409,-8; add.u64 %r493,%r422,8; ld.u64 %r318,[%r422]; bra $L122; $L121: and.b32 %r810,%r314,16; setp.eq.u32 %r811,%r810,0; @ %r811 bra $L123; add.u64 %r416,%r493,7; and.b64 %r399,%r416,-8; add.u64 %r493,%r399,8; ld.u64 %r318,[%r399]; bra $L122; $L123: ld.u32 %r480,[%r493]; add.u64 %r493,%r493,4; and.b32 %r812,%r314,64; setp.eq.u32 %r813,%r812,0; @ %r813 bra $L124; cvt.u16.u32 %r814,%r480; cvt.u64.u16 %r318,%r814; bra $L122; $L124: cvt.u64.u32 %r318,%r480; $L122: .loc 1 1549 0 and.b32 %r815,%r314,1; setp.eq.u32 %r816,%r815,0; @ %r816 bra $L249; setp.eq.u64 %r817,%r318,0; @ %r817 bra $L250; .loc 1 1550 0 mov.u32 %r818,48; st.u8 [%frame+216],%r818; .loc 1 1551 0 st.u8 [%frame+217],%r311; .loc 1 1552 0 or.b32 %r314,%r314,2; .loc 1 1547 0 mov.u32 %r319,2; bra $L111; $L249: mov.u32 %r319,2; bra $L111; $L250: mov.u32 %r319,2; $L111: .loc 1 1559 0 mov.u32 %r819,0; st.u8 [%frame+218],%r819; .loc 1 1565 0 setp.eq.u32 %r821,%r316,-1; @ %r821 bra $L251; .loc 1 1566 0 and.b32 %r350,%r314,-129; .loc 1 1574 0 set.u32.ne.u64 %r823,%r318,0; neg.s32 %r824,%r823; set.u32.ne.u32 %r826,%r316,0; neg.s32 %r827,%r826; cvt.u16.u32 %r829,%r824; cvt.u16.u32 %r830,%r827; or.b16 %r828,%r829,%r830; cvt.u32.u16 %r831,%r828; cvt.u16.u8 %r832,%r831; setp.eq.u16 %r833,%r832,0; @ %r833 bra $L126; bra $L234; $L259: mov.u32 %r319,1; $L234: ld.s8 %r452,[%frame+218]; mov.u32 %r314,%r350; bra $L125; $L251: mov.u32 %r452,0; $L125: .loc 1 1580 0 cvt.u16.u32 %r834,%r319; setp.eq.u16 %r835,%r834,1; @ %r835 bra $L128; setp.eq.u16 %r837,%r834,2; @ %r837 bra $L252; .loc 1 1573 0 mov.u64 %r312,%r1353; bra $L127; $L254: .loc 1 1581 0 mov.u64 %r312,%r313; $L127: .loc 1 1583 0 add.u64 %r313,%r312,-1; cvt.u16.u64 %r840,%r318; and.b16 %r839,%r840,7; add.u16 %r842,%r839,48; cvt.u32.u16 %r844,%r842; cvt.s32.s8 %r189,%r844; st.u8 [%r313],%r844; .loc 1 1584 0 shr.u64 %r318,%r318,3; .loc 1 1585 0 setp.ne.u64 %r846,%r318,0; @ %r846 bra $L254; .loc 1 1587 0 cvt.u16.u32 %r848,%r189; set.u32.ne.u16 %r849,%r848,48; neg.s32 %r850,%r849; cvt.u16.u32 %r853,%r314; and.b16 %r852,%r853,1; cvt.u16.u32 %r856,%r850; and.b16 %r855,%r856,%r852; cvt.u32.u16 %r858,%r855; cvt.u16.u8 %r859,%r858; setp.ne.u16 %r860,%r859,0; @ %r860 bra $L130; sub.u64 %r861,%r1353,%r313; cvt.u32.u64 %r321,%r861; bra $L131; $L130: .loc 1 1588 0 add.u64 %r351,%r312,-2; mov.u32 %r862,48; st.u8 [%r313+-1],%r862; sub.u64 %r863,%r1353,%r351; cvt.u32.u64 %r321,%r863; mov.u64 %r313,%r351; bra $L131; $L128: .loc 1 1593 0 setp.gt.u64 %r864,%r318,9; @ %r864 bra $L255; .loc 1 1594 0 cvt.u16.u64 %r867,%r318; add.u16 %r866,%r867,48; cvt.u32.u16 %r868,%r866; st.u8 [%frame+167],%r868; .loc 1 1595 0 mov.u32 %r321,1; .loc 1 1594 0 add.u64 %r313,%frame,167; .loc 1 1595 0 bra $L131; $L255: .loc 1 1573 0 mov.u64 %r313,%r1353; $L132: .loc 1 1601 0 add.u64 %r313,%r313,-1; rem.u64 %r870,%r318,10; cvt.u16.u64 %r873,%r870; add.u16 %r872,%r873,48; cvt.u32.u16 %r874,%r872; st.u8 [%r313],%r874; .loc 1 1622 0 div.u64 %r318,%r318,10; .loc 1 1623 0 setp.ne.u64 %r877,%r318,0; @ %r877 bra $L132; sub.u64 %r878,%r1353,%r313; cvt.u32.u64 %r321,%r878; bra $L131; $L252: .loc 1 1573 0 mov.u64 %r313,%r1353; $L129: .loc 1 1628 0 add.u64 %r313,%r313,-1; and.b64 %r879,%r318,15; add.u64 %r880,%r118,%r879; ld.u8 %r881,[%r880]; st.u8 [%r313],%r881; .loc 1 1629 0 shr.u64 %r318,%r318,4; .loc 1 1630 0 setp.ne.u64 %r882,%r318,0; @ %r882 bra $L129; sub.u64 %r883,%r1353,%r313; cvt.u32.u64 %r321,%r883; bra $L131; $L126: .loc 1 1648 0 setp.eq.u32 %r884,%r319,0; @ %r884 bra $L133; $L235: ld.s8 %r452,[%frame+218]; .loc 1 1594 0 mov.u32 %r314,%r350; mov.u32 %r316,0; mov.u32 %r321,%r316; .loc 1 1573 0 mov.u64 %r313,%r1353; bra $L131; $L133: .loc 1 1648 0 and.b32 %r321,%r314,1; setp.ne.u32 %r885,%r321,0; @ %r885 bra $L134; mov.u32 %r316,%r319; mov.u32 %r452,%r316; .loc 1 1566 0 mov.u32 %r314,%r350; .loc 1 1573 0 mov.u64 %r313,%r1353; bra $L131; $L134: .loc 1 1649 0 mov.u32 %r886,48; st.u8 [%frame+167],%r886; mov.u32 %r452,%r319; .loc 1 1566 0 mov.u32 %r314,%r350; .loc 1 1649 0 mov.u32 %r316,%r452; add.u64 %r313,%frame,167; $L131: max.s32 %r320,%r316,%r321; .loc 1 948 0 mov.u32 %r150,0; bra $L59; $L14: setp.eq.u32 %r887,%r323,0; @ %r887 bra $L135; cvt.u32.u32 %r888,%r390; st.u8 [%frame+218],%r888; $L135: .loc 1 1655 0 setp.eq.u32 %r889,%r311,0; @ %r889 bra $L11; .loc 1 1659 0 st.u8 [%frame+128],%r311; .loc 1 1661 0 mov.u32 %r890,0; st.u8 [%frame+218],%r890; .loc 1 1662 0 mov.u32 %r320,1; .loc 1 1660 0 mov.u32 %r321,%r320; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1658 0 add.u64 %r313,%frame,128; setp.eq.u32 %r1328,1,1; .loc 1 1662 0 bra $L136; $L59: .loc 1 1681 0 setp.eq.u32 %r1328,%r452,0; @ %r1328 bra $L136; $L356: .loc 1 1682 0 add.u32 %r320,%r320,1; $L136: .loc 1 1683 0 and.b32 %r203,%r314,2; setp.eq.u32 %r1324,%r203,0; @ %r1324 bra $L137; .loc 1 1684 0 add.u32 %r320,%r320,2; $L137: .loc 1 1687 0 and.b32 %r204,%r314,132; ld.u64 %r453,[%frame+184]; setp.ne.u32 %r893,%r204,0; @ %r893 bra $L138; .loc 1 1688 0 sub.u32 %r256,%r315,%r320; setp.le.s32 %r894,%r256,0; @ %r894 bra $L138; ld.u32 %r471,[%frame+176]; setp.le.s32 %r895,%r256,16; @ ! %r895 bra $L357; cvta.const.u64 %r1318,blanks$4102; bra $L139; $L357: cvta.const.u64 %r1318,blanks$4102; $L142: st.u64 [%r322],%r1318; mov.u64 %r897,16; st.u64 [%r322+8],%r897; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r471,%r471,1; st.u32 [%frame+176],%r471; setp.gt.s32 %r898,%r471,7; @ %r898 bra $L140; add.u64 %r322,%r322,16; bra $L141; $L140: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r903,[%value_in]; } setp.ne.u32 %r904,%r903,0; @ %r904 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r471,[%frame+176]; mov.u64 %r322,%frame; $L141: add.u32 %r256,%r256,-16; setp.gt.s32 %r905,%r256,16; @ %r905 bra $L142; $L139: st.u64 [%r322],%r1318; cvt.s64.s32 %r206,%r256; st.u64 [%r322+8],%r206; add.u64 %r453,%r453,%r206; st.u64 [%frame+184],%r453; add.u32 %r207,%r471,1; st.u32 [%frame+176],%r207; setp.gt.s32 %r907,%r207,7; @ %r907 bra $L143; add.u64 %r322,%r322,16; ld.s8 %r452,[%frame+218]; setp.eq.u32 %r1328,%r452,0; bra $L138; $L143: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r912,[%value_in]; } setp.ne.u32 %r913,%r912,0; @ %r913 bra $L10; ld.s8 %r452,[%frame+218]; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; setp.eq.u32 %r1328,%r452,0; $L138: .loc 1 1691 0 @ %r1328 bra $L144; .loc 1 1692 0 st.u64 [%r322],%r1356; mov.u64 %r916,1; st.u64 [%r322+8],%r916; add.u64 %r453,%r453,1; st.u64 [%frame+184],%r453; ld.u32 %r917,[%frame+176]; add.u32 %r210,%r917,1; st.u32 [%frame+176],%r210; setp.gt.s32 %r918,%r210,7; @ %r918 bra $L145; add.u64 %r322,%r322,16; bra $L144; $L145: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r923,[%value_in]; } setp.ne.u32 %r924,%r923,0; @ %r924 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L144: .loc 1 1693 0 @ %r1324 bra $L146; .loc 1 1694 0 st.u64 [%r322],%r1355; mov.u64 %r927,2; st.u64 [%r322+8],%r927; add.u64 %r453,%r453,2; st.u64 [%frame+184],%r453; ld.u32 %r928,[%frame+176]; add.u32 %r214,%r928,1; st.u32 [%frame+176],%r214; setp.gt.s32 %r929,%r214,7; @ %r929 bra $L147; add.u64 %r322,%r322,16; bra $L146; $L147: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r934,[%value_in]; } setp.ne.u32 %r935,%r934,0; @ %r935 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L146: .loc 1 1697 0 setp.ne.u32 %r936,%r204,128; @ %r936 bra $L148; .loc 1 1698 0 sub.u32 %r347,%r315,%r320; setp.le.s32 %r937,%r347,0; @ %r937 bra $L148; ld.u32 %r470,[%frame+176]; setp.le.s32 %r938,%r347,16; @ ! %r938 bra $L358; cvta.const.u64 %r1319,zeroes$4103; bra $L149; $L358: cvta.const.u64 %r1319,zeroes$4103; $L152: st.u64 [%r322],%r1319; mov.u64 %r940,16; st.u64 [%r322+8],%r940; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r470,%r470,1; st.u32 [%frame+176],%r470; setp.gt.s32 %r941,%r470,7; @ %r941 bra $L150; add.u64 %r322,%r322,16; bra $L151; $L150: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r946,[%value_in]; } setp.ne.u32 %r947,%r946,0; @ %r947 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r470,[%frame+176]; mov.u64 %r322,%frame; $L151: add.u32 %r347,%r347,-16; setp.gt.s32 %r948,%r347,16; @ %r948 bra $L152; $L149: st.u64 [%r322],%r1319; cvt.s64.s32 %r218,%r347; st.u64 [%r322+8],%r218; add.u64 %r453,%r453,%r218; st.u64 [%frame+184],%r453; add.u32 %r219,%r470,1; st.u32 [%frame+176],%r219; setp.gt.s32 %r950,%r219,7; @ %r950 bra $L153; add.u64 %r322,%r322,16; bra $L148; $L153: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r955,[%value_in]; } setp.ne.u32 %r956,%r955,0; @ %r956 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L148: .loc 1 1701 0 sub.u32 %r356,%r316,%r321; setp.le.s32 %r957,%r356,0; @ %r957 bra $L154; ld.u32 %r469,[%frame+176]; setp.le.s32 %r958,%r356,16; @ ! %r958 bra $L359; cvta.const.u64 %r1319,zeroes$4103; bra $L155; $L359: cvta.const.u64 %r1319,zeroes$4103; $L158: st.u64 [%r322],%r1319; mov.u64 %r960,16; st.u64 [%r322+8],%r960; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r469,%r469,1; st.u32 [%frame+176],%r469; setp.gt.s32 %r961,%r469,7; @ %r961 bra $L156; add.u64 %r322,%r322,16; bra $L157; $L156: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r966,[%value_in]; } setp.ne.u32 %r967,%r966,0; @ %r967 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r469,[%frame+176]; mov.u64 %r322,%frame; $L157: add.u32 %r356,%r356,-16; setp.gt.s32 %r968,%r356,16; @ %r968 bra $L158; $L155: st.u64 [%r322],%r1319; cvt.s64.s32 %r223,%r356; st.u64 [%r322+8],%r223; add.u64 %r453,%r453,%r223; st.u64 [%frame+184],%r453; add.u32 %r224,%r469,1; st.u32 [%frame+176],%r224; setp.gt.s32 %r970,%r224,7; @ %r970 bra $L159; add.u64 %r322,%r322,16; bra $L154; $L159: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r975,[%value_in]; } setp.ne.u32 %r976,%r975,0; @ %r976 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L154: .loc 1 1705 0 and.b32 %r977,%r314,256; setp.ne.u32 %r978,%r977,0; @ %r978 bra $L160; .loc 1 1706 0 st.u64 [%r322],%r313; cvt.s64.s32 %r227,%r321; st.u64 [%r322+8],%r227; add.u64 %r453,%r453,%r227; st.u64 [%frame+184],%r453; ld.u32 %r979,[%frame+176]; add.u32 %r230,%r979,1; st.u32 [%frame+176],%r230; setp.gt.s32 %r980,%r230,7; @ %r980 bra $L161; add.u64 %r322,%r322,16; bra $L162; $L161: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r985,[%value_in]; } setp.ne.u32 %r986,%r985,0; @ %r986 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L160: .loc 1 1708 0 setp.le.s32 %r987,%r311,101; @ %r987 bra $L163; .loc 1 1709 0 setp.neu.f64 %r988,%r335,0d0000000000000000; @ %r988 bra $L164; .loc 1 1711 0 cvta.const.u64 %r989,$LC7; st.u64 [%r322],%r989; mov.u64 %r990,1; st.u64 [%r322+8],%r990; add.u64 %r991,%r453,1; st.u64 [%frame+184],%r991; ld.u32 %r992,[%frame+176]; add.u32 %r234,%r992,1; st.u32 [%frame+176],%r234; setp.gt.s32 %r993,%r234,7; @ %r993 bra $L165; add.u64 %r322,%r322,16; bra $L166; $L165: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r998,[%value_in]; } setp.ne.u32 %r999,%r998,0; @ %r999 bra $L10; mov.u64 %r322,%frame; $L166: .loc 1 1712 0 ld.u32 %r1000,[%frame+212]; setp.lt.s32 %r1001,%r1000,%r401; @ %r1001 bra $L167; and.b32 %r1002,%r314,1; setp.ne.u32 %r1003,%r1002,0; @ %r1003 bra $L167; ld.u64 %r453,[%frame+184]; bra $L162; $L167: .loc 1 1713 0 st.u64 [%r322],%r327; st.u64 [%r322+8],%r507; ld.u64 %r1004,[%frame+184]; add.u64 %r453,%r507,%r1004; st.u64 [%frame+184],%r453; ld.u32 %r1005,[%frame+176]; add.u32 %r240,%r1005,1; st.u32 [%frame+176],%r240; setp.gt.s32 %r1006,%r240,7; @ %r1006 bra $L168; add.u64 %r322,%r322,16; bra $L169; $L168: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1011,[%value_in]; } setp.ne.u32 %r1012,%r1011,0; @ %r1012 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L169: .loc 1 1714 0 add.u32 %r284,%r401,-1; setp.le.s32 %r1013,%r284,0; @ %r1013 bra $L162; ld.u32 %r468,[%frame+176]; setp.le.s32 %r1014,%r284,16; @ ! %r1014 bra $L360; cvta.const.u64 %r1319,zeroes$4103; bra $L170; $L360: cvta.const.u64 %r1319,zeroes$4103; $L173: st.u64 [%r322],%r1319; mov.u64 %r1016,16; st.u64 [%r322+8],%r1016; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r468,%r468,1; st.u32 [%frame+176],%r468; setp.gt.s32 %r1017,%r468,7; @ %r1017 bra $L171; add.u64 %r322,%r322,16; bra $L172; $L171: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1022,[%value_in]; } setp.ne.u32 %r1023,%r1022,0; @ %r1023 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r468,[%frame+176]; mov.u64 %r322,%frame; $L172: add.u32 %r284,%r284,-16; setp.gt.s32 %r1024,%r284,16; @ %r1024 bra $L173; $L170: st.u64 [%r322],%r1319; cvt.s64.s32 %r244,%r284; st.u64 [%r322+8],%r244; add.u64 %r453,%r453,%r244; st.u64 [%frame+184],%r453; add.u32 %r245,%r468,1; st.u32 [%frame+176],%r245; setp.gt.s32 %r1026,%r245,7; @ %r1026 bra $L174; add.u64 %r322,%r322,16; bra $L162; $L174: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1031,[%value_in]; } setp.ne.u32 %r1032,%r1031,0; @ %r1032 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L164: .loc 1 1716 0 ld.u32 %r247,[%frame+212]; setp.gt.s32 %r1033,%r247,0; @ %r1033 bra $L175; .loc 1 1717 0 cvta.const.u64 %r1034,$LC7; st.u64 [%r322],%r1034; mov.u64 %r1035,1; st.u64 [%r322+8],%r1035; add.u64 %r453,%r453,1; st.u64 [%frame+184],%r453; ld.u32 %r1036,[%frame+176]; add.u32 %r249,%r1036,1; st.u32 [%frame+176],%r249; setp.gt.s32 %r1037,%r249,7; @ %r1037 bra $L176; add.u64 %r322,%r322,16; bra $L177; $L176: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1042,[%value_in]; } setp.ne.u32 %r1043,%r1042,0; @ %r1043 bra $L10; ld.u32 %r247,[%frame+212]; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L177: .loc 1 1718 0 or.b32 %r1044,%r401,%r247; setp.ne.u32 %r1045,%r1044,0; @ %r1045 bra $L178; and.b32 %r1046,%r314,1; setp.eq.u32 %r1047,%r1046,0; @ %r1047 bra $L162; $L178: .loc 1 1719 0 st.u64 [%r322],%r327; st.u64 [%r322+8],%r507; add.u64 %r466,%r507,%r453; st.u64 [%frame+184],%r466; ld.u32 %r1048,[%frame+176]; add.u32 %r467,%r1048,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1049,%r467,7; @ %r1049 bra $L179; add.u64 %r324,%r322,16; bra $L180; $L179: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1054,[%value_in]; } setp.ne.u32 %r1055,%r1054,0; @ %r1055 bra $L10; ld.u32 %r247,[%frame+212]; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r324,%frame; $L180: .loc 1 1720 0 setp.ge.s32 %r1056,%r247,0; @ %r1056 bra $L181; neg.s32 %r153,%r247; setp.ge.s32 %r1057,%r247,-16; @ ! %r1057 bra $L361; cvta.const.u64 %r1319,zeroes$4103; bra $L182; $L361: cvta.const.u64 %r1319,zeroes$4103; $L185: st.u64 [%r324],%r1319; mov.u64 %r1059,16; st.u64 [%r324+8],%r1059; add.u64 %r466,%r466,16; st.u64 [%frame+184],%r466; add.u32 %r467,%r467,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1060,%r467,7; @ %r1060 bra $L183; add.u64 %r324,%r324,16; bra $L184; $L183: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1065,[%value_in]; } setp.ne.u32 %r1066,%r1065,0; @ %r1066 bra $L10; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r324,%frame; $L184: add.u32 %r153,%r153,-16; setp.gt.s32 %r1067,%r153,16; @ %r1067 bra $L185; $L182: st.u64 [%r324],%r1319; cvt.s64.s32 %r255,%r153; st.u64 [%r324+8],%r255; add.u64 %r466,%r466,%r255; st.u64 [%frame+184],%r466; add.u32 %r467,%r467,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1069,%r467,7; @ %r1069 bra $L186; add.u64 %r324,%r324,16; bra $L181; $L186: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1074,[%value_in]; } setp.ne.u32 %r1075,%r1074,0; @ %r1075 bra $L10; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r324,%frame; $L181: .loc 1 1721 0 st.u64 [%r324],%r313; cvt.s64.s32 %r258,%r401; st.u64 [%r324+8],%r258; add.u64 %r453,%r258,%r466; st.u64 [%frame+184],%r453; add.u32 %r259,%r467,1; st.u32 [%frame+176],%r259; setp.gt.s32 %r1076,%r259,7; @ %r1076 bra $L187; add.u64 %r322,%r324,16; bra $L162; $L187: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1081,[%value_in]; } setp.ne.u32 %r1082,%r1081,0; @ %r1082 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L175: min.s32 %r334,%r150,%r401; .loc 1 1725 0 setp.le.s32 %r1083,%r334,0; @ %r1083 bra $L188; st.u64 [%r322],%r313; cvt.s64.s32 %r261,%r334; st.u64 [%r322+8],%r261; add.u64 %r453,%r453,%r261; st.u64 [%frame+184],%r453; ld.u32 %r1084,[%frame+176]; add.u32 %r263,%r1084,1; st.u32 [%frame+176],%r263; setp.gt.s32 %r1085,%r263,7; @ %r1085 bra $L189; add.u64 %r322,%r322,16; bra $L188; $L189: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1090,[%value_in]; } setp.ne.u32 %r1091,%r1090,0; @ %r1091 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L188: max.s32 %r265,%r334,0; sub.u32 %r228,%r150,%r265; setp.le.s32 %r1092,%r228,0; @ %r1092 bra $L190; ld.u32 %r465,[%frame+176]; setp.le.s32 %r1093,%r228,16; @ ! %r1093 bra $L362; cvta.const.u64 %r1319,zeroes$4103; bra $L191; $L362: cvta.const.u64 %r1319,zeroes$4103; $L194: st.u64 [%r322],%r1319; mov.u64 %r1095,16; st.u64 [%r322+8],%r1095; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r465,%r465,1; st.u32 [%frame+176],%r465; setp.gt.s32 %r1096,%r465,7; @ %r1096 bra $L192; add.u64 %r322,%r322,16; bra $L193; $L192: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1101,[%value_in]; } setp.ne.u32 %r1102,%r1101,0; @ %r1102 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r465,[%frame+176]; mov.u64 %r322,%frame; $L193: add.u32 %r228,%r228,-16; setp.gt.s32 %r1103,%r228,16; @ %r1103 bra $L194; $L191: st.u64 [%r322],%r1319; cvt.s64.s32 %r267,%r228; st.u64 [%r322+8],%r267; add.u64 %r453,%r453,%r267; st.u64 [%frame+184],%r453; add.u32 %r268,%r465,1; st.u32 [%frame+176],%r268; setp.gt.s32 %r1105,%r268,7; @ %r1105 bra $L195; add.u64 %r322,%r322,16; bra $L190; $L195: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1110,[%value_in]; } setp.ne.u32 %r1111,%r1110,0; @ %r1111 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L190: .loc 1 1746 0 ld.u32 %r271,[%frame+212]; setp.lt.s32 %r1112,%r271,%r401; @ %r1112 bra $L196; and.b32 %r1113,%r314,1; setp.eq.u32 %r1114,%r1113,0; @ %r1114 bra $L197; $L196: .loc 1 1747 0 st.u64 [%r322],%r327; st.u64 [%r322+8],%r507; add.u64 %r453,%r453,%r507; st.u64 [%frame+184],%r453; ld.u32 %r1115,[%frame+176]; add.u32 %r274,%r1115,1; st.u32 [%frame+176],%r274; setp.gt.s32 %r1116,%r274,7; @ %r1116 bra $L198; add.u64 %r322,%r322,16; bra $L197; $L198: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1121,[%value_in]; } setp.ne.u32 %r1122,%r1121,0; @ %r1122 bra $L10; ld.u32 %r271,[%frame+212]; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L197: .loc 1 1748 0 sub.u32 %r361,%r401,%r150; sub.u32 %r277,%r401,%r271; min.s32 %r340,%r277,%r361; setp.le.s32 %r1123,%r340,0; @ %r1123 bra $L199; .loc 1 1727 0 cvt.s64.s32 %r1124,%r150; add.u64 %r1125,%r313,%r1124; .loc 1 1748 0 st.u64 [%r322],%r1125; cvt.s64.s32 %r279,%r340; st.u64 [%r322+8],%r279; add.u64 %r453,%r453,%r279; st.u64 [%frame+184],%r453; ld.u32 %r1126,[%frame+176]; add.u32 %r281,%r1126,1; st.u32 [%frame+176],%r281; setp.gt.s32 %r1127,%r281,7; @ %r1127 bra $L200; add.u64 %r322,%r322,16; bra $L199; $L200: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1132,[%value_in]; } setp.ne.u32 %r1133,%r1132,0; @ %r1133 bra $L10; ld.u32 %r1134,[%frame+212]; sub.u32 %r277,%r401,%r1134; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L199: max.s32 %r283,%r340,0; sub.u32 %r354,%r277,%r283; setp.le.s32 %r1135,%r354,0; @ %r1135 bra $L162; ld.u32 %r464,[%frame+176]; setp.le.s32 %r1136,%r354,16; @ ! %r1136 bra $L363; cvta.const.u64 %r1319,zeroes$4103; bra $L201; $L363: cvta.const.u64 %r1319,zeroes$4103; $L204: st.u64 [%r322],%r1319; mov.u64 %r1138,16; st.u64 [%r322+8],%r1138; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r464,%r464,1; st.u32 [%frame+176],%r464; setp.gt.s32 %r1139,%r464,7; @ %r1139 bra $L202; add.u64 %r322,%r322,16; bra $L203; $L202: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1144,[%value_in]; } setp.ne.u32 %r1145,%r1144,0; @ %r1145 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r464,[%frame+176]; mov.u64 %r322,%frame; $L203: add.u32 %r354,%r354,-16; setp.gt.s32 %r1146,%r354,16; @ %r1146 bra $L204; $L201: st.u64 [%r322],%r1319; cvt.s64.s32 %r286,%r354; st.u64 [%r322+8],%r286; add.u64 %r453,%r453,%r286; st.u64 [%frame+184],%r453; add.u32 %r287,%r464,1; st.u32 [%frame+176],%r287; setp.gt.s32 %r1148,%r287,7; @ %r1148 bra $L205; add.u64 %r322,%r322,16; bra $L162; $L205: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1153,[%value_in]; } setp.ne.u32 %r1154,%r1153,0; @ %r1154 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L163: add.u64 %r460,%r453,1; ld.u32 %r485,[%frame+176]; add.u32 %r458,%r485,1; add.u64 %r293,%r322,16; .loc 1 1752 0 setp.gt.s32 %r1155,%r401,1; @ %r1155 bra $L206; and.b32 %r1156,%r314,1; setp.eq.u32 %r1157,%r1156,0; @ %r1157 bra $L207; $L206: .loc 1 1753 0 st.u64 [%r322],%r313; mov.u64 %r1158,1; st.u64 [%r322+8],%r1158; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r458; setp.le.s32 %r1159,%r458,7; @ %r1159 bra $L208; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1164,[%value_in]; } setp.ne.u32 %r1165,%r1164,0; @ %r1165 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r458,[%frame+176]; mov.u64 %r293,%frame; $L208: .loc 1 1755 0 st.u64 [%r293],%r327; st.u64 [%r293+8],%r507; add.u64 %r460,%r460,%r507; st.u64 [%frame+184],%r460; add.u32 %r461,%r458,1; st.u32 [%frame+176],%r461; setp.gt.s32 %r1166,%r461,7; @ %r1166 bra $L209; add.u64 %r293,%r293,16; bra $L210; $L209: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1171,[%value_in]; } setp.ne.u32 %r1172,%r1171,0; @ %r1172 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r461,[%frame+176]; mov.u64 %r293,%frame; $L210: add.u32 %r459,%r461,1; mov.u32 %r1327,%r459; add.u32 %r221,%r401,-1; add.u64 %r322,%r293,16; .loc 1 1756 0 setp.eq.f64 %r1173,%r335,0d0000000000000000; @ %r1173 bra $L211; .loc 1 1754 0 add.u64 %r1174,%r313,1; .loc 1 1757 0 st.u64 [%r293],%r1174; cvt.s64.s32 %r292,%r221; st.u64 [%r293+8],%r292; add.u64 %r460,%r460,%r292; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r459; setp.gt.s32 %r1175,%r459,7; @ %r1175 bra $L212; add.u32 %r459,%r461,2; add.u64 %r486,%r293,32; mov.u64 %r293,%r322; mov.u64 %r322,%r486; bra $L213; $L212: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1180,[%value_in]; } setp.ne.u32 %r1181,%r1180,0; @ %r1181 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r1182,[%frame+176]; add.u32 %r459,%r1182,1; add.u64 %r322,%frame,16; mov.u64 %r293,%frame; bra $L213; $L211: .loc 1 1760 0 setp.le.s32 %r1183,%r221,0; @ %r1183 bra $L213; setp.le.s32 %r1184,%r221,16; @ %r1184 bra $L256; cvta.const.u64 %r1319,zeroes$4103; $L217: st.u64 [%r293],%r1319; mov.u64 %r1186,16; st.u64 [%r293+8],%r1186; add.u64 %r460,%r460,16; st.u64 [%frame+184],%r460; mov.u32 %r461,%r1327; st.u32 [%frame+176],%r461; setp.gt.s32 %r1187,%r461,7; @ %r1187 bra $L215; add.u64 %r293,%r293,16; bra $L216; $L215: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1192,[%value_in]; } setp.ne.u32 %r1193,%r1192,0; @ %r1193 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r461,[%frame+176]; mov.u64 %r293,%frame; $L216: add.u32 %r221,%r221,-16; setp.gt.s32 %r1194,%r221,16; @ ! %r1194 bra $L364; add.u32 %r1327,%r461,1; bra $L217; $L364: add.u32 %r459,%r461,1; add.u64 %r462,%r293,16; bra $L214; $L256: mov.u64 %r462,%r322; cvta.const.u64 %r1319,zeroes$4103; $L214: st.u64 [%r293],%r1319; cvt.s64.s32 %r297,%r221; st.u64 [%r293+8],%r297; add.u64 %r460,%r460,%r297; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r459; setp.gt.s32 %r1196,%r459,7; @ %r1196 bra $L218; add.u32 %r459,%r459,1; add.u64 %r322,%r462,16; mov.u64 %r293,%r462; bra $L213; $L218: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1201,[%value_in]; } setp.ne.u32 %r1202,%r1201,0; @ %r1202 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r1203,[%frame+176]; add.u32 %r459,%r1203,1; add.u64 %r322,%frame,16; mov.u64 %r293,%frame; bra $L213; $L207: .loc 1 1762 0 st.u64 [%r322],%r313; mov.u64 %r1204,1; st.u64 [%r322+8],%r1204; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r458; setp.gt.s32 %r1205,%r458,7; @ %r1205 bra $L219; add.u32 %r459,%r485,2; add.u64 %r322,%r322,32; bra $L213; $L219: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1210,[%value_in]; } setp.ne.u32 %r1211,%r1210,0; @ %r1211 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r1212,[%frame+176]; add.u32 %r459,%r1212,1; add.u64 %r322,%frame,16; mov.u64 %r293,%frame; $L213: .loc 1 1763 0 st.u64 [%r293],%r1354; cvt.s64.s32 %r300,%r317; st.u64 [%r293+8],%r300; add.u64 %r453,%r300,%r460; st.u64 [%frame+184],%r453; st.u32 [%frame+176],%r459; setp.le.s32 %r1214,%r459,7; @ %r1214 bra $L162; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1219,[%value_in]; } setp.ne.u32 %r1220,%r1219,0; @ %r1220 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L162: .loc 1 1770 0 and.b32 %r1221,%r314,4; setp.eq.u32 %r1222,%r1221,0; @ %r1222 bra $L220; .loc 1 1771 0 sub.u32 %r152,%r315,%r320; setp.le.s32 %r1223,%r152,0; @ %r1223 bra $L220; ld.u32 %r454,[%frame+176]; setp.le.s32 %r1224,%r152,16; @ ! %r1224 bra $L365; cvta.const.u64 %r1318,blanks$4102; bra $L221; $L365: cvta.const.u64 %r1318,blanks$4102; $L224: st.u64 [%r322],%r1318; mov.u64 %r1226,16; st.u64 [%r322+8],%r1226; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r454,%r454,1; st.u32 [%frame+176],%r454; setp.gt.s32 %r1227,%r454,7; @ %r1227 bra $L222; add.u64 %r322,%r322,16; bra $L223; $L222: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1232,[%value_in]; } setp.ne.u32 %r1233,%r1232,0; @ %r1233 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r454,[%frame+176]; mov.u64 %r322,%frame; $L223: add.u32 %r152,%r152,-16; setp.gt.s32 %r1234,%r152,16; @ %r1234 bra $L224; $L221: st.u64 [%r322],%r1318; cvt.s64.s32 %r304,%r152; st.u64 [%r322+8],%r304; add.u64 %r453,%r453,%r304; st.u64 [%frame+184],%r453; add.u32 %r305,%r454,1; st.u32 [%frame+176],%r305; setp.le.s32 %r1236,%r305,7; @ %r1236 bra $L220; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1241,[%value_in]; } setp.ne.u32 %r1242,%r1241,0; @ %r1242 bra $L10; ld.u64 %r453,[%frame+184]; $L220: .loc 1 1774 0 max.s32 %r1243,%r315,%r320; add.u32 %r489,%r489,%r1243; .loc 1 1776 0 setp.ne.u64 %r1244,%r453,0; @ %r1244 bra $L225; $L226: mov.u32 %r1245,0; st.u32 [%frame+176],%r1245; mov.u64 %r322,%frame; bra $L5; $L225: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1250,[%value_in]; } setp.ne.u32 %r1251,%r1250,0; @ ! %r1251 bra $L226; .loc 1 1785 0 bra $L10; $L11: .loc 1 1784 0 ld.u64 %r1252,[%frame+184]; setp.eq.u64 %r1253,%r1252,0; @ %r1253 bra $L10; add.u64 %r1257,%frame,168; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1257; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1258,[%value_in]; } $L10: .loc 1 1791 0 ld.u16 %r1260,[%r491+16]; and.b16 %r1259,%r1260,64; setp.ne.u16 %r1261,%r1259,0; selp.u32 %r489,-1,%r489,%r1261; bra $L1; $L258: .loc 1 1882 0 mov.u32 %r371,%r316; $L79: .loc 1 1883 0 cvt.s64.s32 %r1263,%r371; add.u64 %r375,%r313,%r1263; bra $L227; $L78: .loc 1 1880 0 mov.u32 %r1266,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r368; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1266; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r316; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1359; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1358; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1357; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1274,[%value_in]; } mov.u64 %r313,%r1274; .loc 1 1882 0 setp.ne.u32 %r1329,%r448,71; @ ! %r1329 bra $L366; bra $L258; $L77: .loc 1 1880 0 mov.u32 %r1278,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r368; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1278; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r316; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1359; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1358; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1357; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1286,[%value_in]; } mov.u64 %r313,%r1286; .loc 1 1883 0 cvt.s64.s32 %r353,%r316; .loc 1 1885 0 ld.s8 %r1289,[%r1286]; cvt.u16.u32 %r1288,%r1289; set.u32.eq.u16 %r1290,%r1288,48; neg.s32 %r1291,%r1290; set.u32.neu.f64 %r1293,%r368,0d0000000000000000; neg.s32 %r1294,%r1293; cvt.u16.u32 %r1296,%r1291; cvt.u16.u32 %r1297,%r1294; and.b16 %r1295,%r1296,%r1297; cvt.u32.u16 %r1298,%r1295; cvt.u16.u8 %r1299,%r1298; setp.ne.u16 %r1300,%r1299,0; @ ! %r1300 bra $L367; bra $L229; $L65: .loc 1 1565 0 setp.ne.u32 %r1302,%r316,-1; @ %r1302 bra $L231; ld.s8 %r452,[%frame+218]; bra $L128; $L232: .loc 1 1883 0 cvt.s64.s32 %r1303,%r316; add.u64 %r375,%r313,%r1303; bra $L227; $L366: .loc 1 1882 0 and.b32 %r1304,%r314,1; setp.ne.u32 %r1305,%r1304,0; @ %r1305 bra $L232; bra $L368; $L231: .loc 1 1566 0 and.b32 %r350,%r314,-129; .loc 1 1574 0 set.u32.ne.u32 %r1307,%r316,0; neg.s32 %r1308,%r1307; set.u32.ne.u64 %r1310,%r318,0; neg.s32 %r1311,%r1310; cvt.u16.u32 %r1313,%r1308; cvt.u16.u32 %r1314,%r1311; or.b16 %r1312,%r1313,%r1314; cvt.u32.u16 %r1315,%r1312; cvt.u16.u8 %r1316,%r1315; setp.ne.u16 %r1317,%r1316,0; @ ! %r1317 bra $L235; bra $L259; $L1: .loc 1 1793 0 mov.u32 %value,%r489; st.param.u32 [%value_out],%value; ret; } lib_a-swab.o/ 0 0 0 644 1671 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: swab .visible .func swab (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/swab.c" // BEGIN GLOBAL FUNCTION DEF: swab .visible .func swab (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r60; .reg .u64 %r62; .reg .u64 %r67; .reg .u64 %r70; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u32 %r87; mov.u64 %r73,%ar0; mov.u64 %r74,%ar1; mov.u64 %r75,%ar2; .loc 1 35 0 setp.le.s64 %r76,%r75,1; @ %r76 bra $L5; mov.u64 %r58,%r73; mov.u64 %r57,%r74; add.u64 %r60,%r58,1; add.u64 %r62,%r74,1; add.u64 %r67,%r75,-2; and.b64 %r77,%r67,-2; add.u64 %r78,%r77,%r74; add.u64 %r70,%r78,2; $L3: .loc 1 38 0 ld.s8 %r55,[%r58]; .loc 1 39 0 ld.u8 %r79,[%r60]; st.u8 [%r57],%r79; .loc 1 40 0 cvt.u32.u32 %r80,%r55; st.u8 [%r62],%r80; add.u64 %r58,%r58,2; add.u64 %r57,%r57,2; add.u64 %r60,%r60,2; add.u64 %r62,%r62,2; .loc 1 35 0 setp.ne.u64 %r81,%r57,%r70; @ %r81 bra $L3; and.b64 %r83,%r67,-2; add.u64 %r56,%r83,3; bra $L2; $L5: mov.u64 %r56,1; $L2: .loc 1 42 0 setp.ne.u64 %r84,%r75,%r56; @ %r84 bra $L1; .loc 1 43 0 add.u64 %r85,%r74,%r75; add.u64 %r86,%r85,-1; mov.u32 %r87,0; st.u8 [%r86],%r87; $L1: .loc 1 44 0 ret; } /866 0 0 0 644 7289 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __get_current_time_locale .visible .func (.param .u64 %value_out) __get_current_time_locale; .file 1 "../../../../../newlib/libc/locale/timelocal.c" // BEGIN GLOBAL FUNCTION DECL: __time_load_locale .visible .func (.param .u32 %value_out) __time_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN VAR DEF: _time_locale .global .align 8 .u64 _time_locale[63]; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {77,97,114,0 }; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {76,67,95,84,73,77,69,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {74,97,110,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[4] = {70,101,98,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[4] = {65,112,114,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[4] = {77,97,121,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[4] = {74,117,110,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[4] = {74,117,108,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[4] = {65,117,103,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[4] = {83,101,112,0 }; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[4] = {79,99,116,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[4] = {78,111,118,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[4] = {68,101,99,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[8] = {74,97,110,117,97,114,121,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[9] = {70,101,98,114,117,97,114,121,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[6] = {77,97,114,99,104,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[6] = {65,112,114,105,108,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[5] = {74,117,110,101,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[5] = {74,117,108,121,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[7] = {65,117,103,117,115,116,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[10] = {83,101,112,116,101,109,98,101,114,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[8] = {79,99,116,111,98,101,114,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[9] = {78,111,118,101,109,98,101,114,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[9] = {68,101,99,101,109,98,101,114,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[4] = {83,117,110,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[4] = {77,111,110,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[4] = {84,117,101,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[4] = {87,101,100,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[4] = {84,104,117,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[4] = {70,114,105,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[4] = {83,97,116,0 }; // BEGIN VAR DEF: $LC31 .const .align 1 .u8 $LC31[7] = {83,117,110,100,97,121,0 }; // BEGIN VAR DEF: $LC32 .const .align 1 .u8 $LC32[7] = {77,111,110,100,97,121,0 }; // BEGIN VAR DEF: $LC33 .const .align 1 .u8 $LC33[8] = {84,117,101,115,100,97,121,0 }; // BEGIN VAR DEF: $LC34 .const .align 1 .u8 $LC34[10] = {87,101,100,110,101,115,100,97,121,0 }; // BEGIN VAR DEF: $LC35 .const .align 1 .u8 $LC35[9] = {84,104,117,114,115,100,97,121,0 }; // BEGIN VAR DEF: $LC36 .const .align 1 .u8 $LC36[7] = {70,114,105,100,97,121,0 }; // BEGIN VAR DEF: $LC37 .const .align 1 .u8 $LC37[9] = {83,97,116,117,114,100,97,121,0 }; // BEGIN VAR DEF: $LC38 .const .align 1 .u8 $LC38[9] = {37,72,58,37,77,58,37,83,0 }; // BEGIN VAR DEF: $LC39 .const .align 1 .u8 $LC39[9] = {37,109,47,37,100,47,37,121,0 }; // BEGIN VAR DEF: $LC40 .const .align 1 .u8 $LC40[21] = {37,97,32,37,98,32,37,101,32,37,72,58,37,77,58,37,83,32,37,89,0 }; // BEGIN VAR DEF: $LC41 .const .align 1 .u8 $LC41[3] = {65,77,0 }; // BEGIN VAR DEF: $LC42 .const .align 1 .u8 $LC42[3] = {80,77,0 }; // BEGIN VAR DEF: $LC43 .const .align 1 .u8 $LC43[24] = {37,97,32,37,98,32,37,101,32,37,72,58,37,77,58,37,83,32,37,90,32,37,89,0 }; // BEGIN VAR DEF: $LC44 .const .align 1 .u8 $LC44[3] = {109,100,0 }; // BEGIN VAR DEF: $LC45 .const .align 1 .u8 $LC45[12] = {37,73,58,37,77,58,37,83,32,37,112,0 }; // BEGIN VAR DEF: $LC46 .const .align 1 .u8 $LC46[1] = {0 }; // BEGIN VAR DEF: _C_time_locale .const .align 8 .u64 _C_time_locale[63] = {generic($LC1),generic($LC2),generic($LC3),generic($LC4),generic($LC5),generic($LC6),generic($LC7),generic($LC8),generic($LC9),generic($LC10),generic($LC11),generic($LC12),generic($LC13),generic($LC14),generic($LC15),generic($LC16),generic($LC5),generic($LC17),generic($LC18),generic($LC19),generic($LC20),generic($LC21),generic($LC22),generic($LC23),generic($LC24),generic($LC25),generic($LC26),generic($LC27),generic($LC28),generic($LC29),generic($LC30),generic($LC31),generic($LC32),generic($LC33),generic($LC34),generic($LC35),generic($LC36),generic($LC37),generic($LC38),generic($LC39),generic($LC40),generic($LC41),generic($LC42),generic($LC43),generic($LC13),generic($LC14),generic($LC15),generic($LC16),generic($LC5),generic($LC17),generic($LC18),generic($LC19),generic($LC20),generic($LC21),generic($LC22),generic($LC23),generic($LC44),generic($LC45),generic($LC46),generic($LC46),generic($LC46),generic($LC46),generic($LC46) }; // BEGIN VAR DEF: _time_using_locale .global .align 4 .u32 _time_using_locale[1]; // BEGIN GLOBAL FUNCTION DEF: __get_current_time_locale .visible .func (.param .u64 %value_out) __get_current_time_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 156 0 ld.global.u32 %r24,[_time_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L3; cvta.const.u64 %r23,_C_time_locale; bra $L1; $L3: cvta.global.u64 %r23,_time_locale; $L1: .loc 1 157 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __time_load_locale .visible .func (.param .u32 %value_out) __time_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u32 %r31; .reg .u64 %r32; .reg .u32 %r33; mov.u64 %r23,%ar0; .loc 1 182 0 cvta.global.u64 %r32,_time_locale; mov.u32 %r31,63; cvta.const.u64 %r29,$LC0; mov.u64 %r28,0; cvta.global.u64 %r27,_time_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r29; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r31; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r31; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r32; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r33,[%value_in]; } .loc 1 188 0 mov.u32 %value,%r33; st.param.u32 [%value_out],%value; ret; } lib_a-tolower.o/0 0 0 644 1064 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tolower .visible .func (.param .u32 %value_out) tolower (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/tolower.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: tolower .visible .func (.param .u32 %value_out) tolower (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u16 %r42; mov.u32 %r29,%ar0; .loc 1 74 0 cvt.s64.s32 %r30,%r29; ld.global.u64 %r31,[__ctype_ptr__]; add.u64 %r32,%r31,%r30; ld.u8 %r42,[%r32+1]; mov.u16 %r36,%r42; and.b16 %r35,%r36,3; cvt.u32.u16 %r39,%r35; cvt.s32.s8 %r38,%r39; cvt.u16.u32 %r37,%r38; setp.ne.u16 %r40,%r37,1; @ %r40 bra $L2; add.u32 %r29,%r29,32; $L2: .loc 1 76 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } lib_a-toupper.o/0 0 0 644 1065 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: toupper .visible .func (.param .u32 %value_out) toupper (.param .u32 %in_ar0); .file 1 "../../../../../newlib/libc/ctype/toupper.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: toupper .visible .func (.param .u32 %value_out) toupper (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u16 %r42; mov.u32 %r29,%ar0; .loc 1 73 0 cvt.s64.s32 %r30,%r29; ld.global.u64 %r31,[__ctype_ptr__]; add.u64 %r32,%r31,%r30; ld.u8 %r42,[%r32+1]; mov.u16 %r36,%r42; and.b16 %r35,%r36,3; cvt.u32.u16 %r39,%r35; cvt.s32.s8 %r38,%r39; cvt.u16.u32 %r37,%r38; setp.ne.u16 %r40,%r37,2; @ %r40 bra $L2; add.u32 %r29,%r29,-32; $L2: .loc 1 75 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } /885 0 0 0 644 700 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _user_strerror .visible .func (.param .u64 %value_out) _user_strerror (.param .u32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../newlib/libc/string/u_strerr.c" // BEGIN GLOBAL FUNCTION DEF: _user_strerror .visible .func (.param .u64 %value_out) _user_strerror (.param .u32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .loc 1 9 0 mov.u64 %value,0; .loc 1 10 0 st.param.u64 [%value_out],%value; ret; } /903 0 0 0 644 79582 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _vfprintf_r .visible .func (.param .u32 %value_out) _vfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdio/vfprintf.c" // BEGIN GLOBAL FUNCTION DECL: vfprintf .visible .func (.param .u32 %value_out) vfprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: __sbprintf .func (.param .u32 %value_out) __sbprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __sinit .extern .func __sinit (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __swsetup_r .extern .func (.param .u32 %value_out) __swsetup_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __sprint_r .extern .func (.param .u32 %value_out) __sprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _fflush_r .extern .func (.param .u32 %value_out) _fflush_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[4] = {78,65,78,0 }; // BEGIN VAR DEF: blanks$4117 .const .align 1 .u8 blanks$4117[16] = {32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {73,78,70,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {105,110,102,0 }; // BEGIN VAR DEF: zeroes$4118 .const .align 1 .u8 zeroes$4118[16] = {48,48,48,48,48,48,48,48,48,48,48,48,48,48,48,48 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {110,97,110,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[17] = {48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[17] = {48,49,50,51,52,53,54,55,56,57,97,98,99,100,101,102,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[7] = {40,110,117,108,108,41,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[2] = {48,0 }; // BEGIN GLOBAL FUNCTION DEF: _vfprintf_r .visible .func (.param .u32 %value_out) _vfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[224]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r116; .reg .u64 %r117; .reg .u64 %r126; .reg .u32 %r130; .reg .u32 %r133; .reg .u32 %r156; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r195; .reg .u64 %r206; .reg .u32 %r208; .reg .u32 %r209; .reg .u64 %r211; .reg .u32 %r212; .reg .u32 %r215; .reg .u32 %r219; .reg .u64 %r222; .reg .u32 %r224; .reg .u64 %r227; .reg .u32 %r228; .reg .u64 %r231; .reg .u32 %r233; .reg .u32 %r234; .reg .u32 %r238; .reg .u32 %r244; .reg .u64 %r247; .reg .u32 %r249; .reg .u32 %r251; .reg .u32 %r253; .reg .u32 %r254; .reg .u64 %r260; .reg .u32 %r261; .reg .u64 %r263; .reg .u32 %r264; .reg .u64 %r266; .reg .u32 %r268; .reg .u32 %r270; .reg .u64 %r272; .reg .u32 %r273; .reg .u32 %r276; .reg .u32 %r279; .reg .u32 %r281; .reg .u32 %r282; .reg .u32 %r283; .reg .u64 %r284; .reg .u32 %r286; .reg .u32 %r288; .reg .u64 %r290; .reg .u32 %r291; .reg .u64 %r296; .reg .u64 %r298; .reg .u64 %r301; .reg .u64 %r305; .reg .u64 %r309; .reg .u32 %r310; .reg .u32 %r316; .reg .u64 %r317; .reg .u64 %r318; .reg .u64 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r327; .reg .u64 %r328; .reg .u32 %r329; .reg .u64 %r330; .reg .u32 %r332; .reg .u64 %r334; .reg .u64 %r337; .reg .u32 %r342; .reg .f64 %r343; .reg .u32 %r348; .reg .u32 %r350; .reg .u64 %r351; .reg .u32 %r355; .reg .u32 %r357; .reg .u64 %r359; .reg .u64 %r360; .reg .u64 %r361; .reg .u64 %r362; .reg .u32 %r363; .reg .u32 %r365; .reg .u32 %r368; .reg .f64 %r375; .reg .u64 %r376; .reg .u64 %r377; .reg .u32 %r378; .reg .u64 %r382; .reg .u32 %r388; .reg .u64 %r392; .reg .u32 %r397; .reg .u64 %r401; .reg .u64 %r405; .reg .u32 %r406; .reg .u32 %r407; .reg .u64 %r408; .reg .u64 %r409; .reg .u64 %r410; .reg .u64 %r412; .reg .u64 %r413; .reg .u64 %r414; .reg .u64 %r415; .reg .u64 %r416; .reg .u64 %r417; .reg .u64 %r418; .reg .u64 %r421; .reg .u64 %r425; .reg .u64 %r426; .reg .u64 %r428; .reg .u64 %r429; .reg .u64 %r430; .reg .u64 %r431; .reg .u64 %r433; .reg .u64 %r440; .reg .u32 %r447; .reg .u64 %r449; .reg .u64 %r450; .reg .u64 %r453; .reg .u32 %r454; .reg .u32 %r456; .reg .u32 %r457; .reg .u32 %r458; .reg .u64 %r459; .reg .u32 %r460; .reg .u32 %r464; .reg .u32 %r465; .reg .u64 %r466; .reg .u32 %r467; .reg .u64 %r468; .reg .u32 %r470; .reg .u32 %r471; .reg .u64 %r472; .reg .u32 %r473; .reg .u32 %r474; .reg .u32 %r475; .reg .u32 %r476; .reg .u32 %r477; .reg .u32 %r486; .reg .u32 %r487; .reg .u32 %r488; .reg .u32 %r489; .reg .u32 %r490; .reg .u32 %r491; .reg .u64 %r492; .reg .u32 %r495; .reg .u64 %r496; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r499; .reg .u64 %r511; .reg .u64 %r513; .reg .pred %r514; .reg .u32 %r515; .reg .pred %r516; .reg .u16 %r518; .reg .u16 %r519; .reg .pred %r520; .reg .u16 %r521; .reg .u32 %r524; .reg .u32 %r525; .reg .u16 %r526; .reg .u16 %r527; .reg .pred %r528; .reg .u64 %r529; .reg .pred %r530; .reg .u32 %r533; .reg .pred %r534; .reg .u16 %r535; .reg .u16 %r536; .reg .pred %r537; .reg .u16 %r538; .reg .pred %r539; .reg .u32 %r544; .reg .u64 %r545; .reg .u32 %r546; .reg .u16 %r548; .reg .u32 %r549; .reg .u32 %r550; .reg .u32 %r553; .reg .u32 %r554; .reg .u16 %r555; .reg .u16 %r556; .reg .u16 %r557; .reg .u32 %r558; .reg .u16 %r559; .reg .pred %r560; .reg .u16 %r562; .reg .u32 %r563; .reg .u32 %r564; .reg .u32 %r567; .reg .u32 %r568; .reg .u16 %r569; .reg .u16 %r570; .reg .u16 %r571; .reg .u32 %r572; .reg .u16 %r573; .reg .pred %r574; .reg .u64 %r575; .reg .pred %r576; .reg .u64 %r577; .reg .u64 %r578; .reg .u32 %r579; .reg .pred %r580; .reg .u32 %r585; .reg .pred %r586; .reg .u16 %r587; .reg .u32 %r588; .reg .pred %r589; .reg .u32 %r590; .reg .pred %r591; .reg .pred %r592; .reg .pred %r593; .reg .pred %r594; .reg .pred %r595; .reg .pred %r596; .reg .pred %r597; .reg .pred %r598; .reg .pred %r599; .reg .pred %r600; .reg .pred %r601; .reg .pred %r602; .reg .pred %r603; .reg .pred %r604; .reg .pred %r605; .reg .pred %r606; .reg .pred %r607; .reg .pred %r608; .reg .pred %r609; .reg .pred %r610; .reg .pred %r611; .reg .pred %r612; .reg .pred %r613; .reg .pred %r614; .reg .pred %r615; .reg .pred %r616; .reg .pred %r617; .reg .pred %r618; .reg .pred %r619; .reg .pred %r620; .reg .pred %r621; .reg .pred %r622; .reg .pred %r623; .reg .pred %r624; .reg .pred %r625; .reg .pred %r626; .reg .u32 %r627; .reg .pred %r628; .reg .u32 %r629; .reg .pred %r630; .reg .pred %r631; .reg .pred %r632; .reg .pred %r633; .reg .u32 %r634; .reg .u32 %r636; .reg .u32 %r637; .reg .u32 %r638; .reg .pred %r639; .reg .u32 %r641; .reg .u32 %r642; .reg .u32 %r643; .reg .pred %r646; .reg .u16 %r647; .reg .pred %r648; .reg .u32 %r649; .reg .u32 %r650; .reg .pred %r651; .reg .u32 %r652; .reg .u32 %r653; .reg .pred %r654; .reg .u32 %r655; .reg .pred %r656; .reg .u32 %r657; .reg .pred %r658; .reg .u16 %r659; .reg .pred %r660; .reg .u32 %r661; .reg .pred %r662; .reg .u32 %r663; .reg .u64 %r664; .reg .u32 %r668; .reg .pred %r669; .reg .pred %r670; .reg .u32 %r671; .reg .pred %r672; .reg .u32 %r674; .reg .pred %r675; .reg .pred %r676; .reg .pred %r677; .reg .u32 %r679; .reg .u32 %r680; .reg .u32 %r682; .reg .u32 %r683; .reg .u16 %r684; .reg .u16 %r685; .reg .u16 %r686; .reg .u32 %r687; .reg .u16 %r688; .reg .pred %r689; .reg .u64 %r690; .reg .u64 %r691; .reg .u32 %r692; .reg .pred %r693; .reg .pred %r694; .reg .pred %r695; .reg .u32 %r698; .reg .u64 %r706; .reg .u32 %r707; .reg .u64 %r708; .reg .u64 %r709; .reg .pred %r710; .reg .u64 %r711; .reg .u32 %r712; .reg .pred %r713; .reg .pred %r714; .reg .u64 %r715; .reg .u32 %r718; .reg .u32 %r719; .reg .u32 %r721; .reg .u32 %r722; .reg .u16 %r723; .reg .u16 %r724; .reg .u16 %r725; .reg .u32 %r726; .reg .u16 %r727; .reg .pred %r728; .reg .pred %r729; .reg .pred %r730; .reg .u32 %r731; .reg .u32 %r732; .reg .u32 %r733; .reg .pred %r734; .reg .u32 %r738; .reg .u16 %r740; .reg .u16 %r741; .reg .u32 %r742; .reg .pred %r747; .reg .u16 %r749; .reg .u16 %r750; .reg .u32 %r751; .reg .pred %r755; .reg .u32 %r757; .reg .pred %r760; .reg .u64 %r767; .reg .u32 %r768; .reg .u16 %r770; .reg .u16 %r771; .reg .u32 %r772; .reg .u64 %r774; .reg .pred %r775; .reg .pred %r776; .reg .pred %r777; .reg .pred %r778; .reg .u32 %r779; .reg .pred %r780; .reg .u32 %r781; .reg .pred %r782; .reg .u32 %r783; .reg .pred %r784; .reg .pred %r785; .reg .u32 %r786; .reg .pred %r787; .reg .pred %r788; .reg .u32 %r789; .reg .pred %r790; .reg .u32 %r791; .reg .pred %r792; .reg .u32 %r793; .reg .u64 %r794; .reg .u32 %r795; .reg .pred %r796; .reg .u64 %r797; .reg .u32 %r798; .reg .pred %r799; .reg .u64 %r800; .reg .u32 %r801; .reg .pred %r802; .reg .u32 %r803; .reg .pred %r804; .reg .u32 %r805; .reg .pred %r806; .reg .u32 %r807; .reg .pred %r808; .reg .u16 %r809; .reg .u32 %r810; .reg .u32 %r811; .reg .u32 %r812; .reg .pred %r813; .reg .pred %r814; .reg .u32 %r816; .reg .u64 %r818; .reg .u64 %r819; .reg .pred %r820; .reg .u64 %r821; .reg .u32 %r822; .reg .u64 %r824; .reg .u32 %r825; .reg .pred %r826; .reg .u32 %r827; .reg .pred %r828; .reg .u32 %r829; .reg .pred %r830; .reg .u16 %r831; .reg .pred %r832; .reg .u32 %r833; .reg .u32 %r834; .reg .pred %r835; .reg .u32 %r836; .reg .pred %r837; .reg .u32 %r838; .reg .pred %r839; .reg .u16 %r840; .reg .u32 %r841; .reg .pred %r842; .reg .pred %r843; .reg .u32 %r844; .reg .u32 %r845; .reg .pred %r847; .reg .u32 %r849; .reg .u32 %r850; .reg .u32 %r852; .reg .u32 %r853; .reg .u16 %r854; .reg .u16 %r855; .reg .u16 %r856; .reg .u32 %r857; .reg .u16 %r858; .reg .pred %r859; .reg .u16 %r860; .reg .pred %r861; .reg .pred %r863; .reg .u16 %r865; .reg .u16 %r866; .reg .u16 %r868; .reg .u32 %r870; .reg .pred %r872; .reg .u16 %r874; .reg .u32 %r875; .reg .u32 %r876; .reg .u16 %r878; .reg .u16 %r879; .reg .u16 %r881; .reg .u16 %r882; .reg .u32 %r884; .reg .u16 %r885; .reg .pred %r886; .reg .u64 %r887; .reg .u32 %r888; .reg .u64 %r889; .reg .pred %r890; .reg .u16 %r892; .reg .u16 %r893; .reg .u32 %r894; .reg .u64 %r896; .reg .u16 %r898; .reg .u16 %r899; .reg .u32 %r900; .reg .pred %r903; .reg .u64 %r904; .reg .u64 %r905; .reg .u64 %r906; .reg .u32 %r907; .reg .pred %r908; .reg .u64 %r909; .reg .pred %r910; .reg .pred %r911; .reg .u32 %r912; .reg .pred %r913; .reg .u32 %r914; .reg .pred %r915; .reg .u32 %r916; .reg .pred %r919; .reg .pred %r920; .reg .pred %r921; .reg .u64 %r923; .reg .pred %r924; .reg .u32 %r929; .reg .pred %r930; .reg .pred %r931; .reg .pred %r933; .reg .u32 %r938; .reg .pred %r939; .reg .u64 %r942; .reg .u32 %r943; .reg .pred %r944; .reg .u32 %r949; .reg .pred %r950; .reg .u64 %r953; .reg .u32 %r954; .reg .pred %r955; .reg .u32 %r960; .reg .pred %r961; .reg .pred %r962; .reg .pred %r963; .reg .pred %r964; .reg .u64 %r966; .reg .pred %r967; .reg .u32 %r972; .reg .pred %r973; .reg .pred %r974; .reg .pred %r976; .reg .u32 %r981; .reg .pred %r982; .reg .pred %r983; .reg .pred %r984; .reg .u64 %r986; .reg .pred %r987; .reg .u32 %r992; .reg .pred %r993; .reg .pred %r994; .reg .pred %r996; .reg .u32 %r1001; .reg .pred %r1002; .reg .u32 %r1003; .reg .pred %r1004; .reg .u32 %r1005; .reg .pred %r1006; .reg .u32 %r1011; .reg .pred %r1012; .reg .pred %r1013; .reg .pred %r1014; .reg .u64 %r1015; .reg .u64 %r1016; .reg .u64 %r1017; .reg .u32 %r1018; .reg .pred %r1019; .reg .u32 %r1024; .reg .pred %r1025; .reg .u32 %r1026; .reg .pred %r1027; .reg .u32 %r1028; .reg .pred %r1029; .reg .u64 %r1030; .reg .u32 %r1031; .reg .pred %r1032; .reg .u32 %r1037; .reg .pred %r1038; .reg .pred %r1039; .reg .pred %r1040; .reg .u64 %r1042; .reg .pred %r1043; .reg .u32 %r1048; .reg .pred %r1049; .reg .pred %r1050; .reg .pred %r1052; .reg .u32 %r1057; .reg .pred %r1058; .reg .pred %r1059; .reg .u64 %r1060; .reg .u64 %r1061; .reg .u32 %r1062; .reg .pred %r1063; .reg .u32 %r1068; .reg .pred %r1069; .reg .u32 %r1070; .reg .pred %r1071; .reg .u32 %r1072; .reg .pred %r1073; .reg .u32 %r1074; .reg .pred %r1075; .reg .u32 %r1080; .reg .pred %r1081; .reg .pred %r1082; .reg .pred %r1083; .reg .u64 %r1085; .reg .pred %r1086; .reg .u32 %r1091; .reg .pred %r1092; .reg .pred %r1093; .reg .pred %r1095; .reg .u32 %r1100; .reg .pred %r1101; .reg .pred %r1102; .reg .u32 %r1107; .reg .pred %r1108; .reg .pred %r1109; .reg .u32 %r1110; .reg .pred %r1111; .reg .u32 %r1116; .reg .pred %r1117; .reg .pred %r1118; .reg .pred %r1119; .reg .u64 %r1121; .reg .pred %r1122; .reg .u32 %r1127; .reg .pred %r1128; .reg .pred %r1129; .reg .pred %r1131; .reg .u32 %r1136; .reg .pred %r1137; .reg .pred %r1138; .reg .u32 %r1139; .reg .pred %r1140; .reg .u32 %r1141; .reg .pred %r1142; .reg .u32 %r1147; .reg .pred %r1148; .reg .pred %r1149; .reg .u64 %r1150; .reg .u64 %r1151; .reg .u32 %r1152; .reg .pred %r1153; .reg .u32 %r1158; .reg .pred %r1159; .reg .u32 %r1160; .reg .pred %r1161; .reg .pred %r1162; .reg .u64 %r1164; .reg .pred %r1165; .reg .u32 %r1170; .reg .pred %r1171; .reg .pred %r1172; .reg .pred %r1174; .reg .u32 %r1179; .reg .pred %r1180; .reg .pred %r1181; .reg .u32 %r1182; .reg .pred %r1183; .reg .u64 %r1184; .reg .pred %r1185; .reg .u32 %r1190; .reg .pred %r1191; .reg .pred %r1192; .reg .u32 %r1197; .reg .pred %r1198; .reg .pred %r1199; .reg .u64 %r1200; .reg .pred %r1201; .reg .u32 %r1206; .reg .pred %r1207; .reg .u32 %r1208; .reg .pred %r1209; .reg .pred %r1210; .reg .u64 %r1212; .reg .pred %r1213; .reg .u32 %r1218; .reg .pred %r1219; .reg .pred %r1220; .reg .pred %r1222; .reg .u32 %r1227; .reg .pred %r1228; .reg .u32 %r1229; .reg .u64 %r1230; .reg .pred %r1231; .reg .u32 %r1236; .reg .pred %r1237; .reg .u32 %r1238; .reg .pred %r1240; .reg .u32 %r1245; .reg .pred %r1246; .reg .u32 %r1247; .reg .pred %r1248; .reg .pred %r1249; .reg .pred %r1250; .reg .u64 %r1252; .reg .pred %r1253; .reg .u32 %r1258; .reg .pred %r1259; .reg .pred %r1260; .reg .pred %r1262; .reg .u32 %r1267; .reg .pred %r1268; .reg .u32 %r1269; .reg .pred %r1270; .reg .u32 %r1271; .reg .u32 %r1276; .reg .pred %r1277; .reg .u64 %r1278; .reg .pred %r1279; .reg .u64 %r1283; .reg .u32 %r1284; .reg .u16 %r1285; .reg .u16 %r1286; .reg .pred %r1287; .reg .u64 %r1289; .reg .u32 %r1292; .reg .u64 %r1300; .reg .u32 %r1304; .reg .u64 %r1312; .reg .u16 %r1314; .reg .u32 %r1315; .reg .u32 %r1316; .reg .u32 %r1317; .reg .u32 %r1319; .reg .u32 %r1320; .reg .u16 %r1321; .reg .u16 %r1322; .reg .u16 %r1323; .reg .u32 %r1324; .reg .u16 %r1325; .reg .pred %r1326; .reg .pred %r1328; .reg .u64 %r1329; .reg .u32 %r1330; .reg .pred %r1331; .reg .u32 %r1333; .reg .u32 %r1334; .reg .u32 %r1336; .reg .u32 %r1337; .reg .u16 %r1338; .reg .u16 %r1339; .reg .u16 %r1340; .reg .u32 %r1341; .reg .u16 %r1342; .reg .pred %r1343; .reg .pred %r1348; .reg .u64 %r1349; .reg .u32 %r1350; .reg .u64 %r1351; .reg .u32 %r1352; .reg .pred %r1353; .reg .pred %r1354; .reg .u64 %r1355; .reg .u64 %r1379; .reg .u64 %r1380; .reg .u64 %r1381; .reg .u64 %r1382; .reg .u64 %r1383; .reg .u64 %r1384; .reg .u64 %r1385; .reg .u64 %r1386; .reg .u64 %r1387; .reg .u64 %r1388; mov.u64 %r496,%ar0; mov.u64 %r497,%ar1; mov.u64 %r498,%ar2; mov.u64 %r499,%ar3; .loc 1 696 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r511,[%value_in]; } ld.u64 %r334,[%r511]; .loc 1 697 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r334; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r513,[%value_in]; } .loc 1 859 0 setp.eq.u64 %r514,%r496,0; @ %r514 bra $L2; ld.u32 %r515,[%r496+80]; setp.ne.u32 %r516,%r515,0; @ %r516 bra $L2; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; call __sinit,(%out_arg1); } $L2: .loc 1 862 0 ld.s16 %r116,[%r497+16]; cvt.u16.u32 %r519,%r116; and.b16 %r518,%r519,8192; setp.ne.u16 %r520,%r518,0; @ %r520 bra $L3; or.b16 %r521,%r519,8192; cvt.s32.s16 %r116,%r521; st.u16 [%r497+16],%r521; ld.u32 %r525,[%r497+172]; and.b32 %r524,%r525,-8193; st.u32 [%r497+172],%r524; $L3: .loc 1 865 0 cvt.u16.u32 %r527,%r116; and.b16 %r526,%r527,8; setp.eq.u16 %r528,%r526,0; @ %r528 bra $L4; ld.u64 %r529,[%r497+24]; setp.ne.u64 %r530,%r529,0; @ %r530 bra $L5; $L4: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; call (%value_in),__swsetup_r,(%out_arg1,%out_arg2); ld.param.u32 %r533,[%value_in]; } setp.ne.u32 %r534,%r533,0; @ %r534 bra $L6; ld.s16 %r116,[%r497+16]; $L5: .loc 1 872 0 cvt.u16.u32 %r536,%r116; and.b16 %r535,%r536,26; setp.ne.u16 %r537,%r535,10; @ %r537 bra $L7; ld.u16 %r538,[%r497+18]; setp.lt.s16 %r539,%r538,0; @ %r539 bra $L7; .loc 1 875 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r498; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r499; call (%value_in),__sbprintf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r544,[%value_in]; } mov.u32 %r495,%r544; bra $L1; $L7: .loc 1 894 0 st.u64 [%frame+168],%frame; .loc 1 895 0 mov.u64 %r545,0; st.u64 [%frame+184],%r545; .loc 1 896 0 cvt.u32.u64 %r546,%r545; st.u32 [%frame+176],%r546; .loc 1 707 0 cvt.u32.u64 %r407,%r545; .loc 1 699 0 mov.f64 %r343,0d0000000000000000; .loc 1 894 0 mov.u64 %r328,%frame; .loc 1 718 0 mov.u64 %r117,%r545; .loc 1 702 0 cvt.u32.u64 %r323,%r117; .loc 1 898 0 cvt.u32.u64 %r495,%r117; .loc 1 929 0 add.u64 %r1379,%frame,168; .loc 1 1763 0 add.u64 %r1380,%frame,200; .loc 1 1694 0 add.u64 %r1381,%frame,216; .loc 1 1692 0 add.u64 %r1382,%frame,218; .loc 1 1880 0 add.u64 %r1383,%frame,192; add.u64 %r1384,%frame,208; add.u64 %r1385,%frame,212; .loc 1 1928 0 add.u64 %r1386,%frame,204; .loc 1 1917 0 add.u64 %r1387,%frame,199; .loc 1 1923 0 add.u64 %r1388,%frame,202; $L9: .loc 1 925 0 ld.s8 %r283,[%r498]; cvt.u16.u32 %r548,%r283; set.u32.ne.u16 %r549,%r548,37; neg.s32 %r550,%r549; set.u32.ne.u16 %r553,%r548,0; neg.s32 %r554,%r553; cvt.u16.u32 %r556,%r550; cvt.u16.u32 %r557,%r554; and.b16 %r555,%r556,%r557; cvt.u32.u16 %r558,%r555; cvt.u16.u8 %r559,%r558; setp.eq.u16 %r560,%r559,0; @ %r560 bra $L240; mov.u64 %r317,%r498; $L11: .loc 1 926 0 add.u64 %r317,%r317,1; .loc 1 925 0 ld.s8 %r342,[%r317]; cvt.u16.u32 %r562,%r342; set.u32.ne.u16 %r563,%r562,0; neg.s32 %r564,%r563; set.u32.ne.u16 %r567,%r562,37; neg.s32 %r568,%r567; cvt.u16.u32 %r570,%r564; cvt.u16.u32 %r571,%r568; and.b16 %r569,%r570,%r571; cvt.u32.u16 %r572,%r569; cvt.u16.u8 %r573,%r572; setp.ne.u16 %r574,%r573,0; @ %r574 bra $L11; sub.u64 %r575,%r317,%r498; cvt.u32.u64 %r447,%r575; .loc 1 928 0 setp.eq.u32 %r576,%r447,0; @ %r576 bra $L10; .loc 1 929 0 st.u64 [%r328],%r498; cvt.s64.s32 %r126,%r447; st.u64 [%r328+8],%r126; ld.u64 %r578,[%frame+184]; add.u64 %r577,%r578,%r126; st.u64 [%frame+184],%r577; ld.u32 %r579,[%frame+176]; add.u32 %r130,%r579,1; st.u32 [%frame+176],%r130; setp.gt.s32 %r580,%r130,7; @ %r580 bra $L12; add.u64 %r328,%r328,16; bra $L13; $L12: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r585,[%value_in]; } setp.ne.u32 %r586,%r585,0; @ %r586 bra $L14; mov.u64 %r328,%frame; $L13: .loc 1 930 0 add.u32 %r495,%r495,%r447; bra $L10; $L240: .loc 1 925 0 mov.u64 %r317,%r498; $L10: .loc 1 936 0 ld.s8 %r588,[%r317]; cvt.u16.u32 %r587,%r588; setp.eq.u16 %r589,%r587,0; @ %r589 bra $L15; .loc 1 940 0 add.u64 %r498,%r317,1; .loc 1 946 0 mov.u32 %r590,0; st.u8 [%frame+218],%r590; ld.s8 %r490,[%r317+1]; mov.u32 %r397,0; mov.u32 %r329,%r397; .loc 1 945 0 mov.u32 %r322,-1; .loc 1 944 0 mov.u32 %r321,%r397; .loc 1 942 0 mov.u32 %r320,%r397; bra $L16; $L241: .loc 1 1018 0 mov.u64 %r499,%r412; $L16: .loc 1 958 0 add.u64 %r498,%r498,1; mov.u32 %r316,%r490; $L17: .loc 1 959 0 setp.eq.u32 %r591,%r316,85; @ %r591 bra $L19; setp.gt.s32 %r592,%r316,85; @ %r592 bra $L20; setp.eq.u32 %r593,%r316,48; @ %r593 bra $L21; setp.gt.s32 %r594,%r316,48; @ %r594 bra $L22; setp.eq.u32 %r595,%r316,42; @ %r595 bra $L23; setp.gt.s32 %r596,%r316,42; @ %r596 bra $L24; setp.eq.u32 %r597,%r316,32; @ %r597 bra $L25; setp.eq.u32 %r598,%r316,35; @ %r598 bra $L26; bra $L18; $L24: setp.eq.u32 %r599,%r316,45; @ %r599 bra $L27; setp.eq.u32 %r600,%r316,46; @ %r600 bra $L28; setp.eq.u32 %r601,%r316,43; @ ! %r601 bra $L18; bra $L29; $L22: setp.eq.u32 %r602,%r316,69; @ %r602 bra $L30; setp.gt.s32 %r603,%r316,69; @ %r603 bra $L31; setp.le.s32 %r604,%r316,57; @ %r604 bra $L32; setp.eq.u32 %r605,%r316,68; @ %r605 bra $L33; bra $L18; $L31: setp.eq.u32 %r606,%r316,76; @ %r606 bra $L34; setp.eq.u32 %r607,%r316,79; @ %r607 bra $L35; setp.eq.u32 %r608,%r316,71; @ ! %r608 bra $L18; bra $L30; $L20: setp.eq.u32 %r609,%r316,108; @ %r609 bra $L36; setp.gt.s32 %r610,%r316,108; @ %r610 bra $L37; setp.gt.s32 %r611,%r316,103; @ %r611 bra $L38; setp.ge.s32 %r612,%r316,101; @ %r612 bra $L30; setp.eq.u32 %r613,%r316,99; @ %r613 bra $L39; setp.gt.s32 %r614,%r316,99; @ %r614 bra $L40; setp.eq.u32 %r615,%r316,88; @ %r615 bra $L41; bra $L18; $L38: setp.eq.u32 %r616,%r316,104; @ %r616 bra $L42; setp.eq.u32 %r617,%r316,105; @ %r617 bra $L40; bra $L18; $L37: setp.eq.u32 %r618,%r316,113; @ %r618 bra $L43; setp.gt.s32 %r619,%r316,113; @ %r619 bra $L44; setp.eq.u32 %r620,%r316,111; @ %r620 bra $L45; setp.gt.s32 %r621,%r316,111; @ %r621 bra $L46; setp.eq.u32 %r622,%r316,110; @ %r622 bra $L47; bra $L18; $L44: setp.eq.u32 %r623,%r316,117; @ %r623 bra $L48; setp.eq.u32 %r624,%r316,120; @ %r624 bra $L49; setp.eq.u32 %r625,%r316,115; @ ! %r625 bra $L18; bra $L50; $L27: ld.s8 %r490,[%r498]; bra $L51; $L41: setp.eq.u32 %r626,%r397,0; @ %r626 bra $L52; cvt.u32.u32 %r627,%r329; st.u8 [%frame+218],%r627; $L52: .loc 1 1542 0 cvta.const.u64 %r117,$LC4; bra $L53; $L40: setp.eq.u32 %r628,%r397,0; @ %r628 bra $L55; cvt.u32.u32 %r629,%r329; st.u8 [%frame+218],%r629; bra $L55; $L25: ld.s8 %r490,[%r498]; .loc 1 975 0 setp.ne.u32 %r630,%r329,0; selp.u32 %r397,%r397,1,%r630; selp.u32 %r329,%r329,32,%r630; bra $L16; $L26: .loc 1 979 0 or.b32 %r320,%r320,1; ld.s8 %r490,[%r498]; .loc 1 980 0 bra $L16; $L23: .loc 1 1018 0 add.u64 %r412,%r499,4; ld.u32 %r321,[%r499]; ld.s8 %r490,[%r498]; .loc 1 1022 0 setp.ge.s32 %r631,%r321,0; @ %r631 bra $L241; .loc 1 1024 0 neg.s32 %r321,%r321; .loc 1 1018 0 mov.u64 %r499,%r412; $L51: .loc 1 1027 0 or.b32 %r320,%r320,4; .loc 1 1028 0 bra $L16; $L29: ld.s8 %r490,[%r498]; .loc 1 1031 0 mov.u32 %r397,1; .loc 1 1030 0 mov.u32 %r329,%r316; .loc 1 1031 0 bra $L16; $L28: .loc 1 1033 0 add.u64 %r362,%r498,1; ld.s8 %r316,[%r498]; setp.eq.u32 %r632,%r316,42; @ %r632 bra $L57; .loc 1 1072 0 add.u32 %r1350,%r316,-48; setp.le.u32 %r633,%r1350,9; @ %r633 bra $L58; .loc 1 1033 0 mov.u64 %r498,%r362; .loc 1 1071 0 mov.u32 %r322,0; bra $L17; $L57: ld.u32 %r634,[%r499]; max.s32 %r322,%r634,-1; ld.s8 %r490,[%r498+1]; .loc 1 1063 0 add.u64 %r499,%r499,4; .loc 1 1033 0 mov.u64 %r498,%r362; bra $L16; $L58: mov.u64 %r377,%r362; .loc 1 1071 0 mov.u32 %r322,0; $L60: .loc 1 1073 0 shl.b32 %r636,%r322,2; add.u32 %r637,%r636,%r322; add.u32 %r638,%r637,%r637; add.u32 %r322,%r638,%r1350; add.u64 %r498,%r377,1; .loc 1 1074 0 ld.s8 %r316,[%r377]; .loc 1 1072 0 add.u32 %r1350,%r316,-48; mov.u64 %r377,%r498; setp.le.u32 %r639,%r1350,9; @ %r639 bra $L60; bra $L17; $L21: .loc 1 1084 0 or.b32 %r320,%r320,128; ld.s8 %r490,[%r498]; .loc 1 1085 0 bra $L16; $L32: mov.u64 %r376,%r498; .loc 1 1088 0 mov.u32 %r321,0; add.u32 %r1350,%r316,-48; $L61: .loc 1 1090 0 shl.b32 %r641,%r321,2; add.u32 %r642,%r641,%r321; add.u32 %r643,%r642,%r642; add.u32 %r321,%r1350,%r643; add.u64 %r498,%r498,1; .loc 1 1091 0 ld.s8 %r316,[%r376]; mov.u64 %r376,%r498; .loc 1 1092 0 add.u32 %r1350,%r316,-48; setp.le.u32 %r646,%r1350,9; @ %r646 bra $L61; bra $L17; $L34: .loc 1 1108 0 or.b32 %r320,%r320,8; ld.s8 %r490,[%r498]; .loc 1 1109 0 bra $L16; $L42: .loc 1 1118 0 or.b32 %r320,%r320,64; ld.s8 %r490,[%r498]; .loc 1 1119 0 bra $L16; $L36: .loc 1 1122 0 ld.s8 %r490,[%r498]; cvt.u16.u32 %r647,%r490; setp.ne.u16 %r648,%r647,108; @ %r648 bra $L62; .loc 1 1124 0 or.b32 %r320,%r320,32; ld.s8 %r490,[%r498+1]; .loc 1 1123 0 add.u64 %r498,%r498,1; bra $L16; $L62: .loc 1 1127 0 or.b32 %r320,%r320,16; bra $L16; $L43: .loc 1 1130 0 or.b32 %r320,%r320,32; ld.s8 %r490,[%r498]; .loc 1 1131 0 bra $L16; $L39: .loc 1 1189 0 ld.u32 %r649,[%r499]; st.u8 [%frame+128],%r649; .loc 1 1192 0 mov.u32 %r650,0; st.u8 [%frame+218],%r650; .loc 1 1189 0 add.u64 %r499,%r499,4; .loc 1 1193 0 mov.u32 %r326,1; .loc 1 1190 0 mov.u32 %r327,%r326; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1173 0 add.u64 %r319,%frame,128; setp.eq.u32 %r1353,1,1; .loc 1 1193 0 bra $L140; $L33: setp.eq.u32 %r651,%r397,0; @ %r651 bra $L64; cvt.u32.u32 %r652,%r329; st.u8 [%frame+218],%r652; $L64: .loc 1 1195 0 or.b32 %r320,%r320,16; $L55: .loc 1 1199 0 and.b32 %r653,%r320,32; setp.eq.u32 %r654,%r653,0; @ %r654 bra $L65; add.u64 %r430,%r499,7; and.b64 %r408,%r430,-8; add.u64 %r499,%r408,8; ld.u64 %r324,[%r408]; bra $L66; $L65: and.b32 %r655,%r320,16; setp.eq.u32 %r656,%r655,0; @ %r656 bra $L67; add.u64 %r417,%r499,7; and.b64 %r413,%r417,-8; add.u64 %r499,%r413,8; ld.u64 %r324,[%r413]; bra $L66; $L67: ld.u32 %r489,[%r499]; add.u64 %r499,%r499,4; and.b32 %r657,%r320,64; setp.eq.u32 %r658,%r657,0; @ %r658 bra $L68; cvt.u16.u32 %r659,%r489; cvt.s64.s16 %r324,%r659; bra $L66; $L68: cvt.s64.s32 %r324,%r489; $L66: .loc 1 1201 0 setp.ge.s64 %r660,%r324,0; @ %r660 bra $L69; .loc 1 1207 0 neg.s64 %r324,%r324; .loc 1 1208 0 mov.u32 %r661,45; st.u8 [%frame+218],%r661; bra $L69; $L30: setp.eq.u32 %r662,%r397,0; @ %r662 bra $L70; cvt.u32.u32 %r663,%r329; st.u8 [%frame+218],%r663; $L70: add.u64 %r664,%r499,7; and.b64 %r453,%r664,-8; add.u64 %r499,%r453,8; .loc 1 1225 0 ld.f64 %r343,[%r453]; .loc 1 1236 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r343; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r668,[%value_in]; } setp.ne.u32 %r669,%r668,1; @ %r669 bra $L73; .loc 1 1237 0 setp.lt.f64 %r670,%r343,0d0000000000000000; @ %r670 bra $L74; ld.s8 %r458,[%frame+218]; bra $L75; $L74: .loc 1 1238 0 mov.u32 %r671,45; st.u8 [%frame+218],%r671; mov.u32 %r458,45; $L75: .loc 1 1239 0 setp.gt.s32 %r672,%r316,71; @ %r672 bra $L242; .loc 1 1240 0 cvta.const.u64 %r319,$LC0; bra $L76; $L242: .loc 1 1242 0 cvta.const.u64 %r319,$LC1; $L76: .loc 1 1244 0 and.b32 %r320,%r320,-129; .loc 1 1245 0 mov.u32 %r326,3; .loc 1 1243 0 mov.u32 %r327,%r326; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1245 0 bra $L63; $L73: .loc 1 1247 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r343; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r674,[%value_in]; } mov.u32 %r156,%r674; setp.ne.u32 %r675,%r674,0; @ %r675 bra $L77; .loc 1 1248 0 setp.gt.s32 %r676,%r316,71; @ %r676 bra $L243; .loc 1 1249 0 cvta.const.u64 %r319,$LC2; bra $L78; $L243: .loc 1 1251 0 cvta.const.u64 %r319,$LC3; $L78: .loc 1 1253 0 and.b32 %r320,%r320,-129; ld.s8 %r458,[%frame+218]; .loc 1 943 0 mov.u32 %r322,%r674; .loc 1 1254 0 mov.u32 %r326,3; .loc 1 1252 0 mov.u32 %r327,%r326; .loc 1 1254 0 bra $L63; $L77: and.b32 %r454,%r316,-33; .loc 1 1309 0 setp.eq.u32 %r677,%r322,-1; @ %r677 bra $L244; .loc 1 1311 0 set.u32.eq.u32 %r679,%r322,0; neg.s32 %r680,%r679; set.u32.eq.u32 %r682,%r454,71; neg.s32 %r683,%r682; cvt.u16.u32 %r685,%r680; cvt.u16.u32 %r686,%r683; and.b16 %r684,%r685,%r686; cvt.u32.u16 %r687,%r684; cvt.u16.u8 %r688,%r687; setp.ne.u16 %r689,%r688,0; .loc 1 1312 0 selp.u32 %r322,1,%r322,%r689; bra $L79; $L244: .loc 1 1310 0 mov.u32 %r322,6; $L79: .loc 1 1315 0 or.b32 %r350,%r320,256; .loc 1 1814 0 mov.b64 %r690,%r343; shr.u64 %r691,%r690,32; cvt.u32.u64 %r692,%r691; setp.ge.s32 %r693,%r692,0; @ %r693 bra $L246; .loc 1 1815 0 neg.f64 %r375,%r343; .loc 1 1816 0 mov.u32 %r406,45; bra $L80; $L246: .loc 1 1814 0 mov.f64 %r375,%r343; .loc 1 1818 0 mov.u32 %r406,0; $L80: .loc 1 1867 0 setp.eq.u32 %r694,%r454,70; @ %r694 bra $L81; .loc 1 1874 0 setp.ne.u32 %r695,%r454,69; @ %r695 bra $L82; .loc 1 1875 0 add.u32 %r378,%r322,1; .loc 1 1880 0 mov.u32 %r698,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r375; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r698; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r378; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1385; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1384; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1383; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r706,[%value_in]; } mov.u64 %r319,%r706; setp.eq.u32 %r1354,1,1; bra $L83; $L377: ld.u64 %r351,[%frame+192]; bra $L84; $L376: ld.u32 %r457,[%frame+212]; bra $L85; $L233: .loc 1 1886 0 mov.u32 %r707,1; sub.u32 %r457,%r707,%r322; st.u32 [%frame+212],%r457; $L85: .loc 1 1887 0 cvt.s64.s32 %r708,%r457; add.u64 %r709,%r708,%r360; add.u64 %r382,%r1312,%r709; setp.eq.u32 %r1354,1,1; $L231: .loc 1 1889 0 setp.eq.f64 %r710,%r375,0d0000000000000000; @ %r710 bra $L247; bra $L364; $L87: .loc 1 1892 0 add.u64 %r711,%r351,1; st.u64 [%frame+192],%r711; st.u8 [%r351],%r712; .loc 1 1891 0 ld.u64 %r351,[%frame+192]; setp.gt.u64 %r713,%r382,%r351; @ %r713 bra $L87; bra $L84; $L364: ld.u64 %r351,[%frame+192]; setp.lt.u64 %r714,%r351,%r382; @ ! %r714 bra $L84; .loc 1 1892 0 mov.u32 %r712,48; bra $L87; $L247: .loc 1 1889 0 mov.u64 %r351,%r382; $L84: .loc 1 1894 0 sub.u64 %r715,%r351,%r319; cvt.u32.u64 %r407,%r715; ld.u32 %r156,[%frame+212]; .loc 1 1320 0 @ %r1354 bra $L88; .loc 1 1321 0 set.u32.lt.s32 %r718,%r322,%r156; neg.s32 %r719,%r718; set.u32.lt.s32 %r721,%r156,-3; neg.s32 %r722,%r721; cvt.u16.u32 %r724,%r719; cvt.u16.u32 %r725,%r722; or.b16 %r723,%r724,%r725; cvt.u32.u16 %r726,%r723; cvt.u16.u8 %r727,%r726; setp.eq.u16 %r728,%r727,0; @ %r728 bra $L89; .loc 1 1322 0 add.u32 %r316,%r316,-2; bra $L90; $L88: .loc 1 1330 0 setp.eq.u32 %r729,%r316,102; @ %r729 bra $L91; $L90: .loc 1 1331 0 add.u32 %r388,%r156,-1; st.u32 [%frame+212],%r388; .loc 1 1910 0 st.u8 [%frame+200],%r316; .loc 1 1911 0 setp.ge.s32 %r730,%r388,0; @ %r730 bra $L92; .loc 1 1912 0 mov.u32 %r731,1; sub.u32 %r388,%r731,%r156; .loc 1 1913 0 mov.u32 %r732,45; st.u8 [%frame+201],%r732; bra $L93; $L92: .loc 1 1916 0 mov.u32 %r733,43; st.u8 [%frame+201],%r733; $L93: .loc 1 1918 0 setp.le.s32 %r734,%r388,9; @ %r734 bra $L94; .loc 1 1917 0 mov.u64 %r392,%r1387; bra $L95; $L248: .loc 1 1921 0 mov.u64 %r392,%r1351; $L95: .loc 1 1920 0 add.u64 %r1351,%r392,-1; rem.s32 %r738,%r388,10; cvt.u16.u32 %r741,%r738; add.u16 %r740,%r741,48; cvt.u32.u16 %r742,%r740; st.u8 [%r1351],%r742; .loc 1 1921 0 div.s32 %r388,%r388,10; setp.gt.s32 %r747,%r388,9; @ %r747 bra $L248; .loc 1 1922 0 add.u64 %r361,%r392,-2; cvt.u16.u32 %r750,%r388; add.u16 %r749,%r750,48; cvt.u32.u16 %r751,%r749; cvt.s32.s8 %r456,%r751; st.u8 [%r1351+-1],%r751; .loc 1 1923 0 setp.ge.u64 %r755,%r361,%r1387; @ %r755 bra $L249; mov.u64 %r440,%r1388; $L98: add.u64 %r361,%r361,1; cvt.u32.u32 %r757,%r456; st.u8 [%r440],%r757; add.u64 %r440,%r440,1; setp.ne.u64 %r760,%r361,%r1387; @ %r760 bra $L97; sub.u64 %r767,%r1380,%r1351; add.u64 %r401,%r1388,%r767; bra $L96; $L97: ld.s8 %r456,[%r361]; bra $L98; $L94: .loc 1 1927 0 mov.u32 %r768,48; st.u8 [%frame+202],%r768; .loc 1 1928 0 cvt.u16.u32 %r771,%r388; add.u16 %r770,%r771,48; cvt.u32.u16 %r772,%r770; st.u8 [%frame+203],%r772; mov.u64 %r401,%r1386; bra $L96; $L249: .loc 1 1923 0 mov.u64 %r401,%r1388; $L96: .loc 1 1930 0 sub.u64 %r774,%r401,%r1380; cvt.u32.u64 %r323,%r774; .loc 1 1333 0 add.u32 %r327,%r407,%r323; .loc 1 1334 0 setp.gt.s32 %r775,%r407,1; @ %r775 bra $L99; and.b32 %r156,%r320,1; setp.ne.u32 %r776,%r156,0; @ %r776 bra $L99; max.s32 %r326,%r327,0; bra $L100; $L99: .loc 1 1335 0 add.u32 %r327,%r327,1; max.s32 %r326,%r327,0; .loc 1 948 0 mov.u32 %r156,0; bra $L100; $L91: .loc 1 1341 0 setp.le.s32 %r777,%r156,0; @ %r777 bra $L101; .loc 1 1343 0 setp.ne.u32 %r778,%r322,0; @ %r778 bra $L102; and.b32 %r779,%r320,1; setp.eq.u32 %r780,%r779,0; @ %r780 bra $L250; $L102: .loc 1 1344 0 add.u32 %r781,%r322,1; add.u32 %r327,%r781,%r156; mov.u32 %r326,%r327; bra $L100; $L101: .loc 1 1348 0 setp.ne.u32 %r782,%r322,0; @ %r782 bra $L104; .loc 1 1346 0 and.b32 %r783,%r320,1; setp.eq.u32 %r784,%r783,0; @ %r784 bra $L251; $L104: .loc 1 1348 0 add.u32 %r327,%r322,2; mov.u32 %r326,%r327; bra $L100; $L89: .loc 1 1349 0 setp.gt.s32 %r785,%r407,%r156; @ %r785 bra $L105; .loc 1 1351 0 and.b32 %r786,%r320,1; setp.ne.u32 %r787,%r786,0; @ %r787 bra $L106; max.s32 %r326,%r156,0; mov.u32 %r327,%r156; mov.u32 %r316,103; bra $L100; $L106: .loc 1 1352 0 add.u32 %r327,%r156,1; max.s32 %r326,%r327,0; mov.u32 %r316,103; bra $L100; $L105: .loc 1 1355 0 setp.gt.s32 %r788,%r156,0; @ %r788 bra $L252; mov.u32 %r789,2; sub.u32 %r332,%r789,%r156; bra $L107; $L252: mov.u32 %r332,1; $L107: .loc 1 1354 0 add.u32 %r327,%r332,%r407; max.s32 %r326,%r327,0; mov.u32 %r316,103; bra $L100; $L250: mov.u32 %r326,%r156; mov.u32 %r327,%r156; bra $L100; $L251: mov.u32 %r326,1; .loc 1 1348 0 mov.u32 %r327,%r326; $L100: .loc 1 1377 0 setp.ne.u32 %r790,%r406,0; @ %r790 bra $L108; ld.s8 %r458,[%frame+218]; .loc 1 1315 0 mov.u32 %r320,%r350; .loc 1 943 0 mov.u32 %r322,%r406; bra $L63; $L108: .loc 1 1378 0 mov.u32 %r791,45; st.u8 [%frame+218],%r791; .loc 1 1315 0 mov.u32 %r320,%r350; .loc 1 943 0 mov.u32 %r322,0; setp.eq.u32 %r1353,1,0; bra $L365; $L47: setp.eq.u32 %r792,%r397,0; @ %r792 bra $L109; cvt.u32.u32 %r793,%r329; st.u8 [%frame+218],%r793; $L109: add.u64 %r794,%r499,7; and.b64 %r449,%r794,-8; add.u64 %r499,%r449,8; ld.u64 %r450,[%r449]; .loc 1 1392 0 and.b32 %r795,%r320,32; setp.eq.u32 %r796,%r795,0; @ %r796 bra $L110; .loc 1 1393 0 cvt.s64.s32 %r797,%r495; st.u64 [%r450],%r797; bra $L9; $L110: .loc 1 1396 0 and.b32 %r798,%r320,16; setp.eq.u32 %r799,%r798,0; @ %r799 bra $L112; .loc 1 1397 0 cvt.s64.s32 %r800,%r495; st.u64 [%r450],%r800; bra $L9; $L112: .loc 1 1398 0 and.b32 %r801,%r320,64; setp.eq.u32 %r802,%r801,0; @ %r802 bra $L113; .loc 1 1399 0 st.u16 [%r450],%r495; bra $L9; $L113: .loc 1 1405 0 st.u32 [%r450],%r495; bra $L9; $L35: .loc 1 1408 0 or.b32 %r320,%r320,16; $L45: .loc 1 1411 0 and.b32 %r803,%r320,32; setp.eq.u32 %r804,%r803,0; @ %r804 bra $L114; add.u64 %r418,%r499,7; and.b64 %r414,%r418,-8; add.u64 %r499,%r414,8; ld.u64 %r324,[%r414]; .loc 1 1412 0 mov.u32 %r325,0; bra $L115; $L114: .loc 1 1411 0 and.b32 %r805,%r320,16; setp.eq.u32 %r806,%r805,0; @ %r806 bra $L116; add.u64 %r421,%r499,7; and.b64 %r409,%r421,-8; add.u64 %r499,%r409,8; ld.u64 %r324,[%r409]; .loc 1 1412 0 mov.u32 %r325,%r803; bra $L115; $L116: ld.u32 %r488,[%r499]; add.u64 %r499,%r499,4; .loc 1 1411 0 and.b32 %r807,%r320,64; setp.eq.u32 %r808,%r807,0; @ %r808 bra $L117; cvt.u16.u32 %r809,%r488; cvt.u64.u16 %r324,%r809; .loc 1 1412 0 mov.u32 %r325,%r805; bra $L115; $L117: .loc 1 1411 0 cvt.u64.u32 %r324,%r488; .loc 1 1412 0 mov.u32 %r325,%r807; bra $L115; $L46: .loc 1 1426 0 add.u64 %r433,%r499,7; and.b64 %r206,%r433,-8; add.u64 %r499,%r206,8; ld.u64 %r324,[%r206]; .loc 1 1429 0 or.b32 %r320,%r320,2; .loc 1 1430 0 mov.u32 %r810,48; st.u8 [%frame+216],%r810; .loc 1 1431 0 mov.u32 %r811,120; st.u8 [%frame+217],%r811; .loc 1 1428 0 cvta.const.u64 %r117,$LC5; .loc 1 1427 0 mov.u32 %r325,2; .loc 1 1431 0 mov.u32 %r316,120; .loc 1 1432 0 bra $L115; $L50: .loc 1 1437 0 add.u64 %r431,%r499,7; and.b64 %r405,%r431,-8; add.u64 %r499,%r405,8; ld.u64 %r319,[%r405]; .loc 1 1441 0 mov.u32 %r812,0; st.u8 [%frame+218],%r812; .loc 1 1447 0 setp.ne.u64 %r813,%r319,0; @ %r813 bra $L118; .loc 1 1449 0 min.u32 %r326,%r322,6; mov.u32 %r327,%r326; mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1448 0 cvta.const.u64 %r319,$LC6; setp.eq.u32 %r1353,1,1; bra $L140; $L118: .loc 1 1516 0 setp.eq.u32 %r814,%r322,-1; @ %r814 bra $L119; .loc 1 1522 0 cvt.s64.s32 %r818,%r322; mov.u32 %r816,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r319; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r816; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r818; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r819,[%value_in]; } .loc 1 1524 0 setp.ne.u64 %r820,%r819,0; @ %r820 bra $L120; ld.s8 %r458,[%frame+218]; mov.u32 %r326,%r322; mov.u32 %r327,%r322; .loc 1 943 0 cvt.u32.u64 %r322,%r819; .loc 1 948 0 mov.u32 %r156,%r322; bra $L63; $L120: .loc 1 1525 0 sub.u64 %r821,%r819,%r319; cvt.u32.u64 %r822,%r821; min.s32 %r327,%r322,%r822; ld.s8 %r458,[%frame+218]; max.s32 %r326,%r327,0; .loc 1 943 0 mov.u32 %r322,%r816; .loc 1 948 0 mov.u32 %r156,%r322; bra $L63; $L119: .loc 1 1531 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r319; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r824,[%value_in]; } cvt.u32.u64 %r327,%r824; ld.s8 %r458,[%frame+218]; max.s32 %r326,%r327,0; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; bra $L63; $L19: .loc 1 1535 0 or.b32 %r320,%r320,16; $L48: .loc 1 1538 0 and.b32 %r825,%r320,32; setp.eq.u32 %r826,%r825,0; @ %r826 bra $L121; add.u64 %r426,%r499,7; and.b64 %r410,%r426,-8; add.u64 %r499,%r410,8; ld.u64 %r324,[%r410]; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L121: .loc 1 1538 0 and.b32 %r827,%r320,16; setp.eq.u32 %r828,%r827,0; @ %r828 bra $L122; add.u64 %r428,%r499,7; and.b64 %r416,%r428,-8; add.u64 %r499,%r416,8; ld.u64 %r324,[%r416]; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L122: ld.u32 %r487,[%r499]; add.u64 %r499,%r499,4; .loc 1 1538 0 and.b32 %r829,%r320,64; setp.eq.u32 %r830,%r829,0; @ %r830 bra $L123; cvt.u16.u32 %r831,%r487; cvt.u64.u16 %r324,%r831; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L123: .loc 1 1538 0 cvt.u64.u32 %r324,%r487; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L49: setp.eq.u32 %r832,%r397,0; @ %r832 bra $L124; cvt.u32.u32 %r833,%r329; st.u8 [%frame+218],%r833; $L124: .loc 1 1545 0 cvta.const.u64 %r117,$LC5; $L53: .loc 1 1546 0 and.b32 %r834,%r320,32; setp.eq.u32 %r835,%r834,0; @ %r835 bra $L125; add.u64 %r415,%r499,7; and.b64 %r429,%r415,-8; add.u64 %r499,%r429,8; ld.u64 %r324,[%r429]; bra $L126; $L125: and.b32 %r836,%r320,16; setp.eq.u32 %r837,%r836,0; @ %r837 bra $L127; add.u64 %r425,%r499,7; and.b64 %r337,%r425,-8; add.u64 %r499,%r337,8; ld.u64 %r324,[%r337]; bra $L126; $L127: ld.u32 %r486,[%r499]; add.u64 %r499,%r499,4; and.b32 %r838,%r320,64; setp.eq.u32 %r839,%r838,0; @ %r839 bra $L128; cvt.u16.u32 %r840,%r486; cvt.u64.u16 %r324,%r840; bra $L126; $L128: cvt.u64.u32 %r324,%r486; $L126: .loc 1 1549 0 and.b32 %r841,%r320,1; setp.eq.u32 %r842,%r841,0; @ %r842 bra $L253; setp.eq.u64 %r843,%r324,0; @ %r843 bra $L254; .loc 1 1550 0 mov.u32 %r844,48; st.u8 [%frame+216],%r844; .loc 1 1551 0 st.u8 [%frame+217],%r316; .loc 1 1552 0 or.b32 %r320,%r320,2; .loc 1 1547 0 mov.u32 %r325,2; bra $L115; $L253: mov.u32 %r325,2; bra $L115; $L254: mov.u32 %r325,2; $L115: .loc 1 1559 0 mov.u32 %r845,0; st.u8 [%frame+218],%r845; .loc 1 1565 0 setp.eq.u32 %r847,%r322,-1; @ %r847 bra $L255; .loc 1 1566 0 and.b32 %r357,%r320,-129; .loc 1 1574 0 set.u32.ne.u64 %r849,%r324,0; neg.s32 %r850,%r849; set.u32.ne.u32 %r852,%r322,0; neg.s32 %r853,%r852; cvt.u16.u32 %r855,%r850; cvt.u16.u32 %r856,%r853; or.b16 %r854,%r855,%r856; cvt.u32.u16 %r857,%r854; cvt.u16.u8 %r858,%r857; setp.eq.u16 %r859,%r858,0; @ %r859 bra $L130; bra $L238; $L262: mov.u32 %r325,1; $L238: ld.s8 %r458,[%frame+218]; mov.u32 %r320,%r357; bra $L129; $L255: mov.u32 %r458,0; $L129: .loc 1 1580 0 cvt.u16.u32 %r860,%r325; setp.eq.u16 %r861,%r860,1; @ %r861 bra $L132; setp.eq.u16 %r863,%r860,2; @ %r863 bra $L256; .loc 1 1573 0 mov.u64 %r318,%r1379; bra $L131; $L258: .loc 1 1581 0 mov.u64 %r318,%r319; $L131: .loc 1 1583 0 add.u64 %r319,%r318,-1; cvt.u16.u64 %r866,%r324; and.b16 %r865,%r866,7; add.u16 %r868,%r865,48; cvt.u32.u16 %r870,%r868; cvt.s32.s8 %r195,%r870; st.u8 [%r319],%r870; .loc 1 1584 0 shr.u64 %r324,%r324,3; .loc 1 1585 0 setp.ne.u64 %r872,%r324,0; @ %r872 bra $L258; .loc 1 1587 0 cvt.u16.u32 %r874,%r195; set.u32.ne.u16 %r875,%r874,48; neg.s32 %r876,%r875; cvt.u16.u32 %r879,%r320; and.b16 %r878,%r879,1; cvt.u16.u32 %r882,%r876; and.b16 %r881,%r882,%r878; cvt.u32.u16 %r884,%r881; cvt.u16.u8 %r885,%r884; setp.ne.u16 %r886,%r885,0; @ %r886 bra $L134; sub.u64 %r887,%r1379,%r319; cvt.u32.u64 %r327,%r887; bra $L135; $L134: .loc 1 1588 0 add.u64 %r359,%r318,-2; mov.u32 %r888,48; st.u8 [%r319+-1],%r888; sub.u64 %r889,%r1379,%r359; cvt.u32.u64 %r327,%r889; mov.u64 %r319,%r359; bra $L135; $L132: .loc 1 1593 0 setp.gt.u64 %r890,%r324,9; @ %r890 bra $L259; .loc 1 1594 0 cvt.u16.u64 %r893,%r324; add.u16 %r892,%r893,48; cvt.u32.u16 %r894,%r892; st.u8 [%frame+167],%r894; .loc 1 1595 0 mov.u32 %r327,1; .loc 1 1594 0 add.u64 %r319,%frame,167; .loc 1 1595 0 bra $L135; $L259: .loc 1 1573 0 mov.u64 %r319,%r1379; $L136: .loc 1 1601 0 add.u64 %r319,%r319,-1; rem.u64 %r896,%r324,10; cvt.u16.u64 %r899,%r896; add.u16 %r898,%r899,48; cvt.u32.u16 %r900,%r898; st.u8 [%r319],%r900; .loc 1 1622 0 div.u64 %r324,%r324,10; .loc 1 1623 0 setp.ne.u64 %r903,%r324,0; @ %r903 bra $L136; sub.u64 %r904,%r1379,%r319; cvt.u32.u64 %r327,%r904; bra $L135; $L256: .loc 1 1573 0 mov.u64 %r319,%r1379; $L133: .loc 1 1628 0 add.u64 %r319,%r319,-1; and.b64 %r905,%r324,15; add.u64 %r906,%r117,%r905; ld.u8 %r907,[%r906]; st.u8 [%r319],%r907; .loc 1 1629 0 shr.u64 %r324,%r324,4; .loc 1 1630 0 setp.ne.u64 %r908,%r324,0; @ %r908 bra $L133; sub.u64 %r909,%r1379,%r319; cvt.u32.u64 %r327,%r909; bra $L135; $L130: .loc 1 1648 0 setp.eq.u32 %r910,%r325,0; @ %r910 bra $L137; $L239: ld.s8 %r458,[%frame+218]; .loc 1 1594 0 mov.u32 %r320,%r357; mov.u32 %r322,0; mov.u32 %r327,%r322; .loc 1 1573 0 mov.u64 %r319,%r1379; bra $L135; $L137: .loc 1 1648 0 and.b32 %r327,%r320,1; setp.ne.u32 %r911,%r327,0; @ %r911 bra $L138; mov.u32 %r322,%r325; mov.u32 %r458,%r322; .loc 1 1566 0 mov.u32 %r320,%r357; .loc 1 1573 0 mov.u64 %r319,%r1379; bra $L135; $L138: .loc 1 1649 0 mov.u32 %r912,48; st.u8 [%frame+167],%r912; mov.u32 %r458,%r325; .loc 1 1566 0 mov.u32 %r320,%r357; .loc 1 1649 0 mov.u32 %r322,%r458; add.u64 %r319,%frame,167; $L135: max.s32 %r326,%r322,%r327; .loc 1 948 0 mov.u32 %r156,0; bra $L63; $L18: setp.eq.u32 %r913,%r397,0; @ %r913 bra $L139; cvt.u32.u32 %r914,%r329; st.u8 [%frame+218],%r914; $L139: .loc 1 1655 0 setp.eq.u32 %r915,%r316,0; @ %r915 bra $L15; .loc 1 1659 0 st.u8 [%frame+128],%r316; .loc 1 1661 0 mov.u32 %r916,0; st.u8 [%frame+218],%r916; .loc 1 1662 0 mov.u32 %r326,1; .loc 1 1660 0 mov.u32 %r327,%r326; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1658 0 add.u64 %r319,%frame,128; setp.eq.u32 %r1353,1,1; .loc 1 1662 0 bra $L140; $L63: .loc 1 1681 0 setp.eq.u32 %r1353,%r458,0; @ %r1353 bra $L140; $L365: .loc 1 1682 0 add.u32 %r326,%r326,1; $L140: .loc 1 1683 0 and.b32 %r208,%r320,2; setp.eq.u32 %r1348,%r208,0; @ %r1348 bra $L141; .loc 1 1684 0 add.u32 %r326,%r326,2; $L141: .loc 1 1687 0 and.b32 %r209,%r320,132; ld.u64 %r459,[%frame+184]; setp.ne.u32 %r919,%r209,0; @ %r919 bra $L142; .loc 1 1688 0 sub.u32 %r261,%r321,%r326; setp.le.s32 %r920,%r261,0; @ %r920 bra $L142; ld.u32 %r477,[%frame+176]; setp.le.s32 %r921,%r261,16; @ ! %r921 bra $L366; cvta.const.u64 %r1355,blanks$4117; bra $L143; $L366: cvta.const.u64 %r1355,blanks$4117; $L146: st.u64 [%r328],%r1355; mov.u64 %r923,16; st.u64 [%r328+8],%r923; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r477,%r477,1; st.u32 [%frame+176],%r477; setp.gt.s32 %r924,%r477,7; @ %r924 bra $L144; add.u64 %r328,%r328,16; bra $L145; $L144: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r929,[%value_in]; } setp.ne.u32 %r930,%r929,0; @ %r930 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r477,[%frame+176]; mov.u64 %r328,%frame; $L145: add.u32 %r261,%r261,-16; setp.gt.s32 %r931,%r261,16; @ %r931 bra $L146; $L143: st.u64 [%r328],%r1355; cvt.s64.s32 %r211,%r261; st.u64 [%r328+8],%r211; add.u64 %r459,%r459,%r211; st.u64 [%frame+184],%r459; add.u32 %r212,%r477,1; st.u32 [%frame+176],%r212; setp.gt.s32 %r933,%r212,7; @ %r933 bra $L147; add.u64 %r328,%r328,16; ld.s8 %r458,[%frame+218]; setp.eq.u32 %r1353,%r458,0; bra $L142; $L147: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r938,[%value_in]; } setp.ne.u32 %r939,%r938,0; @ %r939 bra $L14; ld.s8 %r458,[%frame+218]; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; setp.eq.u32 %r1353,%r458,0; $L142: .loc 1 1691 0 @ %r1353 bra $L148; .loc 1 1692 0 st.u64 [%r328],%r1382; mov.u64 %r942,1; st.u64 [%r328+8],%r942; add.u64 %r459,%r459,1; st.u64 [%frame+184],%r459; ld.u32 %r943,[%frame+176]; add.u32 %r215,%r943,1; st.u32 [%frame+176],%r215; setp.gt.s32 %r944,%r215,7; @ %r944 bra $L149; add.u64 %r328,%r328,16; bra $L148; $L149: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r949,[%value_in]; } setp.ne.u32 %r950,%r949,0; @ %r950 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L148: .loc 1 1693 0 @ %r1348 bra $L150; .loc 1 1694 0 st.u64 [%r328],%r1381; mov.u64 %r953,2; st.u64 [%r328+8],%r953; add.u64 %r459,%r459,2; st.u64 [%frame+184],%r459; ld.u32 %r954,[%frame+176]; add.u32 %r219,%r954,1; st.u32 [%frame+176],%r219; setp.gt.s32 %r955,%r219,7; @ %r955 bra $L151; add.u64 %r328,%r328,16; bra $L150; $L151: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r960,[%value_in]; } setp.ne.u32 %r961,%r960,0; @ %r961 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L150: .loc 1 1697 0 setp.ne.u32 %r962,%r209,128; @ %r962 bra $L152; .loc 1 1698 0 sub.u32 %r355,%r321,%r326; setp.le.s32 %r963,%r355,0; @ %r963 bra $L152; ld.u32 %r476,[%frame+176]; setp.le.s32 %r964,%r355,16; @ ! %r964 bra $L367; cvta.const.u64 %r1349,zeroes$4118; bra $L153; $L367: cvta.const.u64 %r1349,zeroes$4118; $L156: st.u64 [%r328],%r1349; mov.u64 %r966,16; st.u64 [%r328+8],%r966; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r476,%r476,1; st.u32 [%frame+176],%r476; setp.gt.s32 %r967,%r476,7; @ %r967 bra $L154; add.u64 %r328,%r328,16; bra $L155; $L154: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r972,[%value_in]; } setp.ne.u32 %r973,%r972,0; @ %r973 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r476,[%frame+176]; mov.u64 %r328,%frame; $L155: add.u32 %r355,%r355,-16; setp.gt.s32 %r974,%r355,16; @ %r974 bra $L156; $L153: st.u64 [%r328],%r1349; cvt.s64.s32 %r222,%r355; st.u64 [%r328+8],%r222; add.u64 %r459,%r459,%r222; st.u64 [%frame+184],%r459; add.u32 %r224,%r476,1; st.u32 [%frame+176],%r224; setp.gt.s32 %r976,%r224,7; @ %r976 bra $L157; add.u64 %r328,%r328,16; bra $L152; $L157: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r981,[%value_in]; } setp.ne.u32 %r982,%r981,0; @ %r982 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L152: .loc 1 1701 0 sub.u32 %r365,%r322,%r327; setp.le.s32 %r983,%r365,0; @ %r983 bra $L158; ld.u32 %r475,[%frame+176]; setp.le.s32 %r984,%r365,16; @ ! %r984 bra $L368; cvta.const.u64 %r1349,zeroes$4118; bra $L159; $L368: cvta.const.u64 %r1349,zeroes$4118; $L162: st.u64 [%r328],%r1349; mov.u64 %r986,16; st.u64 [%r328+8],%r986; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r475,%r475,1; st.u32 [%frame+176],%r475; setp.gt.s32 %r987,%r475,7; @ %r987 bra $L160; add.u64 %r328,%r328,16; bra $L161; $L160: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r992,[%value_in]; } setp.ne.u32 %r993,%r992,0; @ %r993 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r475,[%frame+176]; mov.u64 %r328,%frame; $L161: add.u32 %r365,%r365,-16; setp.gt.s32 %r994,%r365,16; @ %r994 bra $L162; $L159: st.u64 [%r328],%r1349; cvt.s64.s32 %r227,%r365; st.u64 [%r328+8],%r227; add.u64 %r459,%r459,%r227; st.u64 [%frame+184],%r459; add.u32 %r228,%r475,1; st.u32 [%frame+176],%r228; setp.gt.s32 %r996,%r228,7; @ %r996 bra $L163; add.u64 %r328,%r328,16; bra $L158; $L163: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1001,[%value_in]; } setp.ne.u32 %r1002,%r1001,0; @ %r1002 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L158: .loc 1 1705 0 and.b32 %r1003,%r320,256; setp.ne.u32 %r1004,%r1003,0; @ %r1004 bra $L164; .loc 1 1706 0 st.u64 [%r328],%r319; cvt.s64.s32 %r231,%r327; st.u64 [%r328+8],%r231; add.u64 %r459,%r459,%r231; st.u64 [%frame+184],%r459; ld.u32 %r1005,[%frame+176]; add.u32 %r233,%r1005,1; st.u32 [%frame+176],%r233; setp.gt.s32 %r1006,%r233,7; @ %r1006 bra $L165; add.u64 %r328,%r328,16; bra $L166; $L165: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1011,[%value_in]; } setp.ne.u32 %r1012,%r1011,0; @ %r1012 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L164: .loc 1 1708 0 setp.le.s32 %r1013,%r316,101; @ %r1013 bra $L167; .loc 1 1709 0 setp.neu.f64 %r1014,%r343,0d0000000000000000; @ %r1014 bra $L168; .loc 1 1711 0 cvta.const.u64 %r1015,$LC7; st.u64 [%r328],%r1015; mov.u64 %r1016,1; st.u64 [%r328+8],%r1016; add.u64 %r1017,%r459,1; st.u64 [%frame+184],%r1017; ld.u32 %r1018,[%frame+176]; add.u32 %r238,%r1018,1; st.u32 [%frame+176],%r238; setp.gt.s32 %r1019,%r238,7; @ %r1019 bra $L169; add.u64 %r328,%r328,16; bra $L170; $L169: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1024,[%value_in]; } setp.ne.u32 %r1025,%r1024,0; @ %r1025 bra $L14; mov.u64 %r328,%frame; $L170: .loc 1 1712 0 ld.u32 %r1026,[%frame+212]; setp.lt.s32 %r1027,%r1026,%r407; @ %r1027 bra $L171; and.b32 %r1028,%r320,1; setp.ne.u32 %r1029,%r1028,0; @ %r1029 bra $L171; ld.u64 %r459,[%frame+184]; bra $L166; $L171: .loc 1 1713 0 st.u64 [%r328],%r334; st.u64 [%r328+8],%r513; ld.u64 %r1030,[%frame+184]; add.u64 %r459,%r513,%r1030; st.u64 [%frame+184],%r459; ld.u32 %r1031,[%frame+176]; add.u32 %r244,%r1031,1; st.u32 [%frame+176],%r244; setp.gt.s32 %r1032,%r244,7; @ %r1032 bra $L172; add.u64 %r328,%r328,16; bra $L173; $L172: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1037,[%value_in]; } setp.ne.u32 %r1038,%r1037,0; @ %r1038 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L173: .loc 1 1714 0 add.u32 %r254,%r407,-1; setp.le.s32 %r1039,%r254,0; @ %r1039 bra $L166; ld.u32 %r474,[%frame+176]; setp.le.s32 %r1040,%r254,16; @ ! %r1040 bra $L369; cvta.const.u64 %r1349,zeroes$4118; bra $L174; $L369: cvta.const.u64 %r1349,zeroes$4118; $L177: st.u64 [%r328],%r1349; mov.u64 %r1042,16; st.u64 [%r328+8],%r1042; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r474,%r474,1; st.u32 [%frame+176],%r474; setp.gt.s32 %r1043,%r474,7; @ %r1043 bra $L175; add.u64 %r328,%r328,16; bra $L176; $L175: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1048,[%value_in]; } setp.ne.u32 %r1049,%r1048,0; @ %r1049 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r474,[%frame+176]; mov.u64 %r328,%frame; $L176: add.u32 %r254,%r254,-16; setp.gt.s32 %r1050,%r254,16; @ %r1050 bra $L177; $L174: st.u64 [%r328],%r1349; cvt.s64.s32 %r247,%r254; st.u64 [%r328+8],%r247; add.u64 %r459,%r459,%r247; st.u64 [%frame+184],%r459; add.u32 %r249,%r474,1; st.u32 [%frame+176],%r249; setp.gt.s32 %r1052,%r249,7; @ %r1052 bra $L178; add.u64 %r328,%r328,16; bra $L166; $L178: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1057,[%value_in]; } setp.ne.u32 %r1058,%r1057,0; @ %r1058 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L168: .loc 1 1716 0 ld.u32 %r251,[%frame+212]; setp.gt.s32 %r1059,%r251,0; @ %r1059 bra $L179; .loc 1 1717 0 cvta.const.u64 %r1060,$LC7; st.u64 [%r328],%r1060; mov.u64 %r1061,1; st.u64 [%r328+8],%r1061; add.u64 %r459,%r459,1; st.u64 [%frame+184],%r459; ld.u32 %r1062,[%frame+176]; add.u32 %r253,%r1062,1; st.u32 [%frame+176],%r253; setp.gt.s32 %r1063,%r253,7; @ %r1063 bra $L180; add.u64 %r328,%r328,16; bra $L181; $L180: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1068,[%value_in]; } setp.ne.u32 %r1069,%r1068,0; @ %r1069 bra $L14; ld.u32 %r251,[%frame+212]; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L181: .loc 1 1718 0 or.b32 %r1070,%r407,%r251; setp.ne.u32 %r1071,%r1070,0; @ %r1071 bra $L182; and.b32 %r1072,%r320,1; setp.eq.u32 %r1073,%r1072,0; @ %r1073 bra $L166; $L182: .loc 1 1719 0 st.u64 [%r328],%r334; st.u64 [%r328+8],%r513; add.u64 %r472,%r513,%r459; st.u64 [%frame+184],%r472; ld.u32 %r1074,[%frame+176]; add.u32 %r473,%r1074,1; st.u32 [%frame+176],%r473; setp.gt.s32 %r1075,%r473,7; @ %r1075 bra $L183; add.u64 %r330,%r328,16; bra $L184; $L183: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1080,[%value_in]; } setp.ne.u32 %r1081,%r1080,0; @ %r1081 bra $L14; ld.u32 %r251,[%frame+212]; ld.u64 %r472,[%frame+184]; ld.u32 %r473,[%frame+176]; mov.u64 %r330,%frame; $L184: .loc 1 1720 0 setp.ge.s32 %r1082,%r251,0; @ %r1082 bra $L185; neg.s32 %r159,%r251; setp.ge.s32 %r1083,%r251,-16; @ ! %r1083 bra $L370; cvta.const.u64 %r1349,zeroes$4118; bra $L186; $L370: cvta.const.u64 %r1349,zeroes$4118; $L189: st.u64 [%r330],%r1349; mov.u64 %r1085,16; st.u64 [%r330+8],%r1085; add.u64 %r472,%r472,16; st.u64 [%frame+184],%r472; add.u32 %r473,%r473,1; st.u32 [%frame+176],%r473; setp.gt.s32 %r1086,%r473,7; @ %r1086 bra $L187; add.u64 %r330,%r330,16; bra $L188; $L187: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1091,[%value_in]; } setp.ne.u32 %r1092,%r1091,0; @ %r1092 bra $L14; ld.u64 %r472,[%frame+184]; ld.u32 %r473,[%frame+176]; mov.u64 %r330,%frame; $L188: add.u32 %r159,%r159,-16; setp.gt.s32 %r1093,%r159,16; @ %r1093 bra $L189; $L186: st.u64 [%r330],%r1349; cvt.s64.s32 %r260,%r159; st.u64 [%r330+8],%r260; add.u64 %r472,%r472,%r260; st.u64 [%frame+184],%r472; add.u32 %r473,%r473,1; st.u32 [%frame+176],%r473; setp.gt.s32 %r1095,%r473,7; @ %r1095 bra $L190; add.u64 %r330,%r330,16; bra $L185; $L190: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1100,[%value_in]; } setp.ne.u32 %r1101,%r1100,0; @ %r1101 bra $L14; ld.u64 %r472,[%frame+184]; ld.u32 %r473,[%frame+176]; mov.u64 %r330,%frame; $L185: .loc 1 1721 0 st.u64 [%r330],%r319; cvt.s64.s32 %r263,%r407; st.u64 [%r330+8],%r263; add.u64 %r459,%r263,%r472; st.u64 [%frame+184],%r459; add.u32 %r264,%r473,1; st.u32 [%frame+176],%r264; setp.gt.s32 %r1102,%r264,7; @ %r1102 bra $L191; add.u64 %r328,%r330,16; bra $L166; $L191: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1107,[%value_in]; } setp.ne.u32 %r1108,%r1107,0; @ %r1108 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L179: min.s32 %r133,%r156,%r407; .loc 1 1725 0 setp.le.s32 %r1109,%r133,0; @ %r1109 bra $L192; st.u64 [%r328],%r319; cvt.s64.s32 %r266,%r133; st.u64 [%r328+8],%r266; add.u64 %r459,%r459,%r266; st.u64 [%frame+184],%r459; ld.u32 %r1110,[%frame+176]; add.u32 %r268,%r1110,1; st.u32 [%frame+176],%r268; setp.gt.s32 %r1111,%r268,7; @ %r1111 bra $L193; add.u64 %r328,%r328,16; bra $L192; $L193: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1116,[%value_in]; } setp.ne.u32 %r1117,%r1116,0; @ %r1117 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L192: max.s32 %r270,%r133,0; sub.u32 %r234,%r156,%r270; setp.le.s32 %r1118,%r234,0; @ %r1118 bra $L194; ld.u32 %r471,[%frame+176]; setp.le.s32 %r1119,%r234,16; @ ! %r1119 bra $L371; cvta.const.u64 %r1349,zeroes$4118; bra $L195; $L371: cvta.const.u64 %r1349,zeroes$4118; $L198: st.u64 [%r328],%r1349; mov.u64 %r1121,16; st.u64 [%r328+8],%r1121; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r471,%r471,1; st.u32 [%frame+176],%r471; setp.gt.s32 %r1122,%r471,7; @ %r1122 bra $L196; add.u64 %r328,%r328,16; bra $L197; $L196: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1127,[%value_in]; } setp.ne.u32 %r1128,%r1127,0; @ %r1128 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r471,[%frame+176]; mov.u64 %r328,%frame; $L197: add.u32 %r234,%r234,-16; setp.gt.s32 %r1129,%r234,16; @ %r1129 bra $L198; $L195: st.u64 [%r328],%r1349; cvt.s64.s32 %r272,%r234; st.u64 [%r328+8],%r272; add.u64 %r459,%r459,%r272; st.u64 [%frame+184],%r459; add.u32 %r273,%r471,1; st.u32 [%frame+176],%r273; setp.gt.s32 %r1131,%r273,7; @ %r1131 bra $L199; add.u64 %r328,%r328,16; bra $L194; $L199: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1136,[%value_in]; } setp.ne.u32 %r1137,%r1136,0; @ %r1137 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L194: .loc 1 1746 0 ld.u32 %r276,[%frame+212]; setp.lt.s32 %r1138,%r276,%r407; @ %r1138 bra $L200; and.b32 %r1139,%r320,1; setp.eq.u32 %r1140,%r1139,0; @ %r1140 bra $L201; $L200: .loc 1 1747 0 st.u64 [%r328],%r334; st.u64 [%r328+8],%r513; add.u64 %r459,%r459,%r513; st.u64 [%frame+184],%r459; ld.u32 %r1141,[%frame+176]; add.u32 %r279,%r1141,1; st.u32 [%frame+176],%r279; setp.gt.s32 %r1142,%r279,7; @ %r1142 bra $L202; add.u64 %r328,%r328,16; bra $L201; $L202: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1147,[%value_in]; } setp.ne.u32 %r1148,%r1147,0; @ %r1148 bra $L14; ld.u32 %r276,[%frame+212]; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L201: .loc 1 1748 0 sub.u32 %r368,%r407,%r156; sub.u32 %r281,%r407,%r276; min.s32 %r348,%r281,%r368; setp.le.s32 %r1149,%r348,0; @ %r1149 bra $L203; .loc 1 1727 0 cvt.s64.s32 %r1150,%r156; add.u64 %r1151,%r319,%r1150; .loc 1 1748 0 st.u64 [%r328],%r1151; cvt.s64.s32 %r284,%r348; st.u64 [%r328+8],%r284; add.u64 %r459,%r459,%r284; st.u64 [%frame+184],%r459; ld.u32 %r1152,[%frame+176]; add.u32 %r286,%r1152,1; st.u32 [%frame+176],%r286; setp.gt.s32 %r1153,%r286,7; @ %r1153 bra $L204; add.u64 %r328,%r328,16; bra $L203; $L204: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1158,[%value_in]; } setp.ne.u32 %r1159,%r1158,0; @ %r1159 bra $L14; ld.u32 %r1160,[%frame+212]; sub.u32 %r281,%r407,%r1160; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L203: max.s32 %r288,%r348,0; sub.u32 %r363,%r281,%r288; setp.le.s32 %r1161,%r363,0; @ %r1161 bra $L166; ld.u32 %r470,[%frame+176]; setp.le.s32 %r1162,%r363,16; @ ! %r1162 bra $L372; cvta.const.u64 %r1349,zeroes$4118; bra $L205; $L372: cvta.const.u64 %r1349,zeroes$4118; $L208: st.u64 [%r328],%r1349; mov.u64 %r1164,16; st.u64 [%r328+8],%r1164; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r470,%r470,1; st.u32 [%frame+176],%r470; setp.gt.s32 %r1165,%r470,7; @ %r1165 bra $L206; add.u64 %r328,%r328,16; bra $L207; $L206: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1170,[%value_in]; } setp.ne.u32 %r1171,%r1170,0; @ %r1171 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r470,[%frame+176]; mov.u64 %r328,%frame; $L207: add.u32 %r363,%r363,-16; setp.gt.s32 %r1172,%r363,16; @ %r1172 bra $L208; $L205: st.u64 [%r328],%r1349; cvt.s64.s32 %r290,%r363; st.u64 [%r328+8],%r290; add.u64 %r459,%r459,%r290; st.u64 [%frame+184],%r459; add.u32 %r291,%r470,1; st.u32 [%frame+176],%r291; setp.gt.s32 %r1174,%r291,7; @ %r1174 bra $L209; add.u64 %r328,%r328,16; bra $L166; $L209: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1179,[%value_in]; } setp.ne.u32 %r1180,%r1179,0; @ %r1180 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L167: add.u64 %r466,%r459,1; ld.u32 %r491,[%frame+176]; add.u32 %r464,%r491,1; add.u64 %r298,%r328,16; .loc 1 1752 0 setp.gt.s32 %r1181,%r407,1; @ %r1181 bra $L210; and.b32 %r1182,%r320,1; setp.eq.u32 %r1183,%r1182,0; @ %r1183 bra $L211; $L210: .loc 1 1753 0 st.u64 [%r328],%r319; mov.u64 %r1184,1; st.u64 [%r328+8],%r1184; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r464; setp.le.s32 %r1185,%r464,7; @ %r1185 bra $L212; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1190,[%value_in]; } setp.ne.u32 %r1191,%r1190,0; @ %r1191 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r464,[%frame+176]; mov.u64 %r298,%frame; $L212: .loc 1 1755 0 st.u64 [%r298],%r334; st.u64 [%r298+8],%r513; add.u64 %r466,%r466,%r513; st.u64 [%frame+184],%r466; add.u32 %r467,%r464,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1192,%r467,7; @ %r1192 bra $L213; add.u64 %r298,%r298,16; bra $L214; $L213: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1197,[%value_in]; } setp.ne.u32 %r1198,%r1197,0; @ %r1198 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r298,%frame; $L214: add.u32 %r465,%r467,1; mov.u32 %r1352,%r465; add.u32 %r282,%r407,-1; add.u64 %r328,%r298,16; .loc 1 1756 0 setp.eq.f64 %r1199,%r343,0d0000000000000000; @ %r1199 bra $L215; .loc 1 1754 0 add.u64 %r1200,%r319,1; .loc 1 1757 0 st.u64 [%r298],%r1200; cvt.s64.s32 %r296,%r282; st.u64 [%r298+8],%r296; add.u64 %r466,%r466,%r296; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r465; setp.gt.s32 %r1201,%r465,7; @ %r1201 bra $L216; add.u32 %r465,%r467,2; add.u64 %r492,%r298,32; mov.u64 %r298,%r328; mov.u64 %r328,%r492; bra $L217; $L216: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1206,[%value_in]; } setp.ne.u32 %r1207,%r1206,0; @ %r1207 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r1208,[%frame+176]; add.u32 %r465,%r1208,1; add.u64 %r328,%frame,16; mov.u64 %r298,%frame; bra $L217; $L215: .loc 1 1760 0 setp.le.s32 %r1209,%r282,0; @ %r1209 bra $L217; setp.le.s32 %r1210,%r282,16; @ %r1210 bra $L260; cvta.const.u64 %r1349,zeroes$4118; $L221: st.u64 [%r298],%r1349; mov.u64 %r1212,16; st.u64 [%r298+8],%r1212; add.u64 %r466,%r466,16; st.u64 [%frame+184],%r466; mov.u32 %r467,%r1352; st.u32 [%frame+176],%r467; setp.gt.s32 %r1213,%r467,7; @ %r1213 bra $L219; add.u64 %r298,%r298,16; bra $L220; $L219: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1218,[%value_in]; } setp.ne.u32 %r1219,%r1218,0; @ %r1219 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r298,%frame; $L220: add.u32 %r282,%r282,-16; setp.gt.s32 %r1220,%r282,16; @ ! %r1220 bra $L373; add.u32 %r1352,%r467,1; bra $L221; $L373: add.u32 %r465,%r467,1; add.u64 %r468,%r298,16; bra $L218; $L260: mov.u64 %r468,%r328; cvta.const.u64 %r1349,zeroes$4118; $L218: st.u64 [%r298],%r1349; cvt.s64.s32 %r301,%r282; st.u64 [%r298+8],%r301; add.u64 %r466,%r466,%r301; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r465; setp.gt.s32 %r1222,%r465,7; @ %r1222 bra $L222; add.u32 %r465,%r465,1; add.u64 %r328,%r468,16; mov.u64 %r298,%r468; bra $L217; $L222: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1227,[%value_in]; } setp.ne.u32 %r1228,%r1227,0; @ %r1228 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r1229,[%frame+176]; add.u32 %r465,%r1229,1; add.u64 %r328,%frame,16; mov.u64 %r298,%frame; bra $L217; $L211: .loc 1 1762 0 st.u64 [%r328],%r319; mov.u64 %r1230,1; st.u64 [%r328+8],%r1230; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r464; setp.gt.s32 %r1231,%r464,7; @ %r1231 bra $L223; add.u32 %r465,%r491,2; add.u64 %r328,%r328,32; bra $L217; $L223: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1236,[%value_in]; } setp.ne.u32 %r1237,%r1236,0; @ %r1237 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r1238,[%frame+176]; add.u32 %r465,%r1238,1; add.u64 %r328,%frame,16; mov.u64 %r298,%frame; $L217: .loc 1 1763 0 st.u64 [%r298],%r1380; cvt.s64.s32 %r305,%r323; st.u64 [%r298+8],%r305; add.u64 %r459,%r305,%r466; st.u64 [%frame+184],%r459; st.u32 [%frame+176],%r465; setp.le.s32 %r1240,%r465,7; @ %r1240 bra $L166; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1245,[%value_in]; } setp.ne.u32 %r1246,%r1245,0; @ %r1246 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L166: .loc 1 1770 0 and.b32 %r1247,%r320,4; setp.eq.u32 %r1248,%r1247,0; @ %r1248 bra $L224; .loc 1 1771 0 sub.u32 %r158,%r321,%r326; setp.le.s32 %r1249,%r158,0; @ %r1249 bra $L224; ld.u32 %r460,[%frame+176]; setp.le.s32 %r1250,%r158,16; @ ! %r1250 bra $L374; cvta.const.u64 %r1355,blanks$4117; bra $L225; $L374: cvta.const.u64 %r1355,blanks$4117; $L228: st.u64 [%r328],%r1355; mov.u64 %r1252,16; st.u64 [%r328+8],%r1252; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r460,%r460,1; st.u32 [%frame+176],%r460; setp.gt.s32 %r1253,%r460,7; @ %r1253 bra $L226; add.u64 %r328,%r328,16; bra $L227; $L226: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1258,[%value_in]; } setp.ne.u32 %r1259,%r1258,0; @ %r1259 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r460,[%frame+176]; mov.u64 %r328,%frame; $L227: add.u32 %r158,%r158,-16; setp.gt.s32 %r1260,%r158,16; @ %r1260 bra $L228; $L225: st.u64 [%r328],%r1355; cvt.s64.s32 %r309,%r158; st.u64 [%r328+8],%r309; add.u64 %r459,%r459,%r309; st.u64 [%frame+184],%r459; add.u32 %r310,%r460,1; st.u32 [%frame+176],%r310; setp.le.s32 %r1262,%r310,7; @ %r1262 bra $L224; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1267,[%value_in]; } setp.ne.u32 %r1268,%r1267,0; @ %r1268 bra $L14; ld.u64 %r459,[%frame+184]; $L224: .loc 1 1774 0 max.s32 %r1269,%r321,%r326; add.u32 %r495,%r495,%r1269; .loc 1 1776 0 setp.ne.u64 %r1270,%r459,0; @ %r1270 bra $L229; $L230: mov.u32 %r1271,0; st.u32 [%frame+176],%r1271; mov.u64 %r328,%frame; bra $L9; $L229: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1276,[%value_in]; } setp.ne.u32 %r1277,%r1276,0; @ ! %r1277 bra $L230; .loc 1 1785 0 bra $L14; $L15: .loc 1 1784 0 ld.u64 %r1278,[%frame+184]; setp.eq.u64 %r1279,%r1278,0; @ %r1279 bra $L14; add.u64 %r1283,%frame,168; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1283; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1284,[%value_in]; } $L14: .loc 1 1791 0 ld.u16 %r1286,[%r497+16]; and.b16 %r1285,%r1286,64; setp.eq.u16 %r1287,%r1285,0; @ %r1287 bra $L1; $L6: mov.u32 %r495,-1; bra $L1; $L261: .loc 1 1882 0 mov.u32 %r378,%r322; $L83: .loc 1 1883 0 cvt.s64.s32 %r1289,%r378; add.u64 %r382,%r319,%r1289; bra $L231; $L82: .loc 1 1880 0 mov.u32 %r1292,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r375; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1292; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r322; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1385; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1384; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1383; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1300,[%value_in]; } mov.u64 %r319,%r1300; .loc 1 1882 0 setp.ne.u32 %r1354,%r454,71; @ ! %r1354 bra $L375; bra $L261; $L81: .loc 1 1880 0 mov.u32 %r1304,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r375; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1304; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r322; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1385; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1384; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1383; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1312,[%value_in]; } mov.u64 %r319,%r1312; .loc 1 1883 0 cvt.s64.s32 %r360,%r322; .loc 1 1885 0 ld.s8 %r1315,[%r1312]; cvt.u16.u32 %r1314,%r1315; set.u32.eq.u16 %r1316,%r1314,48; neg.s32 %r1317,%r1316; set.u32.neu.f64 %r1319,%r375,0d0000000000000000; neg.s32 %r1320,%r1319; cvt.u16.u32 %r1322,%r1317; cvt.u16.u32 %r1323,%r1320; and.b16 %r1321,%r1322,%r1323; cvt.u32.u16 %r1324,%r1321; cvt.u16.u8 %r1325,%r1324; setp.ne.u16 %r1326,%r1325,0; @ ! %r1326 bra $L376; bra $L233; $L69: .loc 1 1565 0 setp.ne.u32 %r1328,%r322,-1; @ %r1328 bra $L235; ld.s8 %r458,[%frame+218]; bra $L132; $L236: .loc 1 1883 0 cvt.s64.s32 %r1329,%r322; add.u64 %r382,%r319,%r1329; bra $L231; $L375: .loc 1 1882 0 and.b32 %r1330,%r320,1; setp.ne.u32 %r1331,%r1330,0; @ %r1331 bra $L236; bra $L377; $L235: .loc 1 1566 0 and.b32 %r357,%r320,-129; .loc 1 1574 0 set.u32.ne.u32 %r1333,%r322,0; neg.s32 %r1334,%r1333; set.u32.ne.u64 %r1336,%r324,0; neg.s32 %r1337,%r1336; cvt.u16.u32 %r1339,%r1334; cvt.u16.u32 %r1340,%r1337; or.b16 %r1338,%r1339,%r1340; cvt.u32.u16 %r1341,%r1338; cvt.u16.u8 %r1342,%r1341; setp.ne.u16 %r1343,%r1342,0; @ ! %r1343 bra $L239; bra $L262; $L1: .loc 1 1793 0 mov.u32 %value,%r495; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vfprintf .visible .func (.param .u32 %value_out) vfprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u32 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 657 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; call (%value_in),_vfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r32,[%value_in]; } .loc 1 659 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: __sbprintf .func (.param .u32 %value_out) __sbprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[1200]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u32 %r40; .reg .u16 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r44; .reg .u32 %r46; .reg .u64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u32 %r57; .reg .pred %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .pred %r61; .reg .u16 %r62; .reg .u16 %r63; mov.u64 %r34,%ar0; mov.u64 %r35,%ar1; mov.u64 %r36,%ar2; mov.u64 %r37,%ar3; .loc 1 470 0 ld.u16 %r39,[%r35+16]; and.b16 %r38,%r39,-3; st.u16 [%frame+1040],%r38; .loc 1 471 0 ld.u32 %r40,[%r35+172]; st.u32 [%frame+1196],%r40; .loc 1 472 0 ld.u16 %r41,[%r35+18]; st.u16 [%frame+1042],%r41; .loc 1 473 0 ld.u64 %r42,[%r35+48]; st.u64 [%frame+1072],%r42; .loc 1 474 0 ld.u64 %r43,[%r35+64]; st.u64 [%frame+1088],%r43; .loc 1 477 0 st.u64 [%frame+1024],%frame; st.u64 [%frame+1048],%frame; .loc 1 478 0 mov.u32 %r44,1024; st.u32 [%frame+1036],%r44; st.u32 [%frame+1056],%r44; .loc 1 479 0 mov.u32 %r46,0; st.u32 [%frame+1064],%r46; .loc 1 485 0 add.u64 %r51,%frame,1024; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r34; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r51; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r36; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r37; call (%value_in),_vfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r52,[%value_in]; } mov.u32 %r33,%r52; .loc 1 486 0 setp.lt.s32 %r53,%r33,0; @ %r53 bra $L380; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r34; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r51; call (%value_in),_fflush_r,(%out_arg1,%out_arg2); ld.param.u32 %r57,[%value_in]; } setp.eq.u32 %r58,%r57,0; .loc 1 487 0 selp.u32 %r33,%r33,-1,%r58; $L380: .loc 1 488 0 ld.u16 %r60,[%frame+1040]; and.b16 %r59,%r60,64; setp.eq.u16 %r61,%r59,0; @ %r61 bra $L379; .loc 1 489 0 ld.u16 %r63,[%r35+16]; or.b16 %r62,%r63,64; st.u16 [%r35+16],%r62; $L379: .loc 1 495 0 mov.u32 %value,%r33; st.param.u32 [%value_out],%value; ret; } /921 0 0 0 644 4622 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _vsnprintf_r .visible .func (.param .u32 %value_out) _vsnprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); .file 1 "../../../../../newlib/libc/stdio/vsnprintf.c" // BEGIN GLOBAL FUNCTION DECL: vsnprintf .visible .func (.param .u32 %value_out) vsnprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: _vsnprintf_r .visible .func (.param .u32 %value_out) _vsnprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .pred %r32; .reg .u32 %r33; .reg .u16 %r34; .reg .pred %r35; .reg .u32 %r36; .reg .u16 %r37; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u32 %r46; .reg .u16 %r48; .reg .u32 %r53; .reg .pred %r54; .reg .u32 %r55; .reg .u32 %r56; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; mov.u64 %r29,%ar2; mov.u64 %r30,%ar3; mov.u64 %r31,%ar4; .loc 1 63 0 setp.le.u64 %r32,%r29,2147483647; @ %r32 bra $L2; .loc 1 65 0 mov.u32 %r33,139; st.u32 [%r27],%r33; .loc 1 66 0 mov.u32 %r26,-1; bra $L1; $L2: .loc 1 68 0 mov.u16 %r34,520; st.u16 [%frame+16],%r34; .loc 1 69 0 st.u64 [%frame],%r28; st.u64 [%frame+24],%r28; .loc 1 70 0 setp.eq.u64 %r35,%r29,0; @ %r35 bra $L4; cvt.u32.u64 %r36,%r29; add.u32 %r25,%r36,-1; st.u32 [%frame+12],%r25; st.u32 [%frame+32],%r25; .loc 1 71 0 mov.u16 %r37,-1; st.u16 [%frame+18],%r37; .loc 1 72 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r31; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r42,[%value_in]; } mov.u32 %r26,%r42; .loc 1 73 0 setp.lt.s32 %r43,%r26,-1; @ %r43 bra $L5; $L7: .loc 1 76 0 ld.u64 %r24,[%frame]; mov.u32 %r44,0; st.u8 [%r24],%r44; bra $L1; $L4: .loc 1 70 0 cvt.u32.u64 %r46,%r29; st.u32 [%frame+12],%r46; st.u32 [%frame+32],%r46; .loc 1 71 0 mov.u16 %r48,-1; st.u16 [%frame+18],%r48; .loc 1 72 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r31; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r53,[%value_in]; } mov.u32 %r26,%r53; .loc 1 73 0 setp.lt.s32 %r54,%r26,-1; @ ! %r54 bra $L1; bra $L6; $L5: .loc 1 74 0 mov.u32 %r55,139; st.u32 [%r27],%r55; bra $L7; $L6: mov.u32 %r56,139; st.u32 [%r27],%r56; $L1: .loc 1 78 0 mov.u32 %value,%r26; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vsnprintf .visible .func (.param .u32 %value_out) vsnprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r33; .reg .u32 %r34; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 41 0 ld.global.u64 %r33,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r27; call (%value_in),_vsnprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u32 %r34,[%value_in]; } .loc 1 42 0 mov.u32 %value,%r34; st.param.u32 [%value_out],%value; ret; } /940 0 0 0 644 3025 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _vsprintf_r .visible .func (.param .u32 %value_out) _vsprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdio/vsprintf.c" // BEGIN GLOBAL FUNCTION DECL: vsprintf .visible .func (.param .u32 %value_out) vsprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: _vsprintf_r .visible .func (.param .u32 %value_out) _vsprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u64 %r22; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r35; .reg .u32 %r36; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 61 0 st.u64 [%frame],%r25; st.u64 [%frame+24],%r25; .loc 1 62 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r27; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r35,[%value_in]; } .loc 1 65 0 ld.u64 %r22,[%frame]; mov.u32 %r36,0; st.u8 [%r22],%r36; .loc 1 67 0 mov.u32 %value,%r35; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vsprintf .visible .func (.param .u32 %value_out) vsprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u32 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 39 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; call (%value_in),_vsprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r32,[%value_in]; } .loc 1 40 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-vsscanf.o/0 0 0 644 3628 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _vsscanf_r .visible .func (.param .u32 %value_out) _vsscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../newlib/libc/stdio/vsscanf.c" // BEGIN GLOBAL FUNCTION DECL: vsscanf .visible .func (.param .u32 %value_out) vsscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __seofread .extern .func (.param .u32 %value_out) __seofread (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ssvfscanf_r .extern .func (.param .u32 %value_out) __ssvfscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: _vsscanf_r .visible .func (.param .u32 %value_out) _vsscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .local .align 8 .b8 %frame_ar[176]; .reg .u64 %frame; cvta.local.u64 %frame,%frame_ar; .reg .u32 %r23; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u32 %r40; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; mov.u64 %r28,%ar3; .loc 1 63 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 64 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 65 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 66 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 67 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 68 0 st.u64 [%frame+120],%r33; .loc 1 69 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 70 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r28; call (%value_in),__ssvfscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r40,[%value_in]; } .loc 1 71 0 mov.u32 %value,%r40; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vsscanf .visible .func (.param .u32 %value_out) vsscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u32 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 43 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; call (%value_in),_vsscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r32,[%value_in]; } .loc 1 44 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-wcstold.o/0 0 0 644 1015 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: wcstold .visible .func (.param .f64 %value_out) wcstold (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../newlib/libc/stdlib/wcstold.c" // BEGIN GLOBAL FUNCTION DECL: wcstod .extern .func (.param .f64 %value_out) wcstod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: wcstold .visible .func (.param .f64 %value_out) wcstold (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),wcstod,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-write.o/ 0 0 0 644 2109 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: write .visible .func (.param .u32 %value_out) write (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/machine/nvptx/write.c" // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: printf .extern .func (.param .u32 %value_out) printf (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {37,99,0 }; // BEGIN GLOBAL FUNCTION DEF: write .visible .func (.param .u32 %value_out) write (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .local .align 8 .b8 %stack_ar[8]; .reg .u64 %stack; cvta.local.u64 %stack,%stack_ar; .reg .u64 %r54; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r67; .reg .u32 %r68; .reg .pred %r70; .reg .u64 %r72; mov.u32 %r58,%ar0; mov.u64 %r59,%ar1; mov.u64 %r60,%ar2; .loc 1 25 0 add.u32 %r61,%r58,-1; setp.gt.u32 %r62,%r61,1; @ %r62 bra $L2; .loc 1 30 0 setp.ne.u64 %r63,%r60,0; @ %r63 bra $L3; bra $L4; $L2: .loc 1 27 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,9; st.u32 [%r64],%r65; .loc 1 28 0 mov.u32 %r57,-1; bra $L1; $L3: mov.u64 %r56,%r59; add.u64 %r54,%r56,%r60; cvta.const.u64 %r72,$LC0; $L6: .loc 1 31 0 ld.s8 %r67,[%r56]; st.u32 [%stack],%r67; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r72; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%stack; call (%value_in),printf,(%out_arg1,%out_arg2); ld.param.u32 %r68,[%value_in]; } add.u64 %r56,%r56,1; .loc 1 30 0 setp.ne.u64 %r70,%r54,%r56; @ %r70 bra $L6; $L4: .loc 1 32 0 cvt.u32.u64 %r57,%r60; $L1: .loc 1 33 0 mov.u32 %value,%r57; st.param.u32 [%value_out],%value; ret; } 07070100000071000081a40000000000000000000000026181424500000000000000000000000000000000000000000000002200000000./usr/nvptx-none/lib/mgomp/libc.a07070100000071000081a40000000000000000000000026181424500115964000000000000000000000000000000000000002200000000./usr/nvptx-none/lib/mgomp/libg.a! // 958 ` lib_a-dtoastub.o/ lib_a-fix_grouping.o/ lib_a-gdtoa-gethex.o/ lib_a-gdtoa-hexnan.o/ lib_a-isxdigit.o/ lib_a-lmessages.o/ lib_a-lmonetary.o/ lib_a-lnumeric.o/ lib_a-nl_langinfo.o/ lib_a-rawmemchr.o/ lib_a-reallocr.o/ lib_a-s_copysign.o/ lib_a-s_finite.o/ lib_a-s_fpclassify.o/ lib_a-s_infconst.o/ lib_a-s_isinfd.o/ lib_a-s_isnand.o/ lib_a-s_scalbn.o/ lib_a-sf_copysign.o/ lib_a-sf_finite.o/ lib_a-sf_fpclassify.o/ lib_a-sf_frexp.o/ lib_a-sf_isinf.o/ lib_a-sf_isinff.o/ lib_a-sf_isnan.o/ lib_a-sf_isnanf.o/ lib_a-sf_ldexp.o/ lib_a-sf_scalbn.o/ lib_a-siprintf.o/ lib_a-snprintf.o/ lib_a-strcasecmp.o/ lib_a-strcasestr.o/ lib_a-strchrnul.o/ lib_a-strdup_r.o/ lib_a-strerror.o/ lib_a-strerror_r.o/ lib_a-strncasecmp.o/ lib_a-strndup_r.o/ lib_a-strsignal.o/ lib_a-strtok_r.o/ lib_a-strtoll_r.o/ lib_a-strtoull.o/ lib_a-strtoull_r.o/ lib_a-svfiprintf.o/ lib_a-svfprintf.o/ lib_a-timelocal.o/ lib_a-u_strerr.o/ lib_a-vfprintf.o/ lib_a-vsnprintf.o/ lib_a-vsprintf.o/ lib_a-a64l.o/ 0 0 0 644 2582 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: a64l .visible .func (.param .u64 %value_out) a64l (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/a64l.c" // BEGIN GLOBAL FUNCTION DEF: a64l .visible .func (.param .u64 %value_out) a64l (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r54; .reg .u64 %r57; .reg .u64 %r58; .reg .u32 %r59; .reg .u64 %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .pred %r67; .reg .u16 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .u16 %r73; .reg .pred %r74; .reg .pred %r76; .reg .pred %r78; .reg .pred %r80; .reg .pred %r82; .reg .u16 %r83; .reg .pred %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .u64 %r92; .reg .pred %r93; .reg .u64 %r95; .reg .u16 %r96; .reg .u64 %r97; mov.u64 %r66,%ar0; .loc 1 75 0 setp.eq.u64 %r67,%r66,0; @ %r67 bra $L14; mov.u64 %r57,%r66; mov.u32 %r64,6; $L4: .loc 1 84 0 ld.s8 %r69,[%r57]; cvt.u16.u32 %r68,%r69; setp.eq.u16 %r70,%r68,0; @ %r70 bra $L3; .loc 1 85 0 add.u64 %r57,%r57,1; $L3: add.u32 %r64,%r64,-1; .loc 1 82 0 setp.ne.u32 %r71,%r64,0; @ %r71 bra $L4; .loc 1 88 0 setp.le.u64 %r72,%r57,%r66; @ %r72 bra $L15; .loc 1 73 0 mov.u64 %r58,0; .loc 1 104 0 mov.u64 %r95,%r58; mov.u16 %r96,25; mov.u64 %r97,1; $L12: .loc 1 90 0 add.u64 %r57,%r57,-1; ld.s8 %r59,[%r57]; .loc 1 104 0 cvt.u16.u32 %r73,%r59; setp.gt.s16 %r74,%r73,90; @ %r74 bra $L7; setp.ge.s16 %r76,%r73,65; @ %r76 bra $L8; setp.eq.u16 %r78,%r73,47; @ %r78 bra $L9; setp.lt.s16 %r80,%r73,47; @ %r80 bra $L16; setp.gt.s16 %r82,%r73,57; @ ! %r82 bra $L22; bra $L16; $L7: add.u16 %r83,%r73,-97; setp.gt.u16 %r87,%r83,%r96; @ ! %r87 bra $L23; bra $L16; $L9: mov.u64 %r63,%r97; bra $L6; $L22: .loc 1 119 0 add.u32 %r88,%r59,-46; cvt.s64.s32 %r63,%r88; .loc 1 120 0 bra $L6; $L8: .loc 1 147 0 add.u32 %r89,%r59,-53; cvt.s64.s32 %r63,%r89; .loc 1 148 0 bra $L6; $L23: .loc 1 175 0 add.u32 %r90,%r59,-59; cvt.s64.s32 %r63,%r90; .loc 1 176 0 bra $L6; $L16: .loc 1 104 0 mov.u64 %r63,%r95; $L6: .loc 1 183 0 shl.b64 %r54,%r58,6; add.u64 %r58,%r54,%r63; .loc 1 88 0 setp.ne.u64 %r91,%r66,%r57; @ %r91 bra $L12; .loc 1 188 0 and.b64 %r92,%r58,2147483648; setp.ne.u64 %r93,%r92,0; @ %r93 bra $L13; mov.u64 %r65,%r58; bra $L1; $L13: .loc 1 189 0 add.u64 %r65,%r58,-4294967296; bra $L1; $L15: .loc 1 88 0 mov.u64 %r65,0; .loc 1 192 0 bra $L1; $L14: .loc 1 76 0 mov.u64 %r65,%r66; $L1: .loc 1 193 0 mov.u64 %value,%r65; st.param.u64 [%value_out],%value; ret; } lib_a-abort.o/ 0 0 0 644 381 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: abort .visible .func abort; .file 1 "../../../../../../../newlib/libc/machine/nvptx/abort.c" // BEGIN GLOBAL FUNCTION DEF: abort .visible .func abort { $L2: .loc 1 24 0 // #APP // 24 "../../../../../../../newlib/libc/machine/nvptx/abort.c" 1 exit; // #NO_APP bra $L2; } lib_a-abs.o/ 0 0 0 644 519 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: abs .visible .func (.param .u32 %value_out) abs (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/abs.c" // BEGIN GLOBAL FUNCTION DEF: abs .visible .func (.param .u32 %value_out) abs (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r23; mov.u32 %r23,%ar0; .loc 1 42 0 abs.s32 %value,%r23; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-assert.o/ 0 0 0 644 1185 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __assert_func .visible .func __assert_func (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdlib/assert.c" // BEGIN GLOBAL FUNCTION DECL: __assert .visible .func __assert (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: abort .extern .func abort; // BEGIN GLOBAL FUNCTION DEF: __assert_func .visible .func __assert_func (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .loc 1 65 0 { call abort; trap; // (noreturn) } } // BEGIN GLOBAL FUNCTION DEF: __assert .visible .func __assert (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .loc 1 65 0 { call abort; trap; // (noreturn) } } lib_a-atof.o/ 0 0 0 644 913 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atof .visible .func (.param .f64 %value_out) atof (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/atof.c" // BEGIN GLOBAL FUNCTION DECL: strtod .extern .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atof .visible .func (.param .f64 %value_out) atof (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .f64 %r26; mov.u64 %r23,%ar0; .loc 1 71 0 mov.u64 %r25,0; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),strtod,(%out_arg1,%out_arg2); ld.param.f64 %r26,[%value_in]; } .loc 1 72 0 mov.f64 %value,%r26; st.param.f64 [%value_out],%value; ret; } lib_a-atoff.o/ 0 0 0 644 916 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atoff .visible .func (.param .f32 %value_out) atoff (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/atoff.c" // BEGIN GLOBAL FUNCTION DECL: strtof .extern .func (.param .f32 %value_out) strtof (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: atoff .visible .func (.param .f32 %value_out) atoff (.param .u64 %in_ar0) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .f32 %r26; mov.u64 %r23,%ar0; .loc 1 8 0 mov.u64 %r25,0; { .param .f32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),strtof,(%out_arg1,%out_arg2); ld.param.f32 %r26,[%value_in]; } .loc 1 9 0 mov.f32 %value,%r26; st.param.f32 [%value_out],%value; ret; } lib_a-atoi.o/ 0 0 0 644 2166 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atoi .visible .func (.param .u32 %value_out) atoi (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/atoi.c" // BEGIN GLOBAL FUNCTION DECL: _atoi_r .visible .func (.param .u32 %value_out) _atoi_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtol .extern .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _strtol_r .extern .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: atoi .visible .func (.param .u32 %value_out) atoi (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r26; .reg .u32 %r27; .reg .u64 %r28; mov.u64 %r24,%ar0; .loc 1 70 0 mov.u32 %r27,10; mov.u64 %r26,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r27; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r28,[%value_in]; } .loc 1 71 0 cvt.u32.u64 %value,%r28; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _atoi_r .visible .func (.param .u32 %value_out) _atoi_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r28; .reg .u32 %r29; .reg .u64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 79 0 mov.u32 %r29,10; mov.u64 %r28,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r29; call (%value_in),_strtol_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 80 0 cvt.u32.u64 %value,%r30; st.param.u32 [%value_out],%value; ret; } lib_a-atol.o/ 0 0 0 644 2158 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atol .visible .func (.param .u64 %value_out) atol (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/atol.c" // BEGIN GLOBAL FUNCTION DECL: _atol_r .visible .func (.param .u64 %value_out) _atol_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtol .extern .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _strtol_r .extern .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: atol .visible .func (.param .u64 %value_out) atol (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r27; mov.u64 %r23,%ar0; .loc 1 12 0 mov.u32 %r26,10; mov.u64 %r25,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r26; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r27,[%value_in]; } .loc 1 13 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _atol_r .visible .func (.param .u64 %value_out) _atol_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r27; .reg .u32 %r28; .reg .u64 %r29; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 19 0 mov.u32 %r28,10; mov.u64 %r27,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r28; call (%value_in),_strtol_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r29,[%value_in]; } .loc 1 20 0 mov.u64 %value,%r29; st.param.u64 [%value_out],%value; ret; } lib_a-atoll.o/ 0 0 0 644 2173 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: atoll .visible .func (.param .u64 %value_out) atoll (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/atoll.c" // BEGIN GLOBAL FUNCTION DECL: _atoll_r .visible .func (.param .u64 %value_out) _atoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtoll .extern .func (.param .u64 %value_out) strtoll (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _strtoll_r .extern .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: atoll .visible .func (.param .u64 %value_out) atoll (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r27; mov.u64 %r23,%ar0; .loc 1 84 0 mov.u32 %r26,10; mov.u64 %r25,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r26; call (%value_in),strtoll,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r27,[%value_in]; } .loc 1 85 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _atoll_r .visible .func (.param .u64 %value_out) _atoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r27; .reg .u32 %r28; .reg .u64 %r29; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 93 0 mov.u32 %r28,10; mov.u64 %r27,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r28; call (%value_in),_strtoll_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r29,[%value_in]; } .loc 1 94 0 mov.u64 %value,%r29; st.param.u64 [%value_out],%value; ret; } lib_a-bcmp.o/ 0 0 0 644 1210 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: bcmp .visible .func (.param .u32 %value_out) bcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/bcmp.c" // BEGIN GLOBAL FUNCTION DECL: memcmp .extern .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: bcmp .visible .func (.param .u32 %value_out) bcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r29; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 48 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r29,[%value_in]; } .loc 1 49 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } lib_a-bcopy.o/ 0 0 0 644 1095 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: bcopy .visible .func bcopy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/bcopy.c" // BEGIN GLOBAL FUNCTION DECL: memmove .extern .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: bcopy .visible .func bcopy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r28; mov.u64 %r22,%ar0; mov.u64 %r23,%ar1; mov.u64 %r24,%ar2; .loc 1 38 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r22; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r24; call (%value_in),memmove,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r28,[%value_in]; } .loc 1 39 0 ret; } lib_a-btowc.o/ 0 0 0 644 3101 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: btowc .visible .func (.param .u32 %value_out) btowc (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/btowc.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __mbtowc .extern .global .align 8 .u64 __mbtowc[1]; // BEGIN GLOBAL FUNCTION DECL: memset .extern .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __locale_charset .extern .func (.param .u64 %value_out) __locale_charset; // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: btowc .visible .func (.param .u32 %value_out) btowc (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r23; .reg .u32 %r29; .reg .u32 %r30; .reg .pred %r31; .reg .u32 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .pred %r47; mov.u32 %r30,%ar0; .loc 1 16 0 setp.ne.u32 %r31,%r30,-1; @ %r31 bra $L2; $L4: .loc 1 17 0 mov.u32 %r29,-1; bra $L1; $L2: .loc 1 19 0 st.u8 [%frame+12],%r30; .loc 1 22 0 mov.u64 %r34,8; mov.u32 %r33,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r34; call (%value_in),memset,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r35,[%value_in]; } .loc 1 26 0 ld.global.u64 %r23,[__mbtowc]; .loc 1 27 0 { .param .u64 %value_in; call (%value_in),__locale_charset; ld.param.u64 %r36,[%value_in]; } .loc 1 26 0 add.u64 %r43,%frame,12; add.u64 %r44,%frame,8; ld.global.u64 %r45,[_impure_ptr]; mov.u64 %r40,1; { .param .u32 %value_in; $LCT0: .callprototype ( .param .u32 %value_out) _ ( .param .u64 %in_ar0,.param .u64 %in_ar1,.param .u64 %in_ar2,.param .u64 %in_ar3,.param .u64 %in_ar4,.param .u64 %in_ar5); .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r45; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r44; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r43; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r40; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r36; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%frame; call (%value_in),%r23,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6),$LCT0; ld.param.u32 %r46,[%value_in]; } .loc 1 29 0 setp.gt.u32 %r47,%r46,1; @ %r47 bra $L4; .loc 1 32 0 ld.u32 %r29,[%frame+8]; $L1: .loc 1 33 0 mov.u32 %value,%r29; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-bzero.o/ 0 0 0 644 828 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: bzero .visible .func bzero (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/bzero.c" // BEGIN GLOBAL FUNCTION DEF: bzero .visible .func bzero (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r52; .reg .u64 %r53; .reg .pred %r54; .reg .u32 %r55; .reg .pred %r56; mov.u64 %r52,%ar0; mov.u64 %r53,%ar1; .loc 1 41 0 setp.eq.u64 %r54,%r53,0; @ %r54 bra $L1; mov.u64 %r49,%r52; add.u64 %r50,%r49,%r53; .loc 1 42 0 mov.u32 %r55,0; $L3: st.u8 [%r49],%r55; add.u64 %r49,%r49,1; .loc 1 41 0 setp.ne.u64 %r56,%r49,%r50; @ %r56 bra $L3; $L1: .loc 1 43 0 ret; } lib_a-calloc.o/ 0 0 0 644 1620 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: calloc .visible .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../../newlib/libc/machine/nvptx/calloc.c" // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: memset .extern .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: calloc .visible .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r27; .reg .u64 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .u64 %r33; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 22 0 mul.lo.u64 %r27,%r24,%r25; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r28,[%value_in]; } mov.u64 %r23,%r28; .loc 1 23 0 setp.eq.u64 %r29,%r23,0; @ %r29 bra $L1; .loc 1 25 0 mov.u32 %r31,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r31; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),memset,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r33,[%value_in]; } mov.u64 %r23,%r33; $L1: .loc 1 26 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-callocr.o/0 0 0 644 1123 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _calloc_r .visible .func (.param .u64 %value_out) _calloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../../newlib/libc/machine/nvptx/callocr.c" // BEGIN GLOBAL FUNCTION DECL: calloc .extern .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _calloc_r .visible .func (.param .u64 %value_out) _calloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r28; mov.u64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 21 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; call (%value_in),calloc,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } .loc 1 22 0 mov.u64 %value,%r28; st.param.u64 [%value_out],%value; ret; } lib_a-ctype_.o/ 0 0 0 644 1783 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN VAR DEF: _ctype_b .const .align 1 .u8 _ctype_b[384] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,32,32,32,32,32,32,32,32,32,40,40,40,40,40,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,136,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,4,4,4,4,4,4,4,4,4,4,16,16,16,16,16,16,16,65,65,65,65,65,65,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,16,16,16,16,16,16,66,66,66,66,66,66,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,16,16,16,16,32,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: _ctype_ .visible .const .align 1 .u8 _ctype_[257] = {0,32,32,32,32,32,32,32,32,32,40,40,40,40,40,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,136,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,4,4,4,4,4,4,4,4,4,4,16,16,16,16,16,16,16,65,65,65,65,65,65,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,16,16,16,16,16,16,66,66,66,66,66,66,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,16,16,16,16,32,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // BEGIN GLOBAL VAR DEF: __ctype_ptr__ .visible .global .align 8 .u64 __ctype_ptr__[1] = {generic(_ctype_b) + 127 }; lib_a-div.o/ 0 0 0 644 1150 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: div .visible .func div (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libc/stdlib/div.c" // BEGIN GLOBAL FUNCTION DEF: div .visible .func div (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r22; .reg .u32 %r23; .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 95 0 div.s32 %r22,%r25,%r26; .loc 1 96 0 rem.s32 %r23,%r25,%r26; .loc 1 123 0 setp.lt.s32 %r27,%r25,0; @ %r27 bra $L2; setp.ge.s32 %r28,%r23,0; @ %r28 bra $L3; .loc 1 124 0 add.u32 %r22,%r22,1; .loc 1 125 0 sub.u32 %r23,%r23,%r26; bra $L3; $L2: .loc 1 127 0 setp.le.s32 %r29,%r23,0; @ %r29 bra $L3; .loc 1 128 0 add.u32 %r22,%r22,-1; .loc 1 129 0 add.u32 %r23,%r23,%r26; $L3: .loc 1 131 0 st.u32 [%r24],%r22; st.u32 [%r24+4],%r23; .loc 1 132 0 ret; } lib_a-drand48.o/0 0 0 644 1657 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _drand48_r .visible .func (.param .f64 %value_out) _drand48_r (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/drand48.c" // BEGIN GLOBAL FUNCTION DECL: drand48 .visible .func (.param .f64 %value_out) drand48; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _erand48_r .extern .func (.param .f64 %value_out) _erand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _drand48_r .visible .func (.param .f64 %value_out) _drand48_r (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r27; .reg .f64 %r28; mov.u64 %r24,%ar0; .loc 1 21 0 add.u64 %r27,%r24,240; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; call (%value_in),_erand48_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } .loc 1 22 0 mov.f64 %value,%r28; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: drand48 .visible .func (.param .f64 %value_out) drand48 { .reg .f64 %value; .reg .u64 %r22; .reg .u64 %r27; .reg .f64 %r28; .loc 1 28 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 21 0 add.u64 %r27,%r22,240; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r22; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; call (%value_in),_erand48_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } .loc 1 29 0 mov.f64 %value,%r28; st.param.f64 [%value_out],%value; ret; } lib_a-dtoa.o/ 0 0 0 644 59312 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: quorem .func (.param .u32 %value_out) quorem (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/dtoa.c" // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .visible .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL VAR DECL: __mprec_bigtens .extern .const .align 8 .u64 __mprec_bigtens[5]; // BEGIN GLOBAL VAR DECL: __mprec_tens .extern .const .align 8 .u64 __mprec_tens[25]; // BEGIN GLOBAL FUNCTION DECL: __mcmp .extern .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __d2b .extern .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __i2b .extern .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __pow5mult .extern .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __multiply .extern .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __hi0bits .extern .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __lshift .extern .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __multadd .extern .func (.param .u64 %value_out) __multadd (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mdiff .extern .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[9] = {73,110,102,105,110,105,116,121,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {78,97,78,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[2] = {48,0 }; // BEGIN FUNCTION DEF: quorem .func (.param .u32 %value_out) quorem (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r57; .reg .u32 %r66; .reg .u32 %r85; .reg .u32 %r102; .reg .u32 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u32 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .u32 %r117; .reg .u64 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u32 %r125; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r136; .reg .u64 %r137; .reg .u32 %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .pred %r142; .reg .u64 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .u32 %r146; .reg .pred %r147; .reg .u32 %r148; .reg .u32 %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .u32 %r162; .reg .pred %r163; .reg .u32 %r164; .reg .pred %r165; .reg .pred %r166; .reg .u32 %r167; .reg .pred %r168; .reg .pred %r169; .reg .u32 %r170; .reg .pred %r171; .reg .u32 %r174; .reg .pred %r175; .reg .u32 %r176; .reg .u32 %r177; .reg .u32 %r178; .reg .u32 %r179; .reg .u32 %r180; .reg .u32 %r181; .reg .u32 %r182; .reg .u32 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .pred %r186; .reg .u64 %r187; .reg .u64 %r188; .reg .u32 %r189; .reg .pred %r190; .reg .pred %r191; .reg .u32 %r192; .reg .pred %r193; .reg .pred %r194; .reg .u32 %r195; .reg .pred %r196; mov.u64 %r139,%ar0; mov.u64 %r140,%ar1; .loc 1 49 0 ld.u32 %r107,[%r140+20]; .loc 1 54 0 ld.u32 %r141,[%r139+20]; setp.lt.s32 %r142,%r141,%r107; @ %r142 bra $L11; .loc 1 56 0 add.u64 %r108,%r140,24; .loc 1 57 0 add.u32 %r125,%r107,-1; cvt.s64.s32 %r143,%r125; shl.b64 %r57,%r143,2; add.u64 %r109,%r108,%r57; .loc 1 58 0 add.u64 %r110,%r139,24; .loc 1 59 0 add.u64 %r111,%r110,%r57; .loc 1 60 0 ld.u32 %r145,[%r109]; add.u32 %r144,%r145,1; ld.u32 %r146,[%r111]; div.u32 %r105,%r146,%r144; .loc 1 65 0 setp.eq.u32 %r147,%r105,0; @ %r147 bra $L3; mov.u64 %r132,%r110; mov.u64 %r131,%r108; .loc 1 68 0 mov.u32 %r104,0; .loc 1 67 0 mov.u32 %r102,%r104; $L4: .loc 1 72 0 ld.u32 %r112,[%r131]; .loc 1 73 0 and.b32 %r148,%r112,65535; mad.lo.u32 %r113,%r148,%r105,%r104; .loc 1 74 0 shr.u32 %r150,%r112,16; shr.u32 %r152,%r113,16; mad.lo.u32 %r114,%r150,%r105,%r152; .loc 1 75 0 shr.u32 %r104,%r114,16; .loc 1 76 0 ld.u32 %r66,[%r132]; and.b32 %r153,%r66,65535; add.u32 %r154,%r153,%r102; and.b32 %r155,%r113,65535; sub.u32 %r115,%r154,%r155; .loc 1 79 0 shr.u32 %r156,%r66,16; and.b32 %r157,%r114,65535; sub.u32 %r158,%r156,%r157; .loc 1 77 0 shr.s32 %r159,%r115,16; .loc 1 79 0 add.u32 %r117,%r158,%r159; .loc 1 80 0 shr.s32 %r102,%r117,16; .loc 1 82 0 shl.b32 %r160,%r117,16; and.b32 %r161,%r115,65535; or.b32 %r162,%r160,%r161; st.u32 [%r132],%r162; add.u64 %r132,%r132,4; add.u64 %r131,%r131,4; .loc 1 92 0 setp.ge.u64 %r163,%r109,%r131; @ %r163 bra $L4; .loc 1 93 0 ld.u32 %r164,[%r111]; setp.ne.u32 %r165,%r164,0; @ %r165 bra $L3; .loc 1 96 0 add.u64 %r118,%r111,-4; setp.ge.u64 %r166,%r110,%r118; @ %r166 bra $L5; ld.u32 %r167,[%r111+-4]; setp.ne.u32 %r168,%r167,0; @ %r168 bra $L5; $L6: .loc 1 97 0 add.u32 %r125,%r125,-1; .loc 1 96 0 add.u64 %r118,%r118,-4; setp.ge.u64 %r169,%r110,%r118; @ %r169 bra $L5; ld.u32 %r170,[%r118]; setp.eq.u32 %r171,%r170,0; @ %r171 bra $L6; $L5: .loc 1 98 0 st.u32 [%r139+20],%r125; $L3: .loc 1 101 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r139; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r140; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r174,[%value_in]; } setp.lt.s32 %r175,%r174,0; @ %r175 bra $L7; .loc 1 103 0 add.u32 %r105,%r105,1; mov.u64 %r137,%r110; mov.u64 %r136,%r108; .loc 1 104 0 mov.u32 %r103,0; $L8: .loc 1 111 0 ld.u32 %r119,[%r136]; .loc 1 115 0 ld.u32 %r85,[%r137]; and.b32 %r176,%r85,65535; add.u32 %r177,%r176,%r103; .loc 1 112 0 and.b32 %r178,%r119,65535; .loc 1 115 0 sub.u32 %r120,%r177,%r178; .loc 1 118 0 shr.u32 %r179,%r85,16; .loc 1 113 0 shr.u32 %r180,%r119,16; .loc 1 118 0 sub.u32 %r181,%r179,%r180; .loc 1 116 0 shr.s32 %r182,%r120,16; .loc 1 118 0 add.u32 %r122,%r181,%r182; .loc 1 119 0 shr.s32 %r103,%r122,16; .loc 1 121 0 shl.b32 %r183,%r122,16; and.b32 %r184,%r120,65535; or.b32 %r185,%r183,%r184; st.u32 [%r137],%r185; add.u64 %r137,%r137,4; add.u64 %r136,%r136,4; .loc 1 131 0 setp.ge.u64 %r186,%r109,%r136; @ %r186 bra $L8; .loc 1 133 0 cvt.s64.s32 %r187,%r125; shl.b64 %r188,%r187,2; add.u64 %r123,%r110,%r188; .loc 1 134 0 ld.u32 %r189,[%r123]; setp.ne.u32 %r190,%r189,0; @ %r190 bra $L7; .loc 1 136 0 add.u64 %r124,%r123,-4; setp.ge.u64 %r191,%r110,%r124; @ %r191 bra $L9; ld.u32 %r192,[%r123+-4]; setp.ne.u32 %r193,%r192,0; @ %r193 bra $L9; $L10: .loc 1 137 0 add.u32 %r125,%r125,-1; .loc 1 136 0 add.u64 %r124,%r124,-4; setp.ge.u64 %r194,%r110,%r124; @ %r194 bra $L9; ld.u32 %r195,[%r124]; setp.eq.u32 %r196,%r195,0; @ %r196 bra $L10; $L9: .loc 1 138 0 st.u32 [%r139+20],%r125; $L7: .loc 1 141 0 mov.u32 %r138,%r105; bra $L1; $L11: .loc 1 55 0 mov.u32 %r138,0; $L1: .loc 1 142 0 mov.u32 %value,%r138; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _dtoa_r .visible .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u64 %ar6; ld.param.u64 %ar6,[%in_ar6]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r178; .reg .u32 %r179; .reg .u32 %r186; .reg .u32 %r191; .reg .f64 %r197; .reg .u64 %r204; .reg .u32 %r209; .reg .u32 %r211; .reg .u64 %r214; .reg .f64 %r215; .reg .f64 %r220; .reg .u64 %r229; .reg .f64 %r230; .reg .f64 %r232; .reg .f64 %r233; .reg .f64 %r236; .reg .f64 %r241; .reg .f64 %r242; .reg .f64 %r243; .reg .f64 %r245; .reg .f64 %r250; .reg .u32 %r252; .reg .f64 %r253; .reg .u32 %r254; .reg .u64 %r262; .reg .f64 %r263; .reg .f64 %r267; .reg .u32 %r287; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .u32 %r323; .reg .u32 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r327; .reg .u32 %r328; .reg .u32 %r330; .reg .u32 %r332; .reg .u32 %r333; .reg .u32 %r334; .reg .u32 %r335; .reg .u32 %r336; .reg .u32 %r337; .reg .u32 %r338; .reg .u32 %r339; .reg .u32 %r340; .reg .u64 %r342; .reg .u64 %r343; .reg .u64 %r344; .reg .f64 %r345; .reg .f64 %r346; .reg .u64 %r347; .reg .u64 %r349; .reg .u64 %r350; .reg .u32 %r351; .reg .u32 %r352; .reg .u32 %r353; .reg .u32 %r355; .reg .u64 %r356; .reg .u32 %r357; .reg .f64 %r358; .reg .u32 %r359; .reg .u32 %r363; .reg .u32 %r364; .reg .u32 %r366; .reg .u32 %r368; .reg .u64 %r369; .reg .u32 %r370; .reg .f64 %r371; .reg .u32 %r372; .reg .u32 %r373; .reg .u32 %r375; .reg .u32 %r376; .reg .u32 %r377; .reg .u64 %r379; .reg .u32 %r380; .reg .u32 %r381; .reg .u32 %r382; .reg .u32 %r391; .reg .u64 %r393; .reg .u64 %r395; .reg .u64 %r396; .reg .u64 %r398; .reg .u64 %r402; .reg .u64 %r403; .reg .u64 %r409; .reg .u64 %r412; .reg .u64 %r417; .reg .u64 %r421; .reg .u64 %r424; .reg .u64 %r425; .reg .u64 %r431; .reg .f64 %r436; .reg .f64 %r440; .reg .u64 %r446; .reg .u32 %r448; .reg .u64 %r449; .reg .u32 %r451; .reg .u64 %r452; .reg .u32 %r454; .reg .u32 %r455; .reg .u32 %r456; .reg .u32 %r457; .reg .u32 %r459; .reg .u32 %r460; .reg .u32 %r461; .reg .f64 %r465; .reg .u32 %r466; .reg .f64 %r468; .reg .f64 %r470; .reg .u32 %r475; .reg .u32 %r476; .reg .u64 %r481; .reg .u64 %r482; .reg .u64 %r483; .reg .u64 %r484; .reg .u64 %r485; .reg .f64 %r486; .reg .u32 %r487; .reg .u32 %r488; .reg .u64 %r489; .reg .u64 %r490; .reg .u64 %r491; .reg .pred %r492; .reg .u32 %r493; .reg .u32 %r494; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r499; .reg .pred %r500; .reg .u32 %r501; .reg .u64 %r502; .reg .u64 %r503; .reg .u64 %r504; .reg .u32 %r506; .reg .u32 %r507; .reg .pred %r508; .reg .u32 %r509; .reg .u64 %r510; .reg .u64 %r511; .reg .pred %r512; .reg .pred %r513; .reg .u32 %r514; .reg .pred %r515; .reg .u64 %r516; .reg .u64 %r521; .reg .u64 %r522; .reg .pred %r523; .reg .u64 %r525; .reg .u32 %r526; .reg .u32 %r527; .reg .u32 %r528; .reg .u64 %r529; .reg .u64 %r530; .reg .u64 %r531; .reg .u32 %r533; .reg .pred %r534; .reg .u32 %r535; .reg .u32 %r536; .reg .u32 %r537; .reg .u32 %r538; .reg .u32 %r539; .reg .u32 %r540; .reg .u32 %r541; .reg .u64 %r543; .reg .u32 %r544; .reg .u32 %r545; .reg .u64 %r546; .reg .u64 %r547; .reg .u64 %r548; .reg .f64 %r550; .reg .f64 %r551; .reg .f64 %r552; .reg .f64 %r553; .reg .f64 %r554; .reg .pred %r555; .reg .f64 %r556; .reg .pred %r557; .reg .pred %r558; .reg .u64 %r559; .reg .u64 %r560; .reg .u64 %r561; .reg .u64 %r562; .reg .f64 %r563; .reg .f64 %r564; .reg .pred %r565; .reg .pred %r566; .reg .u32 %r567; .reg .pred %r568; .reg .pred %r569; .reg .pred %r570; .reg .pred %r571; .reg .u32 %r572; .reg .u32 %r574; .reg .u32 %r575; .reg .u16 %r576; .reg .u16 %r577; .reg .u16 %r578; .reg .u32 %r579; .reg .pred %r580; .reg .u64 %r582; .reg .u64 %r583; .reg .pred %r584; .reg .u64 %r587; .reg .pred %r588; .reg .pred %r589; .reg .u64 %r590; .reg .u32 %r591; .reg .u64 %r592; .reg .u64 %r593; .reg .u64 %r594; .reg .u32 %r595; .reg .pred %r596; .reg .u64 %r597; .reg .f64 %r598; .reg .u32 %r599; .reg .pred %r600; .reg .f64 %r601; .reg .pred %r602; .reg .pred %r603; .reg .pred %r604; .reg .u64 %r605; .reg .u32 %r606; .reg .u64 %r607; .reg .u64 %r608; .reg .u64 %r609; .reg .f64 %r610; .reg .pred %r611; .reg .u32 %r612; .reg .pred %r613; .reg .f64 %r614; .reg .pred %r615; .reg .pred %r616; .reg .pred %r617; .reg .pred %r618; .reg .pred %r619; .reg .pred %r620; .reg .u32 %r621; .reg .f64 %r622; .reg .u64 %r624; .reg .u32 %r625; .reg .u32 %r626; .reg .u64 %r627; .reg .u64 %r628; .reg .u64 %r629; .reg .f64 %r631; .reg .u64 %r633; .reg .u32 %r634; .reg .u32 %r635; .reg .u64 %r636; .reg .u64 %r637; .reg .u64 %r638; .reg .pred %r640; .reg .f64 %r641; .reg .pred %r642; .reg .f64 %r643; .reg .pred %r644; .reg .u64 %r645; .reg .u32 %r646; .reg .u64 %r647; .reg .u64 %r648; .reg .u64 %r649; .reg .f64 %r650; .reg .u16 %r652; .reg .u16 %r653; .reg .u32 %r654; .reg .pred %r655; .reg .f64 %r656; .reg .f64 %r657; .reg .pred %r659; .reg .f64 %r660; .reg .f64 %r661; .reg .pred %r662; .reg .pred %r663; .reg .u64 %r664; .reg .u32 %r665; .reg .u64 %r666; .reg .f64 %r667; .reg .pred %r669; .reg .pred %r670; .reg .f64 %r671; .reg .u16 %r673; .reg .u16 %r674; .reg .u32 %r675; .reg .pred %r677; .reg .pred %r679; .reg .f64 %r680; .reg .pred %r681; .reg .f64 %r682; .reg .f64 %r683; .reg .pred %r684; .reg .u16 %r685; .reg .pred %r686; .reg .u32 %r687; .reg .u64 %r688; .reg .f64 %r689; .reg .u16 %r691; .reg .u16 %r692; .reg .u32 %r693; .reg .pred %r694; .reg .u64 %r695; .reg .u32 %r697; .reg .u32 %r698; .reg .u32 %r700; .reg .u32 %r701; .reg .u16 %r703; .reg .u16 %r704; .reg .u16 %r705; .reg .u32 %r706; .reg .u16 %r707; .reg .pred %r708; .reg .u64 %r709; .reg .u64 %r710; .reg .u64 %r711; .reg .u64 %r712; .reg .u32 %r714; .reg .u32 %r716; .reg .u32 %r717; .reg .u16 %r719; .reg .u16 %r720; .reg .u16 %r721; .reg .u32 %r722; .reg .u16 %r723; .reg .pred %r724; .reg .pred %r725; .reg .f64 %r726; .reg .f64 %r727; .reg .pred %r728; .reg .f64 %r729; .reg .f64 %r730; .reg .f64 %r731; .reg .u16 %r733; .reg .u16 %r734; .reg .u32 %r735; .reg .pred %r736; .reg .pred %r737; .reg .u32 %r738; .reg .u64 %r739; .reg .pred %r741; .reg .pred %r742; .reg .u32 %r743; .reg .pred %r744; .reg .pred %r745; .reg .u32 %r746; .reg .u16 %r747; .reg .pred %r748; .reg .u16 %r750; .reg .u16 %r751; .reg .u32 %r752; .reg .pred %r753; .reg .f64 %r754; .reg .f64 %r755; .reg .f64 %r756; .reg .u16 %r758; .reg .u16 %r759; .reg .u32 %r760; .reg .pred %r761; .reg .pred %r762; .reg .pred %r763; .reg .pred %r764; .reg .u32 %r765; .reg .u32 %r766; .reg .pred %r767; .reg .u32 %r768; .reg .pred %r769; .reg .u32 %r771; .reg .u64 %r772; .reg .u32 %r774; .reg .u32 %r775; .reg .u32 %r777; .reg .u32 %r778; .reg .u16 %r779; .reg .u16 %r780; .reg .u16 %r781; .reg .u32 %r782; .reg .u16 %r783; .reg .pred %r784; .reg .pred %r785; .reg .pred %r786; .reg .pred %r787; .reg .u64 %r791; .reg .u64 %r795; .reg .pred %r798; .reg .u64 %r802; .reg .u64 %r806; .reg .u32 %r808; .reg .u64 %r809; .reg .u64 %r814; .reg .pred %r815; .reg .u64 %r816; .reg .u32 %r817; .reg .u32 %r818; .reg .pred %r819; .reg .u32 %r821; .reg .u32 %r822; .reg .u32 %r823; .reg .u64 %r824; .reg .u64 %r825; .reg .u64 %r826; .reg .u64 %r827; .reg .u32 %r828; .reg .u32 %r829; .reg .u32 %r830; .reg .pred %r831; .reg .u32 %r832; .reg .pred %r833; .reg .u32 %r834; .reg .pred %r835; .reg .u32 %r836; .reg .pred %r837; .reg .u64 %r841; .reg .pred %r842; .reg .u64 %r846; .reg .u32 %r847; .reg .u32 %r848; .reg .u32 %r849; .reg .pred %r850; .reg .u32 %r853; .reg .pred %r854; .reg .u32 %r857; .reg .u32 %r858; .reg .u64 %r859; .reg .u32 %r861; .reg .u32 %r862; .reg .u16 %r863; .reg .u16 %r864; .reg .u16 %r865; .reg .u32 %r866; .reg .pred %r867; .reg .u64 %r872; .reg .pred %r873; .reg .u32 %r875; .reg .u32 %r876; .reg .u16 %r877; .reg .u16 %r878; .reg .u16 %r879; .reg .u32 %r880; .reg .u16 %r881; .reg .pred %r882; .reg .pred %r883; .reg .u32 %r886; .reg .u64 %r888; .reg .u32 %r891; .reg .pred %r892; .reg .u32 %r893; .reg .pred %r894; .reg .pred %r895; .reg .u64 %r899; .reg .pred %r900; .reg .u64 %r903; .reg .u64 %r907; .reg .u64 %r908; .reg .u64 %r909; .reg .u64 %r910; .reg .u64 %r911; .reg .u64 %r912; .reg .u32 %r915; .reg .u64 %r916; .reg .u32 %r917; .reg .u64 %r918; .reg .u32 %r921; .reg .u32 %r924; .reg .u64 %r928; .reg .u32 %r929; .reg .pred %r930; .reg .u32 %r933; .reg .u32 %r936; .reg .pred %r937; .reg .pred %r941; .reg .pred %r942; .reg .pred %r943; .reg .u32 %r944; .reg .pred %r945; .reg .pred %r949; .reg .u32 %r952; .reg .u64 %r953; .reg .u32 %r956; .reg .pred %r957; .reg .pred %r958; .reg .u32 %r959; .reg .pred %r960; .reg .pred %r961; .reg .pred %r962; .reg .pred %r963; .reg .u32 %r964; .reg .u16 %r966; .reg .u16 %r967; .reg .u32 %r968; .reg .pred %r969; .reg .u32 %r972; .reg .u32 %r973; .reg .u64 %r974; .reg .pred %r975; .reg .u64 %r980; .reg .u64 %r985; .reg .u64 %r990; .reg .u32 %r993; .reg .pred %r994; .reg .u32 %r997; .reg .u32 %r998; .reg .u64 %r999; .reg .u32 %r1002; .reg .u64 %r1003; .reg .u32 %r1006; .reg .pred %r1007; .reg .pred %r1008; .reg .u32 %r1009; .reg .pred %r1010; .reg .pred %r1011; .reg .u32 %r1012; .reg .u16 %r1013; .reg .pred %r1014; .reg .u16 %r1016; .reg .u32 %r1018; .reg .u16 %r1019; .reg .pred %r1020; .reg .pred %r1023; .reg .u32 %r1025; .reg .u32 %r1026; .reg .u32 %r1028; .reg .u32 %r1029; .reg .u16 %r1030; .reg .u16 %r1031; .reg .u16 %r1032; .reg .u32 %r1033; .reg .u16 %r1034; .reg .pred %r1035; .reg .u32 %r1042; .reg .u32 %r1043; .reg .pred %r1044; .reg .pred %r1046; .reg .pred %r1047; .reg .f64 %r1048; .reg .u64 %r1050; .reg .u32 %r1051; .reg .u32 %r1052; .reg .u64 %r1053; .reg .u64 %r1054; .reg .u64 %r1055; .reg .pred %r1057; .reg .pred %r1060; .reg .u32 %r1061; .reg .u64 %r1064; .reg .u32 %r1066; .reg .u32 %r1067; .reg .u32 %r1069; .reg .u32 %r1070; .reg .u16 %r1072; .reg .u16 %r1073; .reg .u16 %r1074; .reg .u32 %r1075; .reg .u16 %r1076; .reg .pred %r1077; .reg .pred %r1078; .reg .pred %r1079; .reg .pred %r1080; .reg .pred %r1081; .reg .pred %r1082; .reg .u32 %r1083; .reg .pred %r1084; .reg .u64 %r1085; .reg .pred %r1086; .reg .u64 %r1087; .reg .pred %r1088; .reg .u64 %r1089; .reg .u64 %r1090; .reg .pred %r1091; .reg .u32 %r1094; .reg .u32 %r1095; .reg .pred %r1096; .reg .f64 %r1097; mov.u64 %r485,%ar0; mov.f64 %r486,%ar1; mov.u32 %r487,%ar2; mov.u32 %r488,%ar3; mov.u64 %r489,%ar4; mov.u64 %r490,%ar5; mov.u64 %r491,%ar6; .loc 1 236 0 mov.b64 %r481,%r486; .loc 1 239 0 ld.u64 %r178,[%r485+96]; setp.eq.u64 %r492,%r178,0; @ %r492 bra $L22; .loc 1 241 0 ld.u32 %r179,[%r485+104]; st.u32 [%r178+8],%r179; .loc 1 242 0 mov.u32 %r494,1; shl.b32 %r493,%r494,%r179; st.u32 [%r178+12],%r493; .loc 1 243 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r178; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 244 0 mov.u64 %r497,0; st.u64 [%r485+96],%r497; $L22: mov.b64 %r498,%r486; shr.u64 %r499,%r498,32; cvt.u32.u64 %r359,%r499; .loc 1 247 0 setp.ge.s32 %r500,%r359,0; @ %r500 bra $L23; .loc 1 250 0 mov.u32 %r501,1; st.u32 [%r490],%r501; .loc 1 251 0 and.b32 %r359,%r359,2147483647; cvt.u64.u32 %r502,%r359; shl.b64 %r503,%r502,32; and.b64 %r504,%r481,4294967295; or.b64 %r481,%r504,%r503; mov.b64 %r486,%r481; bra $L24; $L23: .loc 1 254 0 mov.u32 %r506,0; st.u32 [%r490],%r506; $L24: .loc 1 258 0 and.b32 %r507,%r359,2146435072; setp.ne.u32 %r508,%r507,2146435072; @ %r508 bra $L25; .loc 1 264 0 mov.u32 %r509,9999; st.u32 [%r489],%r509; .loc 1 267 0 mov.b64 %r511,%r486; and.b64 %r510,%r511,4503599627370495; setp.eq.u64 %r512,%r510,0; @ %r512 bra $L26; bra $L264; $L189: cvta.const.u64 %r484,$LC0; .loc 1 273 0 add.u64 %r350,%r484,8; bra $L144; $L190: .loc 1 267 0 cvta.const.u64 %r484,$LC1; .loc 1 273 0 add.u64 %r350,%r484,3; $L144: .loc 1 271 0 st.u64 [%r491],%r350; bra $L21; $L25: .loc 1 282 0 setp.neu.f64 %r513,%r486,0d0000000000000000; @ %r513 bra $L29; .loc 1 284 0 mov.u32 %r514,1; st.u32 [%r489],%r514; .loc 1 286 0 setp.eq.u64 %r515,%r491,0; @ %r515 bra $L153; .loc 1 287 0 cvta.const.u64 %r516,$LC2+1; st.u64 [%r491],%r516; .loc 1 288 0 cvta.const.u64 %r484,$LC2; bra $L21; $L29: .loc 1 291 0 add.u64 %r521,%frame,4; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r486; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r521; call (%value_in),__d2b,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r522,[%value_in]; } mov.u64 %r449,%r522; .loc 1 295 0 shr.u32 %r186,%r359,20; setp.eq.u32 %r523,%r186,0; @ %r523 bra $L30; .loc 1 298 0 mov.b64 %r482,%r486; .loc 1 299 0 shr.u64 %r525,%r482,32; cvt.u32.u64 %r527,%r525; and.b32 %r526,%r527,1048575; .loc 1 300 0 or.b32 %r528,%r526,1072693248; cvt.u64.u32 %r529,%r528; shl.b64 %r530,%r529,32; and.b64 %r531,%r482,4294967295; or.b64 %r482,%r531,%r530; .loc 1 328 0 add.u32 %r323,%r186,-1023; ld.u32 %r454,[%frame+4]; .loc 1 334 0 mov.u32 %r340,0; bra $L31; $L30: .loc 1 340 0 ld.u32 %r454,[%frame+4]; ld.u32 %r533,[%frame]; add.u32 %r191,%r454,%r533; add.u32 %r357,%r191,1074; cvt.u32.u64 %r475,%r481; .loc 1 345 0 setp.le.s32 %r534,%r357,32; @ %r534 bra $L32; .loc 1 344 0 mov.u32 %r536,64; sub.u32 %r535,%r536,%r357; shl.b32 %r537,%r359,%r535; add.u32 %r538,%r191,1042; shr.u32 %r539,%r475,%r538; .loc 1 345 0 or.b32 %r351,%r537,%r539; bra $L33; $L32: mov.u32 %r541,32; sub.u32 %r540,%r541,%r357; shl.b32 %r351,%r475,%r540; $L33: .loc 1 347 0 cvt.rn.f64.u32 %r197,%r351; mov.b64 %r482,%r197; .loc 1 348 0 shr.u64 %r543,%r482,32; cvt.u32.u64 %r545,%r543; add.u32 %r544,%r545,-32505856; cvt.u64.u32 %r546,%r544; shl.b64 %r547,%r546,32; and.b64 %r548,%r482,4294967295; or.b64 %r482,%r548,%r547; .loc 1 349 0 add.u32 %r323,%r191,-1; .loc 1 350 0 mov.u32 %r340,1; $L31: .loc 1 356 0 cvt.rn.f64.s32 %r550,%r323; mov.b64 %r552,%r482; mov.f64 %r553,0d3ff8000000000000; sub.f64 %r551,%r552,%r553; fma.rn.f64 %r554,%r551,0d3fd287a7636f4361,0d3fc68a288b60c8b3; fma.rn.f64 %r358,%r550,0d3fd34413509f79fb,%r554; .loc 1 358 0 cvt.rzi.s32.f64 %r332,%r358; .loc 1 359 0 setp.lt.f64 %r555,%r358,0d0000000000000000; @ ! %r555 bra $L34; cvt.rn.f64.s32 %r556,%r332; setp.eq.f64 %r557,%r556,%r358; @ %r557 bra $L34; .loc 1 360 0 add.u32 %r332,%r332,-1; $L34: .loc 1 362 0 setp.gt.u32 %r558,%r332,22; @ %r558 bra $L154; .loc 1 364 0 cvta.const.u64 %r559,__mprec_tens; cvt.s64.s32 %r560,%r332; shl.b64 %r561,%r560,3; add.u64 %r562,%r559,%r561; ld.f64 %r563,[%r562]; mov.b64 %r564,%r481; setp.gt.f64 %r565,%r563,%r564; @ ! %r565 bra $L265; .loc 1 365 0 add.u32 %r332,%r332,-1; .loc 1 366 0 mov.u32 %r333,0; bra $L36; $L154: .loc 1 361 0 mov.u32 %r333,1; bra $L36; $L265: .loc 1 366 0 mov.u32 %r333,0; $L36: .loc 1 368 0 sub.u32 %r209,%r454,%r323; add.u32 %r337,%r209,-1; .loc 1 369 0 setp.ge.s32 %r566,%r337,0; @ %r566 bra $L156; .loc 1 376 0 mov.u32 %r567,1; sub.u32 %r320,%r567,%r209; .loc 1 377 0 mov.u32 %r337,0; bra $L38; $L156: .loc 1 371 0 mov.u32 %r320,0; $L38: .loc 1 379 0 setp.lt.s32 %r568,%r332,0; @ %r568 bra $L39; .loc 1 383 0 add.u32 %r337,%r337,%r332; mov.u32 %r338,%r332; .loc 1 381 0 mov.u32 %r321,0; bra $L40; $L39: .loc 1 387 0 sub.u32 %r320,%r320,%r332; .loc 1 388 0 neg.s32 %r321,%r332; .loc 1 389 0 mov.u32 %r338,0; $L40: .loc 1 391 0 setp.gt.u32 %r569,%r487,9; @ %r569 bra $L157; .loc 1 394 0 setp.le.s32 %r570,%r487,5; @ %r570 bra $L158; .loc 1 396 0 add.u32 %r487,%r487,-4; mov.u32 %r455,0; bra $L42; $L43: .loc 1 399 0 mov.u32 %r334,1; bra $L44; $L193: .loc 1 409 0 mov.u32 %r334,0; $L44: .loc 1 412 0 setp.le.s32 %r571,%r488,0; @ %r571 bra $L159; mov.u32 %r330,%r488; mov.u32 %r328,%r488; mov.u32 %r324,%r488; bra $L45; $L194: .loc 1 417 0 mov.u32 %r334,0; $L46: .loc 1 420 0 add.u32 %r330,%r332,%r488; add.u32 %r328,%r330,1; max.s32 %r324,%r328,1; $L45: .loc 1 427 0 mov.u32 %r572,0; st.u32 [%r485+104],%r572; cvt.s64.s32 %r446,%r324; set.u32.le.u32 %r574,%r328,14; neg.s32 %r575,%r574; cvt.u16.u32 %r577,%r575; cvt.u16.u32 %r578,%r455; and.b16 %r576,%r577,%r578; cvt.u32.u16 %r579,%r576; cvt.u32.u8 %r455,%r579; setp.le.s32 %r580,%r324,31; @ %r580 bra $L160; mov.u32 %r391,1; .loc 1 426 0 mov.u32 %r355,4; $L48: .loc 1 429 0 mov.u32 %r211,%r391; .loc 1 428 0 add.u32 %r355,%r355,%r355; add.u32 %r391,%r211,1; .loc 1 427 0 cvt.s64.s32 %r582,%r355; add.u64 %r583,%r582,28; setp.le.u64 %r584,%r583,%r446; @ %r584 bra $L48; st.u32 [%r485+104],%r211; bra $L47; $L160: mov.u32 %r211,%r572; $L47: .loc 1 430 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r211; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r587,[%value_in]; } mov.u64 %r214,%r587; st.u64 [%r485+96],%r587; .loc 1 433 0 setp.eq.u32 %r588,%r455,0; @ %r588 bra $L49; .loc 1 438 0 mov.b64 %r215,%r481; .loc 1 442 0 setp.le.s32 %r589,%r332,0; @ %r589 bra $L50; .loc 1 444 0 cvta.const.u64 %r590,__mprec_tens; and.b32 %r591,%r332,15; cvt.s64.s32 %r592,%r591; shl.b64 %r593,%r592,3; add.u64 %r594,%r590,%r593; ld.f64 %r345,[%r594]; .loc 1 445 0 shr.s32 %r366,%r332,4; .loc 1 446 0 and.b32 %r595,%r366,16; setp.eq.u32 %r596,%r595,0; @ %r596 bra $L161; .loc 1 449 0 and.b32 %r366,%r366,15; .loc 1 450 0 cvta.const.u64 %r597,__mprec_bigtens; ld.f64 %r598,[%r597+32]; div.rn.f64 %r220,%r215,%r598; .loc 1 451 0 mov.u32 %r327,3; bra $L51; $L55: cvta.const.u64 %r395,__mprec_bigtens; $L53: .loc 1 454 0 and.b32 %r599,%r366,1; setp.eq.u32 %r600,%r599,0; @ %r600 bra $L52; .loc 1 456 0 add.u32 %r327,%r327,1; .loc 1 457 0 ld.f64 %r601,[%r395]; mul.f64 %r345,%r345,%r601; $L52: .loc 1 453 0 shr.s32 %r366,%r366,1; add.u64 %r395,%r395,8; setp.ne.u32 %r602,%r366,0; @ %r602 bra $L53; bra $L54; $L161: mov.f64 %r220,%r215; .loc 1 441 0 mov.u32 %r327,2; $L51: .loc 1 453 0 setp.ne.u32 %r603,%r366,0; @ %r603 bra $L55; $L54: .loc 1 459 0 div.rn.f64 %r465,%r220,%r345; bra $L56; $L50: .loc 1 461 0 setp.eq.u32 %r604,%r332,0; @ %r604 bra $L162; neg.s32 %r363,%r332; .loc 1 463 0 cvta.const.u64 %r605,__mprec_tens; and.b32 %r606,%r363,15; cvt.s64.s32 %r607,%r606; shl.b64 %r608,%r607,3; add.u64 %r609,%r605,%r608; ld.f64 %r610,[%r609]; mul.f64 %r465,%r215,%r610; .loc 1 464 0 shr.s32 %r364,%r363,4; setp.eq.u32 %r611,%r364,0; @ %r611 bra $L163; cvta.const.u64 %r393,__mprec_bigtens; mov.f64 %r346,%r465; mov.u32 %r325,0; .loc 1 441 0 mov.u32 %r327,2; $L58: .loc 1 465 0 and.b32 %r612,%r364,1; setp.eq.u32 %r613,%r612,0; @ %r613 bra $L57; .loc 1 467 0 add.u32 %r327,%r327,1; .loc 1 468 0 ld.f64 %r614,[%r393]; mul.f64 %r346,%r346,%r614; mov.u32 %r325,%r455; $L57: .loc 1 464 0 shr.s32 %r364,%r364,1; add.u64 %r393,%r393,8; setp.ne.u32 %r615,%r364,0; @ %r615 bra $L58; setp.eq.u32 %r616,%r325,0; selp.f64 %r465,%r465,%r346,%r616; bra $L56; $L162: mov.f64 %r465,%r215; .loc 1 441 0 mov.u32 %r327,2; bra $L56; $L163: mov.u32 %r327,2; $L56: .loc 1 471 0 setp.eq.u32 %r617,%r333,0; @ %r617 bra $L60; setp.lt.f64 %r618,%r465,0d3ff0000000000000; @ ! %r618 bra $L60; setp.eq.u32 %r619,%r328,0; @ %r619 bra $L62; .loc 1 473 0 setp.le.s32 %r620,%r330,0; @ %r620 bra $L63; .loc 1 476 0 add.u32 %r448,%r332,-1; .loc 1 477 0 mul.f64 %r465,%r465,0d4024000000000000; .loc 1 478 0 add.u32 %r621,%r327,1; .loc 1 480 0 cvt.rn.f64.s32 %r622,%r621; fma.rn.f64 %r440,%r465,%r622,0d401c000000000000; mov.b64 %r483,%r440; .loc 1 481 0 shr.u64 %r624,%r483,32; cvt.u32.u64 %r626,%r624; add.u32 %r625,%r626,-54525952; cvt.u64.u32 %r627,%r625; shl.b64 %r628,%r627,32; and.b64 %r629,%r483,4294967295; or.b64 %r483,%r629,%r628; mov.u32 %r451,%r330; bra $L64; $L60: .loc 1 480 0 cvt.rn.f64.s32 %r631,%r327; fma.rn.f64 %r230,%r631,%r465,0d401c000000000000; mov.b64 %r483,%r230; .loc 1 481 0 shr.u64 %r633,%r483,32; cvt.u32.u64 %r635,%r633; add.u32 %r634,%r635,-54525952; cvt.u64.u32 %r636,%r634; shl.b64 %r637,%r636,32; and.b64 %r638,%r483,4294967295; or.b64 %r483,%r638,%r637; .loc 1 482 0 setp.ne.u32 %r640,%r328,0; @ %r640 bra $L164; $L145: .loc 1 485 0 mov.f64 %r641,0d4014000000000000; sub.f64 %r232,%r465,%r641; .loc 1 486 0 mov.b64 %r233,%r483; setp.gt.f64 %r642,%r232,%r233; @ %r642 bra $L165; .loc 1 488 0 neg.f64 %r643,%r233; setp.lt.f64 %r644,%r232,%r643; @ %r644 bra $L166; bra $L63; $L164: mov.u32 %r448,%r332; mov.u32 %r451,%r328; $L64: cvt.rzi.s32.f64 %r466,%r465; mov.b64 %r468,%r483; cvta.const.u64 %r645,__mprec_tens; add.u32 %r646,%r451,-1; cvt.s64.s32 %r647,%r646; shl.b64 %r648,%r647,3; add.u64 %r649,%r645,%r648; ld.f64 %r470,[%r649]; cvt.rn.f64.s32 %r650,%r466; sub.f64 %r245,%r465,%r650; add.u64 %r347,%r587,1; cvt.u16.u32 %r653,%r466; add.u16 %r652,%r653,48; cvt.u32.u16 %r654,%r652; cvt.s32.s8 %r456,%r654; .loc 1 493 0 setp.eq.u32 %r655,%r334,0; @ %r655 bra $L67; .loc 1 498 0 mov.f64 %r657,0d3fe0000000000000; div.rn.f64 %r656,%r657,%r470; sub.f64 %r241,%r656,%r468; .loc 1 503 0 st.u8 [%r587],%r654; .loc 1 504 0 setp.gt.f64 %r659,%r241,%r245; @ %r659 bra $L167; .loc 1 506 0 mov.f64 %r661,0d3ff0000000000000; sub.f64 %r660,%r661,%r245; setp.lt.f64 %r662,%r660,%r241; @ %r662 bra $L69; .loc 1 508 0 setp.eq.u32 %r663,%r451,1; @ %r663 bra $L63; mov.u64 %r356,%r347; add.u64 %r664,%r587,2; add.u32 %r665,%r451,-2; cvt.u64.u32 %r666,%r665; add.u64 %r403,%r664,%r666; .loc 1 506 0 mov.f64 %r1097,%r661; bra $L70; $L266: sub.f64 %r667,%r1097,%r245; setp.lt.f64 %r669,%r667,%r241; @ %r669 bra $L69; mov.u64 %r356,%r409; .loc 1 508 0 setp.eq.u64 %r670,%r403,%r356; @ %r670 bra $L63; $L70: .loc 1 510 0 mul.f64 %r241,%r241,0d4024000000000000; .loc 1 511 0 mul.f64 %r242,%r245,0d4024000000000000; .loc 1 501 0 cvt.rzi.s32.f64 %r370,%r242; .loc 1 502 0 cvt.rn.f64.s32 %r671,%r370; sub.f64 %r245,%r242,%r671; add.u64 %r409,%r356,1; mov.u64 %r347,%r409; .loc 1 503 0 cvt.u16.u32 %r674,%r370; add.u16 %r673,%r674,48; cvt.u32.u16 %r675,%r673; cvt.s32.s8 %r456,%r675; st.u8 [%r356],%r675; .loc 1 504 0 setp.lt.f64 %r677,%r245,%r241; @ ! %r677 bra $L266; .loc 1 855 0 bra $L168; $L67: .loc 1 518 0 mul.f64 %r243,%r468,%r470; .loc 1 523 0 st.u8 [%r587],%r654; .loc 1 524 0 setp.ne.u32 %r679,%r451,1; @ %r679 bra $L72; $L78: .loc 1 526 0 add.f64 %r680,%r243,0d3fe0000000000000; setp.lt.f64 %r681,%r680,%r245; @ ! %r681 bra $L267; ld.s8 %r456,[%r347+-1]; bra $L69; $L267: .loc 1 528 0 mov.f64 %r683,0d3fe0000000000000; sub.f64 %r682,%r683,%r243; setp.gt.f64 %r684,%r682,%r245; @ %r684 bra $L76; bra $L63; $L169: mov.u64 %r347,%r369; $L76: .loc 1 530 0 add.u64 %r369,%r347,-1; ld.s8 %r252,[%r369]; cvt.u16.u32 %r685,%r252; setp.eq.u16 %r686,%r685,48; @ %r686 bra $L169; mov.u64 %r484,%r587; .loc 1 531 0 mov.u64 %r214,%r347; bra $L68; $L72: mov.u64 %r402,%r347; add.u32 %r687,%r451,-2; cvt.u64.u32 %r398,%r687; add.u64 %r688,%r587,2; add.u64 %r396,%r688,%r398; $L77: .loc 1 519 0 mul.f64 %r253,%r245,0d4024000000000000; .loc 1 521 0 cvt.rzi.s32.f64 %r368,%r253; .loc 1 522 0 cvt.rn.f64.s32 %r689,%r368; sub.f64 %r245,%r253,%r689; .loc 1 523 0 cvt.u16.u32 %r692,%r368; add.u16 %r691,%r692,48; cvt.u32.u16 %r693,%r691; st.u8 [%r402],%r693; add.u64 %r402,%r402,1; .loc 1 524 0 setp.ne.u64 %r694,%r396,%r402; @ %r694 bra $L77; add.u64 %r695,%r398,1; add.u64 %r347,%r347,%r695; bra $L78; $L63: .loc 1 542 0 mov.b64 %r481,%r215; $L49: .loc 1 549 0 ld.u32 %r254,[%frame]; set.u32.le.s32 %r697,%r332,14; neg.s32 %r698,%r697; not.b32 %r700,%r254; shr.u32 %r701,%r700,31; cvt.u16.u32 %r704,%r698; cvt.u16.u32 %r705,%r701; and.b16 %r703,%r704,%r705; cvt.u32.u16 %r706,%r703; cvt.u16.u8 %r707,%r706; setp.eq.u16 %r708,%r707,0; @ %r708 bra $L79; bra $L147; $L192: .loc 1 400 0 mov.u32 %r328,-1; .loc 1 406 0 mov.u32 %r488,%r1061; $L147: .loc 1 552 0 cvta.const.u64 %r709,__mprec_tens; cvt.s64.s32 %r710,%r332; shl.b64 %r711,%r710,3; add.u64 %r712,%r709,%r711; ld.f64 %r371,[%r712]; .loc 1 553 0 shr.u32 %r714,%r488,31; set.u32.le.s32 %r716,%r328,0; neg.s32 %r717,%r716; cvt.u16.u32 %r720,%r714; cvt.u16.u32 %r721,%r717; and.b16 %r719,%r720,%r721; cvt.u32.u16 %r722,%r719; cvt.u16.u8 %r723,%r722; setp.eq.u16 %r724,%r723,0; @ %r724 bra $L80; .loc 1 556 0 setp.ne.u32 %r725,%r328,0; @ %r725 bra $L170; mul.f64 %r726,%r371,0d4014000000000000; mov.b64 %r727,%r481; setp.ge.f64 %r728,%r726,%r727; @ %r728 bra $L171; .loc 1 555 0 mov.u64 %r379,0; mov.u64 %r343,%r379; bra $L65; $L80: .loc 1 562 0 mov.b64 %r250,%r481; div.rn.f64 %r729,%r250,%r371; cvt.rzi.s32.f64 %r372,%r729; .loc 1 563 0 neg.f64 %r730,%r371; cvt.rn.f64.s32 %r731,%r372; fma.rn.f64 %r263,%r730,%r731,%r250; .loc 1 572 0 add.u64 %r347,%r214,1; cvt.u16.u32 %r734,%r372; add.u16 %r733,%r734,48; cvt.u32.u16 %r735,%r733; st.u8 [%r214],%r735; .loc 1 573 0 setp.eq.u32 %r736,%r328,1; @ %r736 bra $L81; .loc 1 590 0 mul.f64 %r236,%r263,0d4024000000000000; setp.eq.f64 %r737,%r236,0d0000000000000000; @ %r737 bra $L172; mov.u64 %r229,%r347; add.u32 %r738,%r328,-2; cvt.u64.u32 %r739,%r738; add.u64 %r425,%r229,%r739; bra $L82; $L81: .loc 1 575 0 add.f64 %r267,%r263,%r263; .loc 1 576 0 setp.gt.f64 %r741,%r267,%r371; @ ! %r741 bra $L268; ld.s8 %r456,[%r347+-1]; mov.u32 %r448,%r332; bra $L69; $L268: setp.neu.f64 %r742,%r267,%r371; @ %r742 bra $L173; and.b32 %r743,%r372,1; setp.eq.u32 %r744,%r743,0; @ %r744 bra $L174; ld.s8 %r456,[%r347+-1]; mov.u32 %r448,%r332; bra $L69; $L88: add.u64 %r452,%r452,-1; .loc 1 580 0 setp.eq.u64 %r745,%r1089,%r214; @ %r745 bra $L85; ld.s8 %r456,[%r452]; mov.u64 %r347,%r1089; add.u64 %r1089,%r1089,-1; bra $L86; $L85: .loc 1 582 0 add.u32 %r448,%r448,1; .loc 1 583 0 mov.u32 %r746,48; st.u8 [%r214],%r746; ld.s8 %r456,[%r347+-1]; .loc 1 584 0 mov.u64 %r262,%r214; bra $L87; $L69: add.u64 %r1089,%r347,-1; mov.u64 %r452,%r1089; $L86: .loc 1 579 0 mov.u64 %r262,%r1089; cvt.u16.u32 %r747,%r456; setp.eq.u16 %r748,%r747,57; @ %r748 bra $L88; $L87: .loc 1 586 0 cvt.u16.u32 %r751,%r456; add.u16 %r750,%r751,1; cvt.u32.u16 %r752,%r750; st.u8 [%r262],%r752; mov.u64 %r484,%r214; mov.u64 %r214,%r347; bra $L68; $L269: .loc 1 590 0 mul.f64 %r236,%r263,0d4024000000000000; mov.u64 %r229,%r431; setp.eq.f64 %r753,%r236,0d0000000000000000; @ %r753 bra $L175; $L82: .loc 1 562 0 div.rn.f64 %r754,%r236,%r371; cvt.rzi.s32.f64 %r372,%r754; .loc 1 563 0 cvt.rn.f64.s32 %r755,%r372; neg.f64 %r756,%r755; fma.rn.f64 %r263,%r756,%r371,%r236; add.u64 %r431,%r229,1; mov.u64 %r347,%r431; .loc 1 572 0 cvt.u16.u32 %r759,%r372; add.u16 %r758,%r759,48; cvt.u32.u16 %r760,%r758; st.u8 [%r229],%r760; .loc 1 573 0 setp.eq.u64 %r761,%r229,%r425; @ ! %r761 bra $L269; bra $L81; $L79: .loc 1 599 0 setp.eq.u32 %r762,%r334,0; @ %r762 bra $L176; $L148: .loc 1 601 0 setp.gt.s32 %r763,%r487,1; @ %r763 bra $L91; .loc 1 605 0 setp.eq.u32 %r764,%r340,0; @ %r764 bra $L92; add.u32 %r376,%r254,1075; add.u32 %r337,%r337,%r376; mov.u32 %r336,%r321; .loc 1 596 0 mov.u32 %r335,%r320; add.u32 %r320,%r320,%r376; bra $L93; $L92: .loc 1 605 0 mov.u32 %r765,54; ld.u32 %r766,[%frame+4]; sub.u32 %r375,%r765,%r766; add.u32 %r337,%r337,%r375; mov.u32 %r336,%r321; .loc 1 596 0 mov.u32 %r335,%r320; .loc 1 605 0 add.u32 %r320,%r320,%r375; bra $L93; $L91: .loc 1 615 0 add.u32 %r373,%r328,-1; .loc 1 616 0 setp.lt.s32 %r767,%r321,%r373; @ %r767 bra $L94; .loc 1 617 0 sub.u32 %r336,%r321,%r373; bra $L95; $L94: .loc 1 620 0 sub.u32 %r768,%r373,%r321; add.u32 %r338,%r338,%r768; mov.u32 %r321,%r373; .loc 1 622 0 mov.u32 %r336,0; $L95: .loc 1 624 0 setp.lt.s32 %r769,%r328,0; @ %r769 bra $L96; add.u32 %r337,%r337,%r328; .loc 1 596 0 mov.u32 %r335,%r320; .loc 1 624 0 add.u32 %r320,%r320,%r328; bra $L93; $L96: .loc 1 626 0 sub.u32 %r335,%r320,%r328; $L93: .loc 1 632 0 mov.u32 %r771,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r771; call (%value_in),__i2b,(%out_arg1,%out_arg2); ld.param.u64 %r772,[%value_in]; } mov.u64 %r343,%r772; bra $L90; $L176: mov.u32 %r336,%r321; .loc 1 596 0 mov.u32 %r335,%r320; .loc 1 598 0 mov.u64 %r343,0; $L90: .loc 1 634 0 set.u32.gt.s32 %r774,%r335,0; neg.s32 %r775,%r774; set.u32.gt.s32 %r777,%r337,0; neg.s32 %r778,%r777; cvt.u16.u32 %r780,%r775; cvt.u16.u32 %r781,%r778; and.b16 %r779,%r780,%r781; cvt.u32.u16 %r782,%r779; cvt.u16.u8 %r783,%r782; setp.eq.u16 %r784,%r783,0; @ %r784 bra $L97; .loc 1 636 0 min.s32 %r377,%r335,%r337; .loc 1 637 0 sub.u32 %r320,%r320,%r377; .loc 1 638 0 sub.u32 %r335,%r335,%r377; .loc 1 639 0 sub.u32 %r337,%r337,%r377; $L97: .loc 1 641 0 setp.eq.u32 %r785,%r321,0; @ %r785 bra $L98; .loc 1 643 0 setp.eq.u32 %r786,%r334,0; @ %r786 bra $L99; sub.u32 %r461,%r321,%r336; .loc 1 645 0 setp.eq.u32 %r787,%r336,0; @ %r787 bra $L100; .loc 1 647 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r336; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r791,[%value_in]; } mov.u64 %r343,%r791; .loc 1 648 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r522; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r795,[%value_in]; } .loc 1 649 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r522; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 652 0 setp.eq.u32 %r798,%r461,0; @ %r798 bra $L177; .loc 1 650 0 mov.u64 %r449,%r795; $L100: .loc 1 653 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r461; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r802,[%value_in]; } mov.u64 %r449,%r802; bra $L98; $L99: .loc 1 656 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r522; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r321; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r806,[%value_in]; } mov.u64 %r449,%r806; bra $L98; $L177: .loc 1 650 0 mov.u64 %r449,%r795; $L98: .loc 1 658 0 mov.u32 %r808,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r808; call (%value_in),__i2b,(%out_arg1,%out_arg2); ld.param.u64 %r809,[%value_in]; } mov.u64 %r379,%r809; .loc 1 659 0 setp.eq.u32 %r1091,%r338,0; @ %r1091 bra $L101; .loc 1 660 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r338; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r814,[%value_in]; } mov.u64 %r379,%r814; .loc 1 665 0 setp.le.s32 %r815,%r487,1; @ %r815 bra $L102; .loc 1 664 0 mov.u32 %r338,0; bra $L103; $L152: .loc 1 669 0 shr.u64 %r816,%r481,32; cvt.u32.u64 %r818,%r816; and.b32 %r817,%r818,2146435072; setp.eq.u32 %r819,%r817,0; @ %r819 bra $L178; .loc 1 674 0 add.u32 %r320,%r320,1; .loc 1 675 0 add.u32 %r337,%r337,1; .loc 1 676 0 mov.u32 %r339,1; bra $L104; $L178: .loc 1 664 0 mov.u32 %r339,%r817; $L104: .loc 1 689 0 @ %r1091 bra $L179; mov.u32 %r338,%r339; $L103: ld.u32 %r823,[%r379+20]; add.u32 %r822,%r823,-1; cvt.s64.s32 %r824,%r822; add.u64 %r825,%r824,6; shl.b64 %r826,%r825,2; add.u64 %r827,%r379,%r826; ld.u32 %r821,[%r827]; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r821; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r828,[%value_in]; } mov.u32 %r829,32; sub.u32 %r352,%r829,%r828; bra $L105; $L179: mov.u32 %r338,%r339; mov.u32 %r352,1; $L105: add.u32 %r830,%r352,%r337; and.b32 %r380,%r830,31; setp.eq.u32 %r831,%r380,0; @ %r831 bra $L180; .loc 1 690 0 mov.u32 %r832,32; sub.u32 %r381,%r832,%r380; .loc 1 695 0 setp.le.s32 %r833,%r381,4; @ %r833 bra $L107; .loc 1 697 0 mov.u32 %r834,28; sub.u32 %r382,%r834,%r380; .loc 1 698 0 add.u32 %r320,%r320,%r382; .loc 1 699 0 add.u32 %r335,%r335,%r382; .loc 1 700 0 add.u32 %r337,%r337,%r382; bra $L108; $L107: .loc 1 702 0 setp.eq.u32 %r835,%r381,4; @ %r835 bra $L108; mov.u32 %r836,60; sub.u32 %r460,%r836,%r380; bra $L106; $L180: mov.u32 %r460,28; $L106: .loc 1 705 0 add.u32 %r320,%r320,%r460; .loc 1 706 0 add.u32 %r335,%r335,%r460; .loc 1 707 0 add.u32 %r337,%r337,%r460; $L108: .loc 1 709 0 setp.le.s32 %r837,%r320,0; @ %r837 bra $L109; .loc 1 710 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r320; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r841,[%value_in]; } mov.u64 %r449,%r841; $L109: .loc 1 711 0 setp.le.s32 %r842,%r337,0; @ %r842 bra $L110; .loc 1 712 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r337; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r846,[%value_in]; } mov.u64 %r379,%r846; $L110: set.u32.gt.s32 %r848,%r487,2; neg.s32 %r849,%r848; cvt.u32.u32 %r847,%r849; cvt.u32.u8 %r476,%r847; .loc 1 713 0 setp.eq.u32 %r850,%r333,0; @ %r850 bra $L111; .loc 1 715 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r853,[%value_in]; } setp.ge.s32 %r854,%r853,0; @ %r854 bra $L111; .loc 1 717 0 add.u32 %r332,%r332,-1; .loc 1 718 0 mov.u32 %r858,0; mov.u32 %r857,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r857; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r858; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r859,[%value_in]; } mov.u64 %r449,%r859; set.u32.le.s32 %r861,%r330,0; neg.s32 %r862,%r861; cvt.u16.u32 %r864,%r862; cvt.u16.u32 %r865,%r476; and.b16 %r863,%r864,%r865; cvt.u32.u16 %r866,%r863; cvt.u32.u8 %r459,%r866; .loc 1 719 0 setp.eq.u32 %r867,%r334,0; @ %r867 bra $L112; .loc 1 720 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r857; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r858; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r872,[%value_in]; } mov.u64 %r343,%r872; .loc 1 724 0 setp.ne.u32 %r873,%r459,0; @ %r873 bra $L181; mov.u32 %r328,%r330; bra $L114; $L111: set.u32.le.s32 %r875,%r328,0; neg.s32 %r876,%r875; cvt.u16.u32 %r878,%r876; cvt.u16.u32 %r879,%r476; and.b16 %r877,%r878,%r879; cvt.u32.u16 %r880,%r877; cvt.u16.u8 %r881,%r880; setp.eq.u16 %r882,%r881,0; @ %r882 bra $L115; bra $L113; $L181: mov.u32 %r328,%r330; bra $L113; $L191: mov.u32 %r328,%r330; $L113: .loc 1 726 0 setp.ne.u32 %r883,%r328,0; @ %r883 bra $L66; mov.u32 %r886,5; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r886; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r328; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r888,[%value_in]; } mov.u64 %r379,%r888; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r891,[%value_in]; } setp.gt.s32 %r892,%r891,0; @ %r892 bra $L65; bra $L66; $L166: .loc 1 484 0 mov.u64 %r379,0; mov.u64 %r343,%r379; bra $L66; $L170: .loc 1 555 0 mov.u64 %r379,0; mov.u64 %r343,%r379; bra $L66; $L171: mov.u64 %r379,0; mov.u64 %r343,%r379; $L66: .loc 1 730 0 not.b32 %r448,%r488; .loc 1 731 0 mov.u64 %r484,%r214; bra $L116; $L165: .loc 1 484 0 mov.u64 %r379,0; mov.u64 %r343,%r379; $L65: .loc 1 734 0 mov.u32 %r893,49; st.u8 [%r214],%r893; .loc 1 735 0 add.u32 %r448,%r332,1; .loc 1 736 0 mov.u64 %r484,%r214; .loc 1 734 0 add.u64 %r214,%r214,1; .loc 1 736 0 bra $L116; $L115: .loc 1 738 0 setp.eq.u32 %r894,%r334,0; @ %r894 bra $L117; $L114: .loc 1 740 0 setp.le.s32 %r895,%r335,0; @ %r895 bra $L118; .loc 1 741 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r335; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r899,[%value_in]; } mov.u64 %r343,%r899; $L118: .loc 1 748 0 setp.eq.u32 %r900,%r338,0; @ %r900 bra $L182; .loc 1 750 0 ld.u32 %r287,[%r343+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r287; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r903,[%value_in]; } .loc 1 751 0 ld.s32 %r907,[%r343+20]; add.u64 %r908,%r907,2; shl.b64 %r909,%r908,2; add.u64 %r910,%r343,16; add.u64 %r911,%r903,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r911; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r910; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r909; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r912,[%value_in]; } .loc 1 752 0 mov.u32 %r915,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r903; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r915; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r916,[%value_in]; } mov.u64 %r344,%r916; bra $L119; $L182: mov.u64 %r344,%r343; $L119: mov.u64 %r417,%r214; add.u32 %r917,%r328,-1; cvt.u64.u32 %r918,%r917; add.u64 %r412,%r918,%r214; .loc 1 766 0 cvt.u32.u64 %r1094,%r481; and.b32 %r1095,%r1094,1; setp.ne.u32 %r1096,%r1095,0; $L135: .loc 1 757 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),quorem,(%out_arg1,%out_arg2); ld.param.u32 %r921,[%value_in]; } add.u32 %r322,%r921,48; .loc 1 761 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r924,[%value_in]; } .loc 1 762 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r344; call (%value_in),__mdiff,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r928,[%value_in]; } .loc 1 763 0 ld.u32 %r929,[%r928+16]; setp.ne.u32 %r930,%r929,0; @ %r930 bra $L183; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r928; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r933,[%value_in]; } mov.u32 %r353,%r933; bra $L120; $L183: mov.u32 %r353,1; $L120: .loc 1 764 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r928; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 766 0 or.b32 %r936,%r353,%r487; setp.ne.u32 %r937,%r936,0; @ %r937 bra $L121; @ %r1096 bra $L121; add.u64 %r349,%r417,1; .loc 1 768 0 setp.eq.u32 %r941,%r322,57; @ %r941 bra $L122; .loc 1 770 0 setp.le.s32 %r942,%r924,0; @ %r942 bra $L123; .loc 1 771 0 add.u32 %r322,%r921,49; $L123: .loc 1 772 0 st.u8 [%r417],%r322; .loc 1 773 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r448,%r332; bra $L124; $L121: .loc 1 776 0 setp.lt.s32 %r943,%r924,0; @ %r943 bra $L125; or.b32 %r944,%r924,%r487; setp.ne.u32 %r945,%r944,0; @ %r945 bra $L126; .loc 1 778 0 @ %r1096 bra $L126; $L125: add.u64 %r349,%r417,1; .loc 1 782 0 setp.le.s32 %r949,%r353,0; @ %r949 bra $L127; .loc 1 784 0 mov.u32 %r952,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r952; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r953,[%value_in]; } mov.u64 %r449,%r953; .loc 1 785 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r956,[%value_in]; } .loc 1 786 0 setp.gt.s32 %r957,%r956,0; @ %r957 bra $L128; setp.ne.u32 %r958,%r956,0; @ %r958 bra $L127; and.b32 %r959,%r322,1; setp.eq.u32 %r960,%r959,0; @ %r960 bra $L127; $L128: .loc 1 787 0 setp.eq.u32 %r961,%r322,57; @ %r961 bra $L122; add.u32 %r322,%r921,49; $L127: .loc 1 790 0 st.u8 [%r417],%r322; .loc 1 791 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r448,%r332; bra $L124; $L126: add.u64 %r349,%r417,1; .loc 1 793 0 setp.le.s32 %r962,%r353,0; @ %r962 bra $L129; .loc 1 795 0 setp.ne.u32 %r963,%r322,57; @ %r963 bra $L130; $L122: .loc 1 798 0 mov.u32 %r964,57; st.u8 [%r417],%r964; .loc 1 799 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r457,57; bra $L131; $L130: .loc 1 801 0 cvt.u16.u32 %r967,%r322; add.u16 %r966,%r967,1; cvt.u32.u16 %r968,%r966; st.u8 [%r417],%r968; .loc 1 802 0 mov.u64 %r342,%r343; mov.u64 %r343,%r344; mov.u32 %r448,%r332; bra $L124; $L129: .loc 1 804 0 st.u8 [%r417],%r322; .loc 1 805 0 setp.eq.u64 %r969,%r412,%r417; @ %r969 bra $L184; .loc 1 807 0 mov.u32 %r973,0; mov.u32 %r972,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r974,[%value_in]; } mov.u64 %r449,%r974; .loc 1 808 0 setp.ne.u64 %r975,%r343,%r344; @ %r975 bra $L133; .loc 1 809 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r980,[%value_in]; } mov.u64 %r343,%r980; mov.u64 %r344,%r343; bra $L134; $L133: .loc 1 812 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r985,[%value_in]; } mov.u64 %r343,%r985; .loc 1 813 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r344; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r972; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r973; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r990,[%value_in]; } mov.u64 %r344,%r990; $L134: mov.u64 %r417,%r349; .loc 1 757 0 bra $L135; $L117: mov.u64 %r204,%r214; .loc 1 724 0 mov.u32 %r326,1; $L136: .loc 1 820 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),quorem,(%out_arg1,%out_arg2); ld.param.u32 %r993,[%value_in]; } add.u32 %r322,%r993,48; add.u64 %r349,%r204,1; st.u8 [%r204],%r322; .loc 1 821 0 setp.ge.s32 %r994,%r326,%r328; @ %r994 bra $L185; .loc 1 823 0 mov.u32 %r998,0; mov.u32 %r997,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r997; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r998; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r999,[%value_in]; } mov.u64 %r449,%r999; .loc 1 818 0 add.u32 %r326,%r326,1; mov.u64 %r204,%r349; .loc 1 820 0 bra $L136; $L184: mov.u64 %r342,%r343; mov.u64 %r343,%r344; bra $L132; $L185: .loc 1 598 0 mov.u64 %r342,0; $L132: .loc 1 828 0 mov.u32 %r1002,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1002; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r1003,[%value_in]; } mov.u64 %r449,%r1003; .loc 1 829 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r1006,[%value_in]; } .loc 1 830 0 setp.gt.s32 %r1007,%r1006,0; @ %r1007 bra $L137; ld.s8 %r457,[%r349+-1]; setp.ne.u32 %r1008,%r1006,0; @ %r1008 bra $L138; and.b32 %r1009,%r322,1; setp.ne.u32 %r1010,%r1009,0; @ %r1010 bra $L131; $L138: add.u64 %r421,%r349,-1; bra $L139; $L142: add.u64 %r424,%r424,-1; .loc 1 834 0 setp.eq.u64 %r1011,%r1090,%r214; @ %r1011 bra $L140; ld.s8 %r457,[%r424]; mov.u64 %r349,%r1090; add.u64 %r1090,%r1090,-1; bra $L141; $L140: .loc 1 836 0 add.u32 %r448,%r332,1; .loc 1 837 0 mov.u32 %r1012,49; st.u8 [%r214],%r1012; .loc 1 838 0 bra $L124; $L137: ld.s8 %r457,[%r349+-1]; $L131: add.u64 %r1090,%r349,-1; mov.u64 %r424,%r1090; $L141: .loc 1 833 0 cvt.u16.u32 %r1013,%r457; setp.eq.u16 %r1014,%r1013,57; @ %r1014 bra $L142; .loc 1 840 0 add.u16 %r1016,%r1013,1; cvt.u32.u16 %r1018,%r1016; st.u8 [%r1090],%r1018; mov.u32 %r448,%r332; bra $L124; $L139: add.u64 %r349,%r421,1; add.u64 %r421,%r421,-1; .loc 1 844 0 cvt.u16.u32 %r1019,%r457; setp.ne.u16 %r1020,%r1019,48; @ %r1020 bra $L186; ld.s8 %r457,[%r421]; bra $L139; $L186: mov.u32 %r448,%r332; $L124: .loc 1 848 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 849 0 setp.eq.u64 %r1023,%r343,0; @ %r1023 bra $L187; .loc 1 851 0 set.u32.ne.u64 %r1025,%r342,0; neg.s32 %r1026,%r1025; set.u32.ne.u64 %r1028,%r342,%r343; neg.s32 %r1029,%r1028; cvt.u16.u32 %r1031,%r1026; cvt.u16.u32 %r1032,%r1029; and.b16 %r1030,%r1031,%r1032; cvt.u32.u16 %r1033,%r1030; cvt.u16.u8 %r1034,%r1033; setp.eq.u16 %r1035,%r1034,0; @ %r1035 bra $L188; .loc 1 852 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r342; call _Bfree,(%out_arg1,%out_arg2); } mov.u64 %r484,%r214; mov.u64 %r214,%r349; bra $L143; $L188: mov.u64 %r484,%r214; mov.u64 %r214,%r349; $L143: .loc 1 853 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r343; call _Bfree,(%out_arg1,%out_arg2); } bra $L68; $L167: .loc 1 504 0 mov.u64 %r484,%r587; .loc 1 503 0 mov.u64 %r214,%r347; bra $L68; $L168: .loc 1 855 0 mov.u64 %r484,%r587; .loc 1 503 0 mov.u64 %r214,%r409; bra $L68; $L172: .loc 1 590 0 mov.u64 %r484,%r214; .loc 1 572 0 mov.u64 %r214,%r347; .loc 1 590 0 mov.u32 %r448,%r332; bra $L68; $L173: mov.u64 %r484,%r214; mov.u64 %r214,%r347; mov.u32 %r448,%r332; bra $L68; $L174: mov.u64 %r484,%r214; mov.u64 %r214,%r347; mov.u32 %r448,%r332; bra $L68; $L175: mov.u64 %r484,%r214; .loc 1 572 0 mov.u64 %r214,%r229; mov.u32 %r448,%r332; bra $L68; $L187: .loc 1 855 0 mov.u64 %r484,%r214; mov.u64 %r214,%r349; $L68: .loc 1 856 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r449; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 857 0 mov.u32 %r1042,0; st.u8 [%r214],%r1042; .loc 1 858 0 add.u32 %r1043,%r448,1; st.u32 [%r489],%r1043; .loc 1 859 0 setp.eq.u64 %r1044,%r491,0; @ %r1044 bra $L21; .loc 1 860 0 st.u64 [%r491],%r214; bra $L21; $L153: .loc 1 288 0 cvta.const.u64 %r484,$LC2; bra $L21; $L26: .loc 1 270 0 setp.ne.u64 %r1046,%r491,0; @ %r1046 bra $L189; .loc 1 267 0 cvta.const.u64 %r484,$LC0; bra $L21; $L264: .loc 1 270 0 setp.ne.u64 %r1047,%r491,0; @ %r1047 bra $L190; .loc 1 267 0 cvta.const.u64 %r484,$LC1; bra $L21; $L62: .loc 1 480 0 cvt.rn.f64.s32 %r1048,%r327; fma.rn.f64 %r436,%r1048,%r465,0d401c000000000000; mov.b64 %r483,%r436; .loc 1 481 0 shr.u64 %r1050,%r483,32; cvt.u32.u64 %r1052,%r1050; add.u32 %r1051,%r1052,-54525952; cvt.u64.u32 %r1053,%r1051; shl.b64 %r1054,%r1053,32; and.b64 %r1055,%r483,4294967295; or.b64 %r483,%r1055,%r1054; bra $L145; $L112: .loc 1 724 0 setp.ne.u32 %r1057,%r459,0; @ %r1057 bra $L191; mov.u32 %r328,%r330; bra $L117; $L116: .loc 1 848 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r379; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 849 0 setp.ne.u64 %r1060,%r343,0; @ %r1060 bra $L143; bra $L68; $L146: .loc 1 427 0 mov.u32 %r1061,0; st.u32 [%r485+104],%r1061; .loc 1 430 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r485; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r1061; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r1064,[%value_in]; } mov.u64 %r214,%r1064; st.u64 [%r485+96],%r214; .loc 1 549 0 ld.u32 %r254,[%frame]; set.u32.le.s32 %r1066,%r332,14; neg.s32 %r1067,%r1066; not.b32 %r1069,%r254; shr.u32 %r1070,%r1069,31; cvt.u16.u32 %r1073,%r1067; cvt.u16.u32 %r1074,%r1070; and.b16 %r1072,%r1073,%r1074; cvt.u32.u16 %r1075,%r1072; cvt.u16.u8 %r1076,%r1075; setp.ne.u16 %r1077,%r1076,0; @ %r1077 bra $L192; .loc 1 400 0 mov.u32 %r330,-1; mov.u32 %r328,%r330; .loc 1 406 0 mov.u32 %r488,%r1061; .loc 1 399 0 mov.u32 %r334,1; bra $L148; $L158: mov.u32 %r455,1; $L42: .loc 1 401 0 setp.eq.u32 %r1078,%r487,3; @ %r1078 bra $L194; setp.gt.s32 %r1079,%r487,3; @ %r1079 bra $L149; setp.eq.u32 %r1080,%r487,2; @ %r1080 bra $L193; bra $L146; $L149: setp.eq.u32 %r1081,%r487,4; @ %r1081 bra $L43; setp.eq.u32 %r1082,%r487,5; @ ! %r1082 bra $L146; .loc 1 399 0 mov.u32 %r334,1; bra $L46; $L157: mov.u32 %r487,0; .loc 1 392 0 mov.u32 %r455,%r487; .loc 1 399 0 mov.u32 %r334,1; .loc 1 400 0 mov.u32 %r328,-1; .loc 1 406 0 mov.u32 %r488,%r487; bra $L41; $L159: .loc 1 413 0 mov.u32 %r488,1; mov.u32 %r328,%r488; $L41: .loc 1 427 0 mov.u32 %r1083,0; st.u32 [%r485+104],%r1083; mov.u32 %r330,%r328; mov.u32 %r211,%r1083; bra $L47; $L101: .loc 1 665 0 setp.le.s32 %r1084,%r487,1; @ %r1084 bra $L151; .loc 1 689 0 mov.u32 %r352,%r808; bra $L105; $L102: .loc 1 667 0 and.b64 %r1085,%r481,4503599627370495; setp.eq.u64 %r1086,%r1085,0; @ %r1086 bra $L152; .loc 1 664 0 mov.u32 %r338,0; bra $L103; $L151: .loc 1 667 0 and.b64 %r1087,%r481,4503599627370495; setp.eq.u64 %r1088,%r1087,0; @ %r1088 bra $L152; .loc 1 689 0 mov.u32 %r352,%r808; bra $L105; $L21: .loc 1 862 0 mov.u64 %value,%r484; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } /0 0 0 0 644 2065 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __dtoa .visible .func (.param .u64 %value_out) __dtoa (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5); .file 1 "../../../../../../newlib/libc/stdlib/dtoastub.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DEF: __dtoa .visible .func (.param .u64 %value_out) __dtoa (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .f64 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r37; .reg .u64 %r38; mov.f64 %r24,%ar0; mov.u32 %r25,%ar1; mov.u32 %r26,%ar2; mov.u64 %r27,%ar3; mov.u64 %r28,%ar4; mov.u64 %r29,%ar5; .loc 1 20 0 ld.global.u64 %r37,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r24; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r27; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r28; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r29; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r38,[%value_in]; } .loc 1 21 0 mov.u64 %value,%r38; st.param.u64 [%value_out],%value; ret; } lib_a-ecvtbuf.o/0 0 0 644 36440 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: print_e .func print_e (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5); .file 1 "../../../../../../newlib/libc/stdlib/ecvtbuf.c" // BEGIN GLOBAL FUNCTION DECL: fcvtbuf .visible .func (.param .u64 %value_out) fcvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: ecvtbuf .visible .func (.param .u64 %value_out) ecvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: _gcvt .visible .func (.param .u64 %value_out) _gcvt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DECL: _dcvt .visible .func (.param .u64 %value_out) _dcvt (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u32 %in_ar6); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _realloc_r .extern .func (.param .u64 %value_out) _realloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _mprec_log10 .extern .func (.param .f64 %value_out) _mprec_log10 (.param .u32 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN FUNCTION DEF: print_e .func print_e (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r145; .reg .u32 %r149; .reg .u64 %r163; .reg .u64 %r164; .reg .u64 %r165; .reg .u64 %r166; .reg .u64 %r168; .reg .u64 %r169; .reg .u32 %r170; .reg .u32 %r171; .reg .u32 %r186; .reg .u64 %r187; .reg .u64 %r188; .reg .f64 %r189; .reg .u32 %r190; .reg .u32 %r191; .reg .u32 %r192; .reg .u32 %r195; .reg .u64 %r200; .reg .u64 %r201; .reg .u32 %r202; .reg .u64 %r203; .reg .pred %r204; .reg .u64 %r207; .reg .u32 %r208; .reg .u32 %r209; .reg .pred %r210; .reg .u32 %r211; .reg .u16 %r213; .reg .u32 %r214; .reg .u32 %r215; .reg .u32 %r217; .reg .u32 %r218; .reg .u16 %r219; .reg .u16 %r220; .reg .u16 %r221; .reg .u32 %r222; .reg .u16 %r223; .reg .pred %r224; .reg .u32 %r225; .reg .u32 %r227; .reg .u32 %r228; .reg .u16 %r230; .reg .u32 %r231; .reg .u32 %r232; .reg .u16 %r233; .reg .u16 %r234; .reg .u16 %r235; .reg .u32 %r236; .reg .u16 %r237; .reg .pred %r238; .reg .u16 %r239; .reg .pred %r240; .reg .pred %r242; .reg .u16 %r243; .reg .pred %r244; .reg .pred %r246; .reg .pred %r247; .reg .u64 %r249; .reg .u64 %r250; .reg .u32 %r251; .reg .pred %r252; .reg .u64 %r254; .reg .u64 %r255; .reg .u32 %r256; .reg .pred %r257; .reg .u32 %r258; .reg .u32 %r259; .reg .u32 %r260; .reg .pred %r261; .reg .u16 %r263; .reg .u16 %r264; .reg .u32 %r265; .reg .u16 %r268; .reg .u16 %r269; .reg .u32 %r270; .reg .u32 %r272; .reg .u32 %r273; .reg .u32 %r274; .reg .u32 %r276; .reg .u16 %r278; .reg .u16 %r279; .reg .u32 %r280; .reg .u32 %r281; .reg .u32 %r282; mov.u64 %r187,%ar0; mov.u64 %r188,%ar1; mov.f64 %r189,%ar2; mov.u32 %r190,%ar3; mov.u32 %r191,%ar4; mov.u32 %r192,%ar5; .loc 1 161 0 add.u64 %r200,%frame,12; add.u64 %r201,%frame,8; add.u32 %r202,%r190,1; mov.u32 %r195,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r187; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r189; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r195; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r202; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r201; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r200; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r203,[%value_in]; } .loc 1 163 0 ld.u32 %r145,[%frame+8]; setp.ne.u32 %r204,%r145,9999; @ %r204 bra $L2; .loc 1 165 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r188; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r203; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r207,[%value_in]; } bra $L1; $L2: .loc 1 169 0 ld.u8 %r208,[%r203]; st.u8 [%r188],%r208; .loc 1 170 0 or.b32 %r209,%r190,%r192; setp.eq.u32 %r210,%r209,0; @ %r210 bra $L4; .loc 1 171 0 add.u64 %r163,%r188,2; mov.u32 %r211,46; st.u8 [%r188+1],%r211; .loc 1 173 0 ld.s8 %r149,[%r203+1]; cvt.u16.u32 %r213,%r149; set.u32.ne.u16 %r214,%r213,0; neg.s32 %r215,%r214; set.u32.gt.s32 %r217,%r190,0; neg.s32 %r218,%r217; cvt.u16.u32 %r220,%r215; cvt.u16.u32 %r221,%r218; and.b16 %r219,%r220,%r221; cvt.u32.u16 %r222,%r219; cvt.u16.u8 %r223,%r222; setp.eq.u16 %r224,%r223,0; @ %r224 bra $L5; .loc 1 169 0 add.u64 %r168,%r203,1; mov.u64 %r165,%r163; $L6: .loc 1 175 0 add.u64 %r168,%r168,1; add.u64 %r163,%r163,1; cvt.u32.u32 %r225,%r149; st.u8 [%r165],%r225; .loc 1 176 0 add.u32 %r190,%r190,-1; .loc 1 173 0 ld.s8 %r149,[%r168]; mov.u64 %r165,%r163; set.u32.gt.s32 %r227,%r190,0; neg.s32 %r228,%r227; cvt.u16.u32 %r230,%r149; set.u32.ne.u16 %r231,%r230,0; neg.s32 %r232,%r231; cvt.u16.u32 %r234,%r228; cvt.u16.u32 %r235,%r232; and.b16 %r233,%r234,%r235; cvt.u32.u16 %r236,%r233; cvt.u16.u8 %r237,%r236; setp.ne.u16 %r238,%r237,0; @ %r238 bra $L6; bra $L5; $L4: .loc 1 169 0 add.u64 %r163,%r188,1; .loc 1 182 0 cvt.u16.u32 %r239,%r191; setp.eq.u16 %r240,%r239,103; @ %r240 bra $L12; .loc 1 184 0 setp.eq.u16 %r242,%r239,71; .loc 1 185 0 selp.u32 %r191,69,%r191,%r242; bra $L7; $L5: .loc 1 182 0 cvt.u16.u32 %r243,%r191; setp.eq.u16 %r244,%r243,103; @ %r244 bra $L14; .loc 1 184 0 setp.eq.u16 %r246,%r243,71; @ %r246 bra $L15; .loc 1 188 0 setp.le.s32 %r247,%r190,0; @ %r247 bra $L7; mov.u64 %r169,%r163; add.u32 %r282,%r190,-1; cvt.u64.u32 %r249,%r282; add.u64 %r250,%r163,1; add.u64 %r166,%r249,%r250; .loc 1 190 0 mov.u32 %r251,48; $L8: st.u8 [%r169],%r251; add.u64 %r169,%r169,1; .loc 1 188 0 setp.ne.u64 %r252,%r166,%r169; @ %r252 bra $L8; cvt.s64.s32 %r254,%r282; add.u64 %r255,%r254,1; add.u64 %r163,%r163,%r255; bra $L7; $L12: .loc 1 183 0 mov.u32 %r191,101; bra $L7; $L14: mov.u32 %r191,101; bra $L7; $L15: .loc 1 185 0 mov.u32 %r191,69; $L7: .loc 1 197 0 cvt.u32.u32 %r256,%r191; st.u8 [%r163],%r256; .loc 1 198 0 add.u32 %r186,%r145,-1; add.u64 %r164,%r163,2; .loc 1 199 0 setp.ge.s32 %r257,%r186,0; @ %r257 bra $L9; .loc 1 201 0 mov.u32 %r258,45; st.u8 [%r163+1],%r258; .loc 1 202 0 mov.u32 %r259,1; sub.u32 %r186,%r259,%r145; bra $L10; $L9: .loc 1 206 0 mov.u32 %r260,43; st.u8 [%r163+1],%r260; $L10: .loc 1 208 0 setp.le.s32 %r261,%r186,99; @ %r261 bra $L11; .loc 1 210 0 div.s32 %r170,%r186,100; .loc 1 211 0 add.u64 %r164,%r163,3; cvt.u16.u32 %r264,%r170; add.u16 %r263,%r264,48; cvt.u32.u16 %r265,%r263; st.u8 [%r163+2],%r265; .loc 1 212 0 mad.lo.u32 %r186,%r170,-100,%r186; $L11: .loc 1 214 0 div.s32 %r171,%r186,10; .loc 1 215 0 cvt.u16.u32 %r269,%r171; add.u16 %r268,%r269,48; cvt.u32.u16 %r270,%r268; st.u8 [%r164],%r270; .loc 1 216 0 shl.b32 %r272,%r171,2; add.u32 %r273,%r272,%r171; add.u32 %r274,%r273,%r273; sub.u32 %r276,%r186,%r274; .loc 1 217 0 cvt.u16.u32 %r279,%r276; add.u16 %r278,%r279,48; cvt.u32.u16 %r280,%r278; st.u8 [%r164+1],%r280; .loc 1 219 0 mov.u32 %r281,0; st.u8 [%r164+2],%r281; $L1: .loc 1 220 0 st.shared.u64 [%sspslot],%sspprev; ret; } // BEGIN GLOBAL FUNCTION DEF: fcvtbuf .visible .func (.param .u64 %value_out) fcvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r74; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r82; .reg .u64 %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r90; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r101; .reg .f64 %r102; .reg .u32 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .pred %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .u64 %r114; .reg .u64 %r115; .reg .pred %r116; .reg .pred %r117; .reg .pred %r118; .reg .u32 %r121; .reg .u64 %r126; .reg .u32 %r129; .reg .u64 %r134; .reg .u32 %r135; .reg .u64 %r136; .reg .pred %r137; .reg .u32 %r138; .reg .u64 %r139; .reg .pred %r140; .reg .pred %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .u64 %r144; .reg .u32 %r145; .reg .pred %r146; .reg .u64 %r147; .reg .u32 %r148; mov.f64 %r102,%ar0; mov.u32 %r103,%ar1; mov.u64 %r104,%ar2; mov.u64 %r105,%ar3; mov.u64 %r106,%ar4; .loc 1 236 0 ld.global.u64 %r82,[_impure_ptr]; .loc 1 242 0 setp.ne.u64 %r107,%r106,0; @ %r107 bra $L22; ld.u64 %r106,[%r82+136]; .loc 1 244 0 add.u32 %r108,%r103,35; ld.u32 %r109,[%r82+128]; setp.gt.s32 %r110,%r109,%r108; @ %r110 bra $L22; .loc 1 247 0 add.u32 %r74,%r103,36; .loc 1 246 0 cvt.s64.s32 %r114,%r74; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r82; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r106; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r114; call (%value_in),_realloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r115,[%value_in]; } mov.u64 %r106,%r115; setp.eq.u64 %r116,%r106,0; @ %r116 bra $L33; .loc 1 249 0 st.u32 [%r82+128],%r74; .loc 1 250 0 st.u64 [%r82+136],%r106; $L22: .loc 1 258 0 setp.lt.f64 %r117,%r102,0d3ff0000000000000; @ ! %r117 bra $L25; setp.gt.f64 %r118,%r102,0dbff0000000000000; @ ! %r118 bra $L25; .loc 1 260 0 mov.u32 %r121,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r82; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r102; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r121; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r103; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r104; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r105; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r126,[%value_in]; } mov.u64 %r80,%r126; bra $L28; $L25: .loc 1 264 0 mov.u32 %r129,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r82; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r102; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r129; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r103; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r104; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r105; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r134,[%value_in]; } mov.u64 %r80,%r134; $L28: .loc 1 269 0 ld.u32 %r135,[%r104]; neg.s32 %r86,%r135; .loc 1 270 0 ld.u64 %r136,[%frame]; setp.ge.u64 %r137,%r80,%r136; @ %r137 bra $L34; mov.u64 %r84,%r106; mov.u64 %r85,%r80; $L30: add.u64 %r90,%r84,1; .loc 1 272 0 ld.u8 %r138,[%r85]; st.u8 [%r84],%r138; .loc 1 273 0 add.u32 %r86,%r86,1; mov.u64 %r84,%r90; add.u64 %r85,%r85,1; .loc 1 270 0 ld.u64 %r139,[%frame]; setp.gt.u64 %r140,%r139,%r85; @ %r140 bra $L30; bra $L29; $L34: mov.u64 %r90,%r106; $L29: .loc 1 276 0 setp.le.s32 %r141,%r103,%r86; @ %r141 bra $L31; mov.u64 %r79,%r90; add.u32 %r142,%r103,-1; sub.u32 %r143,%r142,%r86; cvt.u64.u32 %r94,%r143; add.u64 %r144,%r90,1; add.u64 %r95,%r144,%r94; .loc 1 278 0 mov.u32 %r145,48; $L32: st.u8 [%r79],%r145; add.u64 %r79,%r79,1; .loc 1 276 0 setp.ne.u64 %r146,%r79,%r95; @ %r146 bra $L32; add.u64 %r147,%r94,1; add.u64 %r90,%r90,%r147; $L31: .loc 1 281 0 mov.u32 %r148,0; st.u8 [%r90],%r148; .loc 1 282 0 mov.u64 %r101,%r106; bra $L21; $L33: .loc 1 248 0 mov.u64 %r101,%r115; $L21: .loc 1 283 0 mov.u64 %value,%r101; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ecvtbuf .visible .func (.param .u64 %value_out) ecvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r64; .reg .u64 %r68; .reg .u64 %r70; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u64 %r78; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r90; .reg .f64 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .pred %r96; .reg .u32 %r97; .reg .pred %r98; .reg .u64 %r102; .reg .u64 %r103; .reg .pred %r104; .reg .u32 %r107; .reg .u64 %r112; .reg .u64 %r113; .reg .pred %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u64 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .u64 %r124; .reg .u32 %r125; mov.f64 %r91,%ar0; mov.u32 %r92,%ar1; mov.u64 %r93,%ar2; mov.u64 %r94,%ar3; mov.u64 %r95,%ar4; .loc 1 293 0 ld.global.u64 %r70,[_impure_ptr]; .loc 1 299 0 setp.ne.u64 %r96,%r95,0; @ %r96 bra $L40; ld.u64 %r95,[%r70+136]; .loc 1 301 0 ld.u32 %r97,[%r70+128]; setp.gt.s32 %r98,%r97,%r92; @ %r98 bra $L40; .loc 1 304 0 add.u32 %r64,%r92,1; .loc 1 303 0 cvt.s64.s32 %r102,%r64; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r95; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r102; call (%value_in),_realloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r103,[%value_in]; } mov.u64 %r95,%r103; setp.eq.u64 %r104,%r95,0; @ %r104 bra $L47; .loc 1 306 0 st.u32 [%r70+128],%r64; .loc 1 307 0 st.u64 [%r70+136],%r95; $L40: .loc 1 315 0 mov.u32 %r107,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r70; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r91; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r107; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r92; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r93; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r94; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r112,[%value_in]; } .loc 1 319 0 ld.u64 %r113,[%frame]; setp.ge.u64 %r114,%r112,%r113; @ %r114 bra $L48; mov.u64 %r73,%r95; mov.u64 %r74,%r112; .loc 1 297 0 mov.u32 %r75,0; $L44: add.u64 %r78,%r73,1; .loc 1 321 0 ld.u8 %r115,[%r74]; st.u8 [%r73],%r115; .loc 1 322 0 add.u32 %r75,%r75,1; mov.u64 %r73,%r78; add.u64 %r74,%r74,1; .loc 1 319 0 ld.u64 %r116,[%frame]; setp.gt.u64 %r117,%r116,%r74; @ %r117 bra $L44; bra $L43; $L48: mov.u64 %r78,%r95; .loc 1 297 0 mov.u32 %r75,0; $L43: .loc 1 325 0 setp.le.s32 %r118,%r92,%r75; @ %r118 bra $L45; mov.u64 %r68,%r78; add.u32 %r119,%r92,-1; sub.u32 %r120,%r119,%r75; cvt.u64.u32 %r83,%r120; add.u64 %r121,%r78,1; add.u64 %r84,%r121,%r83; .loc 1 327 0 mov.u32 %r122,48; $L46: st.u8 [%r68],%r122; add.u64 %r68,%r68,1; .loc 1 325 0 setp.ne.u64 %r123,%r68,%r84; @ %r123 bra $L46; add.u64 %r124,%r83,1; add.u64 %r78,%r78,%r124; $L45: .loc 1 330 0 mov.u32 %r125,0; st.u8 [%r78],%r125; .loc 1 331 0 mov.u64 %r90,%r95; bra $L39; $L47: .loc 1 305 0 mov.u64 %r90,%r103; $L39: .loc 1 332 0 mov.u64 %value,%r90; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _gcvt .visible .func (.param .u64 %value_out) _gcvt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r354; .reg .u32 %r357; .reg .u32 %r358; .reg .u32 %r361; .reg .u32 %r364; .reg .u32 %r365; .reg .u64 %r366; .reg .u64 %r369; .reg .u32 %r371; .reg .u64 %r372; .reg .u64 %r373; .reg .u64 %r374; .reg .u64 %r376; .reg .u64 %r377; .reg .u32 %r378; .reg .u32 %r383; .reg .u32 %r391; .reg .u64 %r395; .reg .u32 %r397; .reg .u64 %r405; .reg .u64 %r415; .reg .f64 %r416; .reg .u32 %r417; .reg .u64 %r418; .reg .u32 %r419; .reg .u32 %r420; .reg .pred %r421; .reg .pred %r422; .reg .u32 %r423; .reg .u32 %r424; .reg .pred %r425; .reg .u32 %r432; .reg .f64 %r434; .reg .pred %r435; .reg .pred %r436; .reg .u32 %r439; .reg .u64 %r444; .reg .u64 %r445; .reg .u64 %r446; .reg .u32 %r449; .reg .u64 %r454; .reg .u64 %r455; .reg .u64 %r456; .reg .pred %r457; .reg .pred %r458; .reg .pred %r459; .reg .u64 %r462; .reg .u32 %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u32 %r467; .reg .u32 %r468; .reg .u32 %r470; .reg .u32 %r471; .reg .u16 %r472; .reg .u16 %r473; .reg .u16 %r474; .reg .u32 %r475; .reg .u16 %r476; .reg .pred %r477; .reg .pred %r478; .reg .u32 %r479; .reg .u32 %r481; .reg .u32 %r482; .reg .u32 %r484; .reg .u32 %r485; .reg .u16 %r486; .reg .u16 %r487; .reg .u16 %r488; .reg .u32 %r489; .reg .u16 %r490; .reg .pred %r491; .reg .pred %r492; .reg .u16 %r493; .reg .u32 %r494; .reg .pred %r495; .reg .pred %r496; .reg .u32 %r497; .reg .u32 %r498; .reg .u32 %r499; .reg .u32 %r500; .reg .u32 %r501; .reg .u32 %r503; .reg .u16 %r505; .reg .u16 %r506; .reg .u16 %r507; .reg .u32 %r508; .reg .u16 %r509; .reg .pred %r510; .reg .u32 %r511; .reg .u32 %r512; .reg .u32 %r513; .reg .u32 %r514; .reg .u32 %r516; .reg .u16 %r518; .reg .u16 %r519; .reg .u16 %r520; .reg .u32 %r521; .reg .u16 %r522; .reg .pred %r523; .reg .u16 %r525; .reg .u32 %r526; .reg .u32 %r527; .reg .u16 %r528; .reg .u16 %r529; .reg .u16 %r530; .reg .u32 %r531; .reg .u16 %r532; .reg .pred %r533; .reg .u32 %r534; .reg .u16 %r536; .reg .u32 %r537; .reg .u32 %r538; .reg .u32 %r540; .reg .u32 %r541; .reg .u16 %r542; .reg .u16 %r543; .reg .u16 %r544; .reg .u32 %r545; .reg .u16 %r546; .reg .pred %r547; .reg .pred %r548; .reg .pred %r549; .reg .u64 %r551; .reg .u64 %r552; .reg .u32 %r553; .reg .pred %r554; .reg .u64 %r556; .reg .u64 %r557; .reg .u32 %r558; .reg .u32 %r560; mov.u64 %r415,%ar0; mov.f64 %r416,%ar1; mov.u32 %r417,%ar2; mov.u64 %r418,%ar3; mov.u32 %r419,%ar4; mov.u32 %r420,%ar5; .loc 1 347 0 setp.lt.f64 %r421,%r416,0d0000000000000000; @ ! %r421 bra $L52; .loc 1 349 0 neg.f64 %r416,%r416; $L52: .loc 1 352 0 setp.neu.f64 %r422,%r416,0d0000000000000000; @ %r422 bra $L54; .loc 1 354 0 mov.u32 %r423,48; st.u8 [%r418],%r423; .loc 1 355 0 mov.u32 %r424,0; st.u8 [%r418+1],%r424; bra $L55; $L54: .loc 1 363 0 setp.le.f64 %r425,%r416,0d3f1a36e2eb1c432d; @ ! %r425 bra $L97; $L58: .loc 1 372 0 add.u32 %r432,%r417,-1; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r415; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r418; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r416; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r432; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r419; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r420; call print_e,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } bra $L55; $L97: .loc 1 363 0 { .param .f64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r417; call (%value_in),_mprec_log10,(%out_arg1); ld.param.f64 %r434,[%value_in]; } setp.le.f64 %r435,%r434,%r416; @ %r435 bra $L58; .loc 1 381 0 setp.lt.f64 %r436,%r416,0d3ff0000000000000; @ ! %r436 bra $L98; .loc 1 384 0 add.u64 %r444,%frame,8; add.u64 %r445,%frame,12; mov.u32 %r439,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r415; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r416; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r439; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r417; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r445; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r444; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r446,[%value_in]; } mov.u64 %r376,%r446; bra $L61; $L98: .loc 1 388 0 add.u64 %r454,%frame,8; add.u64 %r455,%frame,12; mov.u32 %r449,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r415; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r416; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r449; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r417; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r455; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r454; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r456,[%value_in]; } mov.u64 %r376,%r456; $L61: .loc 1 391 0 ld.u32 %r354,[%frame+12]; setp.eq.u32 %r457,%r354,9999; @ %r457 bra $L62; .loc 1 396 0 ld.s8 %r358,[%r376]; setp.eq.u32 %r458,%r358,0; @ %r458 bra $L79; setp.gt.s32 %r459,%r354,0; @ %r459 bra $L64; mov.u64 %r366,%r418; mov.u32 %r378,%r417; bra $L68; $L62: .loc 1 393 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r418; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r376; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r462,[%value_in]; } bra $L55; $L64: mov.u64 %r377,%r418; .loc 1 396 0 mov.u32 %r357,%r354; $L69: .loc 1 398 0 add.u64 %r376,%r376,1; add.u64 %r366,%r377,1; cvt.u32.u32 %r463,%r358; st.u8 [%r377],%r463; .loc 1 399 0 add.u32 %r357,%r357,-1; st.u32 [%frame+12],%r357; sub.u32 %r464,%r357,%r354; add.u32 %r378,%r464,%r417; .loc 1 396 0 ld.s8 %r358,[%r376]; setp.ne.u32 %r465,%r358,0; @ %r465 bra $L66; bra $L63; $L79: mov.u32 %r357,%r354; mov.u64 %r366,%r418; mov.u32 %r378,%r417; $L63: .loc 1 403 0 set.u32.gt.s32 %r467,%r378,0; neg.s32 %r468,%r467; set.u32.gt.s32 %r470,%r357,0; neg.s32 %r471,%r470; cvt.u16.u32 %r473,%r468; cvt.u16.u32 %r474,%r471; and.b16 %r472,%r473,%r474; cvt.u32.u16 %r475,%r472; cvt.u16.u8 %r476,%r475; setp.ne.u16 %r477,%r476,0; @ %r477 bra $L67; bra $L68; $L66: mov.u64 %r377,%r366; .loc 1 396 0 setp.ne.u32 %r478,%r357,0; @ %r478 bra $L69; bra $L68; $L67: add.u32 %r391,%r357,-1; mov.u64 %r374,%r366; .loc 1 405 0 mov.u32 %r479,48; $L70: add.u64 %r366,%r366,1; st.u8 [%r374],%r479; .loc 1 406 0 mov.u32 %r361,%r391; .loc 1 407 0 add.u32 %r378,%r378,-1; add.u32 %r391,%r391,-1; mov.u64 %r374,%r366; .loc 1 403 0 set.u32.gt.s32 %r481,%r361,0; neg.s32 %r482,%r481; set.u32.gt.s32 %r484,%r378,0; neg.s32 %r485,%r484; cvt.u16.u32 %r487,%r482; cvt.u16.u32 %r488,%r485; and.b16 %r486,%r487,%r488; cvt.u32.u16 %r489,%r486; cvt.u16.u8 %r490,%r489; setp.ne.u16 %r491,%r490,0; @ %r491 bra $L70; st.u32 [%frame+12],%r361; $L68: .loc 1 410 0 setp.ne.u32 %r492,%r420,0; @ %r492 bra $L71; ld.s8 %r494,[%r376]; cvt.u16.u32 %r493,%r494; setp.eq.u16 %r495,%r493,0; @ %r495 bra $L72; $L71: add.u64 %r405,%r366,1; .loc 1 412 0 setp.ne.u64 %r496,%r418,%r366; @ %r496 bra $L73; .loc 1 413 0 mov.u32 %r497,48; st.u8 [%r418],%r497; mov.u64 %r366,%r405; add.u64 %r405,%r418,2; $L73: .loc 1 414 0 mov.u32 %r498,46; st.u8 [%r366],%r498; .loc 1 415 0 ld.u32 %r397,[%frame+12]; set.u32.gt.s32 %r500,%r378,0; neg.s32 %r501,%r500; cvt.u32.u32 %r499,%r501; cvt.u32.u8 %r383,%r499; shr.u32 %r503,%r397,31; cvt.u16.u32 %r506,%r503; cvt.u16.u32 %r507,%r383; and.b16 %r505,%r506,%r507; cvt.u32.u16 %r508,%r505; cvt.u16.u8 %r509,%r508; setp.eq.u16 %r510,%r509,0; @ %r510 bra $L80; add.u32 %r371,%r397,1; mov.u64 %r369,%r405; .loc 1 417 0 mov.u32 %r511,48; $L75: add.u64 %r366,%r369,1; st.u8 [%r369],%r511; .loc 1 418 0 mov.u32 %r364,%r371; .loc 1 419 0 add.u32 %r378,%r378,-1; .loc 1 415 0 set.u32.gt.s32 %r513,%r378,0; neg.s32 %r514,%r513; cvt.u32.u32 %r512,%r514; cvt.u32.u8 %r383,%r512; add.u32 %r371,%r371,1; mov.u64 %r369,%r366; shr.u32 %r516,%r364,31; cvt.u16.u32 %r519,%r516; cvt.u16.u32 %r520,%r383; and.b16 %r518,%r519,%r520; cvt.u32.u16 %r521,%r518; cvt.u16.u8 %r522,%r521; setp.ne.u16 %r523,%r522,0; @ %r523 bra $L75; st.u32 [%frame+12],%r364; bra $L74; $L80: .loc 1 414 0 mov.u64 %r366,%r405; $L74: .loc 1 423 0 ld.s8 %r365,[%r376]; cvt.u16.u32 %r525,%r365; set.u32.ne.u16 %r526,%r525,0; neg.s32 %r527,%r526; cvt.u16.u32 %r529,%r527; cvt.u16.u32 %r530,%r383; and.b16 %r528,%r529,%r530; cvt.u32.u16 %r531,%r528; cvt.u16.u8 %r532,%r531; setp.eq.u16 %r533,%r532,0; @ %r533 bra $L76; mov.u64 %r372,%r366; $L77: .loc 1 425 0 add.u64 %r376,%r376,1; add.u64 %r366,%r366,1; cvt.u32.u32 %r534,%r365; st.u8 [%r372],%r534; .loc 1 426 0 add.u32 %r378,%r378,-1; .loc 1 423 0 ld.s8 %r365,[%r376]; mov.u64 %r372,%r366; cvt.u16.u32 %r536,%r365; set.u32.ne.u16 %r537,%r536,0; neg.s32 %r538,%r537; set.u32.gt.s32 %r540,%r378,0; neg.s32 %r541,%r540; cvt.u16.u32 %r543,%r538; cvt.u16.u32 %r544,%r541; and.b16 %r542,%r543,%r544; cvt.u32.u16 %r545,%r542; cvt.u16.u8 %r546,%r545; setp.ne.u16 %r547,%r546,0; @ %r547 bra $L77; $L76: .loc 1 429 0 setp.eq.u32 %r548,%r420,0; @ %r548 bra $L72; .loc 1 431 0 setp.le.s32 %r549,%r378,0; @ %r549 bra $L72; mov.u64 %r395,%r366; add.u32 %r560,%r378,-1; cvt.u64.u32 %r551,%r560; add.u64 %r552,%r366,1; add.u64 %r373,%r551,%r552; .loc 1 433 0 mov.u32 %r553,48; $L78: st.u8 [%r395],%r553; add.u64 %r395,%r395,1; .loc 1 431 0 setp.ne.u64 %r554,%r373,%r395; @ %r554 bra $L78; cvt.s64.s32 %r556,%r560; add.u64 %r557,%r556,1; add.u64 %r366,%r366,%r557; $L72: .loc 1 438 0 mov.u32 %r558,0; st.u8 [%r366],%r558; $L55: .loc 1 442 0 mov.u64 %value,%r418; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _dcvt .visible .func (.param .u64 %value_out) _dcvt (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .f64 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u32 %in_ar6) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %ar2; ld.param.f64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u32 %ar6; ld.param.u32 %ar6,[%in_ar6]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,16; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r257; .reg .u64 %r258; .reg .u32 %r266; .reg .u64 %r268; .reg .u64 %r269; .reg .u32 %r270; .reg .u32 %r271; .reg .u64 %r272; .reg .u64 %r275; .reg .u32 %r276; .reg .u32 %r280; .reg .u64 %r282; .reg .u64 %r285; .reg .u64 %r294; .reg .u64 %r295; .reg .u32 %r298; .reg .u64 %r302; .reg .u64 %r307; .reg .u64 %r308; .reg .u64 %r312; .reg .u64 %r313; .reg .f64 %r314; .reg .u32 %r315; .reg .u32 %r317; .reg .u32 %r318; .reg .u16 %r320; .reg .u16 %r321; .reg .u32 %r322; .reg .u16 %r323; .reg .pred %r324; .reg .u64 %r325; .reg .u64 %r326; .reg .pred %r327; .reg .u64 %r328; .reg .pred %r329; .reg .u64 %r330; .reg .pred %r331; .reg .pred %r332; .reg .u32 %r335; .reg .u64 %r340; .reg .u64 %r341; .reg .u64 %r342; .reg .pred %r343; .reg .pred %r344; .reg .pred %r345; .reg .u64 %r348; .reg .u32 %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .u64 %r353; .reg .u64 %r355; .reg .u32 %r356; .reg .pred %r357; .reg .u64 %r359; .reg .u64 %r360; .reg .u32 %r361; .reg .pred %r362; .reg .u16 %r363; .reg .u32 %r364; .reg .pred %r365; .reg .pred %r366; .reg .u32 %r367; .reg .u32 %r368; .reg .u32 %r370; .reg .u32 %r371; .reg .u32 %r373; .reg .u16 %r375; .reg .u16 %r376; .reg .u16 %r377; .reg .u32 %r378; .reg .u16 %r379; .reg .pred %r380; .reg .u32 %r381; .reg .u32 %r383; .reg .u32 %r385; .reg .u32 %r386; .reg .u16 %r388; .reg .u16 %r389; .reg .u16 %r390; .reg .u32 %r391; .reg .u16 %r392; .reg .pred %r393; .reg .pred %r394; .reg .pred %r395; .reg .u32 %r396; .reg .pred %r397; .reg .pred %r398; .reg .pred %r399; .reg .u64 %r401; .reg .u64 %r402; .reg .u32 %r403; .reg .pred %r404; .reg .u64 %r406; .reg .u64 %r407; .reg .u32 %r408; .reg .pred %r409; .reg .u64 %r416; .reg .u32 %r424; .reg .u32 %r425; mov.u64 %r312,%ar0; mov.u64 %r313,%ar1; mov.f64 %r314,%ar2; mov.u32 %r315,%ar3; mov.u32 %r317,%ar5; mov.u32 %r318,%ar6; cvt.u16.u32 %r321,%r317; add.u16 %r320,%r321,-69; cvt.u32.u16 %r322,%r320; cvt.u32.u8 %r257,%r322; cvt.u16.u32 %r323,%r257; setp.gt.u16 %r324,%r323,34; @ %r324 bra $L100; mov.u64 %r325,1; shl.b64 %r258,%r325,%r257; and.b64 %r326,%r258,4294967297; setp.ne.u64 %r327,%r326,0; @ %r327 bra $L101; and.b64 %r328,%r258,17179869188; setp.ne.u64 %r329,%r328,0; @ %r329 bra $L102; and.b64 %r330,%r258,8589934594; setp.eq.u64 %r331,%r330,0; @ %r331 bra $L100; .loc 1 458 0 setp.ne.u32 %r332,%r315,0; selp.u32 %r318,1,%r318,%r332; .loc 1 91 0 add.u64 %r340,%frame,8; add.u64 %r341,%frame,12; mov.u32 %r335,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r312; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r314; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r335; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r315; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r341; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r340; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%frame; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r342,[%value_in]; } .loc 1 93 0 ld.u32 %r271,[%frame+12]; setp.eq.u32 %r343,%r271,9999; @ %r343 bra $L104; .loc 1 98 0 ld.s8 %r270,[%r342]; setp.eq.u32 %r344,%r270,0; @ %r344 bra $L125; setp.gt.s32 %r345,%r271,0; @ %r345 bra $L106; mov.u64 %r268,%r342; mov.u64 %r294,%r313; bra $L110; $L104: .loc 1 95 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r313; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r342; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r348,[%value_in]; } bra $L100; $L106: mov.u64 %r307,%r313; .loc 1 98 0 mov.u64 %r268,%r342; $L111: .loc 1 100 0 add.u64 %r268,%r268,1; add.u64 %r294,%r307,1; cvt.u32.u32 %r349,%r270; st.u8 [%r307],%r349; .loc 1 101 0 add.u32 %r271,%r271,-1; st.u32 [%frame+12],%r271; .loc 1 98 0 ld.s8 %r270,[%r268]; setp.ne.u32 %r350,%r270,0; @ %r350 bra $L108; bra $L105; $L125: mov.u64 %r268,%r342; mov.u64 %r294,%r313; $L105: .loc 1 104 0 setp.gt.s32 %r351,%r271,0; @ %r351 bra $L109; bra $L110; $L108: mov.u64 %r307,%r294; .loc 1 98 0 setp.ne.u32 %r352,%r271,0; @ %r352 bra $L111; bra $L110; $L109: mov.u64 %r302,%r294; add.u64 %r353,%r294,1; add.u32 %r424,%r271,-1; cvt.u64.u32 %r355,%r424; add.u64 %r308,%r353,%r355; .loc 1 106 0 mov.u32 %r356,48; $L112: st.u8 [%r302],%r356; add.u64 %r302,%r302,1; .loc 1 104 0 setp.ne.u64 %r357,%r302,%r308; @ %r357 bra $L112; cvt.s64.s32 %r359,%r424; add.u64 %r360,%r359,1; add.u64 %r294,%r294,%r360; mov.u32 %r361,0; st.u32 [%frame+12],%r361; $L110: .loc 1 110 0 setp.ne.u32 %r362,%r318,0; @ %r362 bra $L113; ld.s8 %r364,[%r268]; cvt.u16.u32 %r363,%r364; setp.eq.u16 %r365,%r363,0; @ %r365 bra $L114; $L113: add.u64 %r285,%r294,1; .loc 1 112 0 setp.ne.u64 %r366,%r342,%r268; @ %r366 bra $L115; .loc 1 113 0 mov.u32 %r367,48; st.u8 [%r294],%r367; add.u64 %r272,%r294,2; mov.u64 %r294,%r285; mov.u64 %r285,%r272; $L115: .loc 1 114 0 mov.u32 %r368,46; st.u8 [%r294],%r368; .loc 1 115 0 ld.u32 %r266,[%frame+12]; set.u32.gt.s32 %r370,%r315,0; neg.s32 %r371,%r370; shr.u32 %r373,%r266,31; cvt.u16.u32 %r376,%r371; cvt.u16.u32 %r377,%r373; and.b16 %r375,%r376,%r377; cvt.u32.u16 %r378,%r375; cvt.u16.u8 %r379,%r378; setp.eq.u16 %r380,%r379,0; @ %r380 bra $L116; add.u32 %r298,%r266,1; mov.u64 %r269,%r285; .loc 1 117 0 mov.u32 %r381,48; $L117: add.u64 %r285,%r285,1; st.u8 [%r269],%r381; .loc 1 118 0 mov.u32 %r276,%r298; .loc 1 119 0 add.u32 %r315,%r315,-1; add.u32 %r298,%r298,1; mov.u64 %r269,%r285; .loc 1 115 0 shr.u32 %r383,%r276,31; set.u32.gt.s32 %r385,%r315,0; neg.s32 %r386,%r385; cvt.u16.u32 %r389,%r383; cvt.u16.u32 %r390,%r386; and.b16 %r388,%r389,%r390; cvt.u32.u16 %r391,%r388; cvt.u16.u8 %r392,%r391; setp.ne.u16 %r393,%r392,0; @ %r393 bra $L117; st.u32 [%frame+12],%r276; $L116: .loc 1 123 0 ld.s8 %r280,[%r268]; setp.eq.u32 %r394,%r280,0; @ %r394 bra $L126; setp.le.s32 %r395,%r315,0; @ %r395 bra $L127; mov.u64 %r275,%r285; $L121: .loc 1 125 0 add.u64 %r268,%r268,1; add.u64 %r294,%r275,1; cvt.u32.u32 %r396,%r280; st.u8 [%r275],%r396; .loc 1 126 0 add.u32 %r315,%r315,-1; .loc 1 123 0 ld.s8 %r280,[%r268]; setp.ne.u32 %r397,%r280,0; @ %r397 bra $L119; bra $L118; $L126: mov.u64 %r294,%r285; $L118: .loc 1 129 0 setp.gt.s32 %r398,%r315,0; @ %r398 bra $L120; bra $L114; $L119: mov.u64 %r275,%r294; .loc 1 123 0 setp.ne.u32 %r399,%r315,0; @ %r399 bra $L121; bra $L114; $L120: mov.u64 %r282,%r294; add.u32 %r425,%r315,-1; cvt.u64.u32 %r401,%r425; add.u64 %r402,%r294,1; add.u64 %r295,%r401,%r402; .loc 1 131 0 mov.u32 %r403,48; $L122: st.u8 [%r282],%r403; add.u64 %r282,%r282,1; .loc 1 129 0 setp.ne.u64 %r404,%r282,%r295; @ %r404 bra $L122; cvt.s64.s32 %r406,%r425; add.u64 %r407,%r406,1; add.u64 %r294,%r294,%r407; bra $L114; $L127: .loc 1 123 0 mov.u64 %r294,%r285; $L114: .loc 1 135 0 mov.u32 %r408,0; st.u8 [%r294],%r408; bra $L100; $L102: .loc 1 462 0 setp.eq.u32 %r409,%r315,0; .loc 1 463 0 selp.u32 %r315,1,%r315,%r409; .loc 1 464 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r312; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r314; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r315; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r313; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r317; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r318; call (%value_in),_gcvt,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u64 %r416,[%value_in]; } .loc 1 465 0 bra $L100; $L101: .loc 1 468 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r312; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r313; .param .f64 %out_arg3; st.param.f64 [%out_arg3],%r314; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r315; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r317; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r318; call print_e,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } $L100: .loc 1 471 0 mov.u64 %value,%r313; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } lib_a-efgcvt.o/ 0 0 0 644 8335 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: fcvt .visible .func (.param .u64 %value_out) fcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdlib/efgcvt.c" // BEGIN GLOBAL FUNCTION DECL: fcvtf .visible .func (.param .u64 %value_out) fcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: ecvt .visible .func (.param .u64 %value_out) ecvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: ecvtf .visible .func (.param .u64 %value_out) ecvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: gcvt .visible .func (.param .u64 %value_out) gcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: gcvtf .visible .func (.param .u64 %value_out) gcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: fcvtbuf .extern .func (.param .u64 %value_out) fcvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: ecvtbuf .extern .func (.param .u64 %value_out) ecvtbuf (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: _gcvt .extern .func (.param .u64 %value_out) _gcvt (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DEF: fcvt .visible .func (.param .u64 %value_out) fcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f64 %r23; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; mov.u64 %r25,%ar2; mov.u64 %r26,%ar3; .loc 1 147 0 mov.u64 %r31,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r31; call (%value_in),fcvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r32,[%value_in]; } .loc 1 148 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: fcvtf .visible .func (.param .u64 %value_out) fcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r32; .reg .f64 %r33; .reg .u64 %r34; mov.f32 %r24,%ar0; mov.u32 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 157 0 cvt.f64.f32 %r33,%r24; .loc 1 147 0 mov.u64 %r32,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r27; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r32; call (%value_in),fcvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r34,[%value_in]; } .loc 1 158 0 mov.u64 %value,%r34; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ecvt .visible .func (.param .u64 %value_out) ecvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f64 %r23; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.f64 %r23,%ar0; mov.u32 %r24,%ar1; mov.u64 %r25,%ar2; mov.u64 %r26,%ar3; .loc 1 179 0 mov.u64 %r31,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r31; call (%value_in),ecvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r32,[%value_in]; } .loc 1 180 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: ecvtf .visible .func (.param .u64 %value_out) ecvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .f32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r32; .reg .f64 %r33; .reg .u64 %r34; mov.f32 %r24,%ar0; mov.u32 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 189 0 cvt.f64.f32 %r33,%r24; .loc 1 179 0 mov.u64 %r32,0; { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r33; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r27; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r32; call (%value_in),ecvtbuf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r34,[%value_in]; } .loc 1 190 0 mov.u64 %value,%r34; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: gcvt .visible .func (.param .u64 %value_out) gcvt (.param .f64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .f64 %r26; .reg .u32 %r27; .reg .u64 %r28; .reg .pred %r29; .reg .u32 %r30; .reg .u32 %r35; .reg .u32 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .pred %r39; mov.f64 %r26,%ar0; mov.u32 %r27,%ar1; mov.u64 %r28,%ar2; .loc 1 200 0 setp.lt.f64 %r29,%r26,0d0000000000000000; @ ! %r29 bra $L11; .loc 1 201 0 mov.u32 %r30,45; st.u8 [%r28],%r30; .loc 1 202 0 add.u64 %r24,%r28,1; .loc 1 203 0 add.u32 %r27,%r27,-1; bra $L6; $L11: mov.u64 %r24,%r28; $L6: .loc 1 205 0 ld.global.u64 %r37,[_impure_ptr]; mov.u32 %r36,0; mov.u32 %r35,103; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r26; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r24; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r35; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r36; call (%value_in),_gcvt,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u64 %r38,[%value_in]; } setp.ne.u64 %r39,%r38,0; selp.u64 %value,%r28,0,%r39; .loc 1 206 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: gcvtf .visible .func (.param .u64 %value_out) gcvtf (.param .f32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .f32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .f64 %r30; .reg .u64 %r31; mov.f32 %r24,%ar0; mov.u32 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 167 0 cvt.f64.f32 %r30,%r24; .loc 1 168 0 { .param .u64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r30; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; call (%value_in),gcvt,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r31,[%value_in]; } .loc 1 169 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } lib_a-erand48.o/0 0 0 644 2961 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _erand48_r .visible .func (.param .f64 %value_out) _erand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/erand48.c" // BEGIN GLOBAL FUNCTION DECL: erand48 .visible .func (.param .f64 %value_out) erand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: ldexp .extern .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _erand48_r .visible .func (.param .f64 %value_out) _erand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f64 %r28; .reg .u64 %r33; .reg .u64 %r34; .reg .u32 %r38; .reg .f64 %r39; .reg .u32 %r40; .reg .f64 %r41; .reg .u32 %r43; .reg .f64 %r44; .reg .u32 %r45; .reg .f64 %r46; .reg .u32 %r48; .reg .f64 %r49; .reg .u32 %r50; .reg .f64 %r51; mov.u64 %r33,%ar0; mov.u64 %r34,%ar1; .loc 1 21 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r40,[%r34]; cvt.rn.f64.u32 %r39,%r40; mov.u32 %r38,-48; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r39; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r38; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r41,[%value_in]; } .loc 1 23 0 ld.u16 %r45,[%r34+2]; cvt.rn.f64.u32 %r44,%r45; mov.u32 %r43,-32; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r44; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r43; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r46,[%value_in]; } .loc 1 22 0 add.f64 %r28,%r41,%r46; .loc 1 24 0 ld.u16 %r50,[%r34+4]; cvt.rn.f64.u32 %r49,%r50; mov.u32 %r48,-16; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r49; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),ldexp,(%out_arg1,%out_arg2); ld.param.f64 %r51,[%value_in]; } .loc 1 23 0 add.f64 %value,%r28,%r51; .loc 1 25 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: erand48 .visible .func (.param .f64 %value_out) erand48 (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r27; .reg .f64 %r28; mov.u64 %r24,%ar0; .loc 1 32 0 ld.global.u64 %r27,[_impure_ptr]; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),_erand48_r,(%out_arg1,%out_arg2); ld.param.f64 %r28,[%value_in]; } .loc 1 33 0 mov.f64 %value,%r28; st.param.f64 [%value_out],%value; ret; } lib_a-errno.o/ 0 0 0 644 511 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __errno .visible .func (.param .u64 %value_out) __errno; .file 1 "../../../../../../newlib/libc/errno/errno.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: __errno .visible .func (.param .u64 %value_out) __errno { .reg .u64 %value; .loc 1 13 0 ld.global.u64 %value,[_impure_ptr]; .loc 1 14 0 st.param.u64 [%value_out],%value; ret; } lib_a-exit.o/ 0 0 0 644 738 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: exit .visible .func exit (.param .u32 %in_ar0); .file 1 "../../../../../../../newlib/libc/machine/nvptx/exit.c" // BEGIN GLOBAL VAR DEF: __exitval_ptr .weak .global .align 8 .u64 __exitval_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: exit .visible .func exit (.param .u32 %in_ar0) { .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u32 %r23; .reg .pred %r24; mov.u32 %r23,%ar0; .loc 1 28 0 ld.global.u64 %r22,[__exitval_ptr]; setp.eq.u64 %r24,%r22,0; @ %r24 bra $L3; .loc 1 29 0 st.u32 [%r22],%r23; $L3: .loc 1 31 0 // #APP // 31 "../../../../../../../newlib/libc/machine/nvptx/exit.c" 1 exit; // #NO_APP bra $L3; } lib_a-ffs.o/ 0 0 0 644 877 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ffs .visible .func (.param .u32 %value_out) ffs (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/misc/ffs.c" // BEGIN GLOBAL FUNCTION DEF: ffs .visible .func (.param .u32 %value_out) ffs (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r25; .reg .u32 %r26; .reg .u32 %r27; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r30; .reg .pred %r31; mov.u32 %r28,%ar0; .loc 1 37 0 setp.eq.u32 %r29,%r28,0; @ %r29 bra $L4; .loc 1 40 0 mov.u32 %r26,0; $L3: .loc 1 43 0 add.u32 %r27,%r26,1; shr.s32 %r30,%r28,%r26; and.b32 %r25,%r30,1; mov.u32 %r26,%r27; setp.eq.u32 %r31,%r25,0; @ %r31 bra $L3; bra $L1; $L4: .loc 1 38 0 mov.u32 %r27,%r28; $L1: .loc 1 46 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } /18 0 0 0 644 3801 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fix_locale_grouping_str .visible .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/locale/fix_grouping.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN VAR DEF: nogrouping .const .align 1 .u8 nogrouping[2] = {127,0 }; // BEGIN GLOBAL FUNCTION DEF: __fix_locale_grouping_str .visible .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r31; .reg .u32 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u64 %r45; .reg .u64 %r47; .reg .u64 %r48; .reg .pred %r49; .reg .pred %r50; .reg .u16 %r51; .reg .pred %r52; .reg .pred %r54; .reg .u16 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r59; .reg .u64 %r60; .reg .u64 %r62; .reg .u16 %r65; .reg .u16 %r66; .reg .u32 %r67; .reg .u16 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .u16 %r71; .reg .u16 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u16 %r79; .reg .u16 %r80; .reg .u32 %r81; .reg .u16 %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u32 %r88; .reg .u32 %r89; .reg .u16 %r90; .reg .u16 %r91; .reg .u16 %r94; .reg .u16 %r97; .reg .u16 %r98; .reg .u16 %r101; .reg .u32 %r104; .reg .u32 %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .u32 %r109; .reg .u32 %r111; .reg .u16 %r112; .reg .u32 %r113; mov.u64 %r48,%ar0; .loc 1 45 0 setp.ne.u64 %r49,%r48,0; @ %r49 bra $L2; $L4: .loc 1 46 0 cvta.const.u64 %r47,nogrouping; bra $L1; $L2: .loc 1 45 0 ld.s8 %r38,[%r48]; setp.eq.u32 %r50,%r38,0; @ %r50 bra $L4; mov.u64 %r40,%r48; mov.u64 %r45,%r48; .loc 1 56 0 mov.u32 %r111,127; $L10: .loc 1 52 0 cvt.u16.u32 %r51,%r38; setp.eq.u16 %r52,%r51,59; @ %r52 bra $L11; .loc 1 55 0 setp.ne.u16 %r54,%r51,45; @ %r54 bra $L6; ld.s8 %r56,[%r45+1]; cvt.u16.u32 %r55,%r56; setp.ne.u16 %r57,%r55,49; @ %r57 bra $L6; .loc 1 56 0 st.u8 [%r40],%r111; .loc 1 57 0 add.u64 %r39,%r45,1; .loc 1 56 0 add.u64 %r40,%r40,1; .loc 1 58 0 bra $L5; $L6: .loc 1 61 0 ld.global.u64 %r23,[__ctype_ptr__]; cvt.u32.u32 %r59,%r38; cvt.u32.u8 %r24,%r59; cvt.u64.u8 %r60,%r59; add.u64 %r62,%r23,%r60; ld.u8 %r112,[%r62+1]; mov.u16 %r66,%r112; and.b16 %r65,%r66,4; cvt.u32.u16 %r67,%r65; cvt.s32.s8 %r69,%r67; cvt.u16.u32 %r68,%r69; setp.eq.u16 %r70,%r68,0; @ %r70 bra $L4; .loc 1 67 0 cvt.u16.u32 %r72,%r24; add.u16 %r71,%r72,-48; cvt.u32.u16 %r73,%r71; .loc 1 68 0 ld.u8 %r31,[%r45+1]; cvt.u32.u32 %r75,%r31; cvt.u64.u8 %r74,%r75; add.u64 %r76,%r23,%r74; ld.u8 %r112,[%r76+1]; mov.u16 %r80,%r112; and.b16 %r79,%r80,4; cvt.u32.u16 %r81,%r79; cvt.s32.s8 %r83,%r81; cvt.u16.u32 %r82,%r83; setp.ne.u16 %r84,%r82,0; @ %r84 bra $L7; .loc 1 67 0 cvt.s32.s8 %r41,%r73; mov.u64 %r39,%r45; bra $L8; $L7: .loc 1 69 0 add.u64 %r39,%r45,1; .loc 1 70 0 cvt.u32.u8 %r113,%r73; mov.u32 %r89,%r113; shl.b32 %r88,%r89,2; cvt.u16.u32 %r91,%r88; add.u16 %r90,%r91,%r71; add.u16 %r94,%r90,%r90; .loc 1 71 0 cvt.u16.u32 %r98,%r31; add.u16 %r97,%r98,-48; add.u16 %r101,%r94,%r97; cvt.u32.u16 %r104,%r101; cvt.s32.s8 %r41,%r104; $L8: .loc 1 74 0 cvt.u32.u32 %r105,%r41; st.u8 [%r40],%r105; .loc 1 76 0 setp.ne.u32 %r106,%r41,0; @ %r106 bra $L9; .loc 1 77 0 setp.ne.u64 %r107,%r48,%r40; @ %r107 bra $L12; bra $L4; $L9: .loc 1 78 0 add.u64 %r40,%r40,1; bra $L5; $L11: mov.u64 %r39,%r45; $L5: .loc 1 49 0 add.u64 %r45,%r39,1; ld.s8 %r38,[%r39+1]; setp.ne.u32 %r108,%r38,0; @ %r108 bra $L10; .loc 1 80 0 cvt.u32.u32 %r109,%r38; st.u8 [%r40],%r109; .loc 1 81 0 mov.u64 %r47,%r48; bra $L1; $L12: mov.u64 %r47,%r48; $L1: .loc 1 82 0 mov.u64 %value,%r47; st.param.u64 [%value_out],%value; ret; } lib_a-free.o/ 0 0 0 644 1108 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .visible .func __nvptx_free (.param .u64 %in_ar0); .file 1 "../../../../../../../newlib/libc/machine/nvptx/free.c" // BEGIN GLOBAL FUNCTION DECL: free .extern .func free (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_uni .extern .shared .u32 __nvptx_uni[32]; // BEGIN GLOBAL FUNCTION DEF: __nvptx_free .visible .func __nvptx_free (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; .reg .pred %r24; .reg .u64 %r26; .reg .u32 %r27; .reg .pred %r28; .reg .u64 %r29; { .reg .u32 %ustmp0; .reg .u64 %ustmp1; mov.u32 %ustmp0,%tid.y; mul.wide.u32 %ustmp1,%ustmp0,4; mov.u64 %r29,__nvptx_uni; add.u64 %r29,%r29,%ustmp1; ld.shared.u32 %r27,[%r29]; mov.u32 %ustmp0,%laneid; and.b32 %r27,%r27,%ustmp0; setp.eq.u32 %r28,%r27,%ustmp0; } mov.u64 %r23,%ar0; .loc 1 33 0 setp.eq.u64 %r24,%r23,0; @ %r24 bra $L1; .loc 1 34 0 add.u64 %r26,%r23,-8; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; @ %r28 call free,(%out_arg1); } $L1: .loc 1 35 0 ret; } /40 0 0 0 644 28016 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: rshift .func rshift (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/gdtoa-gethex.c" // BEGIN GLOBAL FUNCTION DECL: __gethex .visible .func (.param .u32 %value_out) __gethex (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strncmp .extern .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __hi0bits .extern .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __any_on .extern .func (.param .u32 %value_out) __any_on (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __lshift .extern .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DEF: __hexdig .visible .const .align 1 .u8 __hexdig[256] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,16,17,18,19,20,21,22,23,24,25,0,0,0,0,0,0,0,26,27,28,29,30,31,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,26,27,28,29,30,31,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // BEGIN FUNCTION DEF: rshift .func rshift (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u64 %r59; .reg .u32 %r60; .reg .u64 %r61; .reg .u32 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u32 %r76; .reg .u64 %r77; .reg .u32 %r79; .reg .u64 %r85; .reg .u64 %r90; .reg .u64 %r99; .reg .u32 %r100; .reg .u64 %r103; .reg .u64 %r105; .reg .u32 %r106; .reg .pred %r107; .reg .u32 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .pred %r113; .reg .pred %r114; .reg .u32 %r116; .reg .u32 %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r137; .reg .pred %r138; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r143; .reg .u64 %r144; .reg .u64 %r146; .reg .pred %r147; .reg .u32 %r148; mov.u64 %r105,%ar0; mov.u32 %r106,%ar1; .loc 1 80 0 add.u64 %r85,%r105,24; .loc 1 81 0 shr.s32 %r70,%r106,5; .loc 1 82 0 ld.u32 %r49,[%r105+20]; setp.gt.s32 %r107,%r49,%r70; @ %r107 bra $L2; .loc 1 99 0 mov.u32 %r108,0; st.u32 [%r105+20],%r108; bra $L3; $L2: mov.u64 %r103,%r85; .loc 1 83 0 cvt.s64.s32 %r109,%r49; shl.b64 %r110,%r109,2; add.u64 %r71,%r85,%r110; .loc 1 84 0 cvt.s64.s32 %r111,%r70; shl.b64 %r112,%r111,2; add.u64 %r72,%r85,%r112; .loc 1 85 0 and.b32 %r73,%r106,31; setp.ne.u32 %r113,%r73,0; @ %r113 bra $L4; .loc 1 96 0 setp.gt.u64 %r114,%r71,%r72; @ %r114 bra $L5; .loc 1 99 0 st.u32 [%r105+20],%r73; bra $L3; $L4: .loc 1 86 0 mov.u32 %r116,32; sub.u32 %r76,%r116,%r73; .loc 1 87 0 add.u64 %r77,%r72,4; ld.u32 %r117,[%r72]; shr.u32 %r79,%r117,%r73; .loc 1 88 0 setp.le.u64 %r118,%r71,%r77; @ %r118 bra $L6; mov.u64 %r59,%r85; mov.u64 %r99,%r77; $L7: .loc 1 89 0 ld.u32 %r120,[%r99]; shl.b32 %r119,%r120,%r76; or.b32 %r121,%r119,%r79; st.u32 [%r59],%r121; .loc 1 90 0 ld.u32 %r122,[%r99]; shr.u32 %r79,%r122,%r73; add.u64 %r59,%r59,4; add.u64 %r99,%r99,4; .loc 1 88 0 setp.gt.u64 %r123,%r71,%r99; @ %r123 bra $L7; sub.u64 %r125,%r71,%r72; add.u64 %r126,%r125,-5; and.b64 %r128,%r126,-4; add.u64 %r129,%r128,4; add.u64 %r85,%r85,%r129; $L6: .loc 1 92 0 st.u32 [%r85],%r79; setp.ne.u32 %r130,%r79,0; @ %r130 bra $L8; sub.u64 %r131,%r85,%r103; shr.s64 %r133,%r131,2; cvt.u32.u64 %r100,%r133; bra $L9; $L8: .loc 1 93 0 add.u64 %r134,%r85,4; sub.u64 %r135,%r134,%r103; shr.s64 %r137,%r135,2; cvt.u32.u64 %r100,%r137; bra $L9; $L5: mov.u64 %r90,%r72; mov.u64 %r61,%r85; $L10: .loc 1 97 0 ld.u32 %r60,[%r90]; st.u32 [%r61],%r60; add.u64 %r90,%r90,4; add.u64 %r61,%r61,4; .loc 1 96 0 setp.gt.u64 %r138,%r71,%r90; @ %r138 bra $L10; not.b64 %r140,%r72; add.u64 %r141,%r140,%r71; and.b64 %r143,%r141,-4; add.u64 %r144,%r143,4; shr.s64 %r146,%r144,2; cvt.u32.u64 %r100,%r146; $L9: .loc 1 99 0 st.u32 [%r105+20],%r100; setp.ne.u32 %r147,%r100,0; @ %r147 bra $L1; $L3: .loc 1 100 0 mov.u32 %r148,0; st.u32 [%r105+24],%r148; $L1: .loc 1 101 0 ret; } // BEGIN GLOBAL FUNCTION DEF: __gethex .visible .func (.param .u32 %value_out) __gethex (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u32 %in_ar5) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r73; .reg .u32 %r75; .reg .u64 %r76; .reg .u32 %r89; .reg .u32 %r91; .reg .u64 %r102; .reg .u32 %r114; .reg .u32 %r116; .reg .u32 %r129; .reg .u64 %r166; .reg .u64 %r167; .reg .u32 %r168; .reg .u32 %r169; .reg .u32 %r170; .reg .u64 %r172; .reg .u64 %r174; .reg .u32 %r175; .reg .u64 %r176; .reg .u32 %r178; .reg .u32 %r180; .reg .u64 %r181; .reg .u32 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .u32 %r186; .reg .u32 %r188; .reg .u32 %r189; .reg .u32 %r190; .reg .u32 %r191; .reg .u32 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .u64 %r195; .reg .u32 %r196; .reg .u32 %r197; .reg .u64 %r198; .reg .u64 %r201; .reg .u64 %r202; .reg .u32 %r204; .reg .u32 %r206; .reg .u64 %r219; .reg .u64 %r223; .reg .u32 %r224; .reg .u32 %r225; .reg .u64 %r228; .reg .u64 %r231; .reg .u64 %r232; .reg .u32 %r233; .reg .u32 %r237; .reg .u32 %r238; .reg .u32 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u32 %r245; .reg .u64 %r247; .reg .u64 %r249; .reg .u64 %r250; .reg .u16 %r252; .reg .pred %r253; .reg .u16 %r254; .reg .pred %r255; .reg .u64 %r257; .reg .u64 %r258; .reg .u16 %r259; .reg .pred %r260; .reg .u32 %r264; .reg .pred %r265; .reg .u64 %r267; .reg .u64 %r268; .reg .pred %r269; .reg .u16 %r270; .reg .pred %r271; .reg .u16 %r272; .reg .pred %r273; .reg .u64 %r275; .reg .u64 %r276; .reg .u16 %r278; .reg .u32 %r279; .reg .u64 %r283; .reg .u64 %r284; .reg .u16 %r285; .reg .pred %r286; .reg .u64 %r289; .reg .u64 %r290; .reg .pred %r291; .reg .u32 %r295; .reg .pred %r296; .reg .pred %r297; .reg .u64 %r299; .reg .u64 %r300; .reg .u16 %r301; .reg .pred %r302; .reg .u64 %r304; .reg .u64 %r305; .reg .u16 %r306; .reg .pred %r307; .reg .pred %r308; .reg .u64 %r309; .reg .u32 %r310; .reg .u32 %r311; .reg .u16 %r312; .reg .pred %r313; .reg .pred %r315; .reg .u16 %r316; .reg .pred %r317; .reg .pred %r319; .reg .u64 %r321; .reg .u64 %r322; .reg .u16 %r323; .reg .u16 %r324; .reg .u16 %r325; .reg .u32 %r326; .reg .pred %r327; .reg .u64 %r330; .reg .u64 %r331; .reg .u16 %r332; .reg .u16 %r333; .reg .u16 %r334; .reg .u32 %r335; .reg .pred %r336; .reg .u32 %r338; .reg .u32 %r339; .reg .u32 %r340; .reg .u64 %r343; .reg .u64 %r344; .reg .u16 %r345; .reg .u16 %r346; .reg .u16 %r347; .reg .u32 %r348; .reg .pred %r349; .reg .pred %r350; .reg .pred %r351; .reg .pred %r352; .reg .u64 %r353; .reg .u32 %r354; .reg .pred %r355; .reg .pred %r356; .reg .u64 %r359; .reg .pred %r360; .reg .u16 %r361; .reg .u16 %r362; .reg .pred %r363; .reg .pred %r364; .reg .u64 %r365; .reg .pred %r367; .reg .u32 %r371; .reg .pred %r372; .reg .u64 %r375; .reg .u64 %r376; .reg .u16 %r378; .reg .u16 %r379; .reg .u32 %r380; .reg .u32 %r381; .reg .u32 %r382; .reg .pred %r383; .reg .u64 %r384; .reg .u64 %r386; .reg .u32 %r388; .reg .pred %r389; .reg .u32 %r392; .reg .pred %r393; .reg .u32 %r394; .reg .u64 %r395; .reg .u64 %r396; .reg .u64 %r397; .reg .u32 %r398; .reg .u32 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .u32 %r402; .reg .pred %r403; .reg .pred %r404; .reg .u32 %r407; .reg .u32 %r408; .reg .pred %r409; .reg .pred %r412; .reg .u64 %r416; .reg .u32 %r417; .reg .pred %r418; .reg .u64 %r421; .reg .pred %r422; .reg .pred %r423; .reg .u32 %r424; .reg .pred %r425; .reg .pred %r426; .reg .pred %r427; .reg .pred %r428; .reg .pred %r429; .reg .u32 %r432; .reg .u32 %r433; .reg .pred %r434; .reg .pred %r435; .reg .pred %r436; .reg .u32 %r437; .reg .u64 %r441; .reg .pred %r442; .reg .pred %r443; .reg .u32 %r446; .reg .u32 %r447; .reg .u64 %r448; .reg .u64 %r449; .reg .u64 %r450; .reg .u32 %r451; .reg .u32 %r452; .reg .u32 %r453; .reg .u32 %r454; .reg .u32 %r455; .reg .pred %r456; .reg .pred %r459; .reg .u32 %r460; .reg .pred %r461; .reg .pred %r462; .reg .pred %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u32 %r466; .reg .u32 %r467; .reg .u32 %r468; .reg .pred %r469; .reg .u32 %r470; .reg .pred %r471; .reg .u64 %r472; .reg .pred %r473; .reg .u32 %r474; .reg .pred %r476; .reg .u32 %r477; .reg .pred %r478; .reg .u32 %r481; .reg .u32 %r482; .reg .u64 %r483; .reg .u64 %r487; .reg .u64 %r488; .reg .u64 %r489; .reg .u64 %r490; .reg .u64 %r491; .reg .u64 %r492; .reg .u32 %r495; .reg .u64 %r496; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r499; .reg .u32 %r500; .reg .pred %r501; .reg .u32 %r502; .reg .u32 %r503; .reg .pred %r504; .reg .u32 %r505; .reg .u64 %r506; .reg .u64 %r507; .reg .u64 %r508; .reg .u32 %r509; .reg .u32 %r510; .reg .u32 %r511; .reg .u32 %r512; .reg .u32 %r513; .reg .pred %r514; .reg .u32 %r515; .reg .pred %r516; .reg .u32 %r518; .reg .u32 %r519; .reg .pred %r520; .reg .pred %r521; .reg .u32 %r522; .reg .u64 %r523; .reg .u32 %r525; .reg .u32 %r526; .reg .u32 %r527; .reg .pred %r528; .reg .u16 %r530; .reg .pred %r531; .reg .pred %r533; .reg .u64 %r534; .reg .u32 %r535; .reg .u16 %r536; mov.u64 %r240,%ar0; mov.u64 %r241,%ar1; mov.u64 %r242,%ar2; mov.u64 %r243,%ar3; mov.u64 %r244,%ar4; mov.u32 %r245,%ar5; .loc 1 162 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r247,[%value_in]; } .loc 1 161 0 ld.u64 %r176,[%r247]; .loc 1 163 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r176; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r249,[%value_in]; } .loc 1 164 0 add.u64 %r250,%r176,%r249; ld.u8 %r178,[%r250+-1]; .loc 1 167 0 ld.u64 %r67,[%r241]; .loc 1 168 0 ld.u8 %r68,[%r67+2]; cvt.u16.u32 %r252,%r68; setp.ne.u16 %r253,%r252,48; @ %r253 bra $L15; add.u64 %r228,%r67,3; .loc 1 166 0 mov.u32 %r224,0; $L16: .loc 1 169 0 add.u32 %r224,%r224,1; .loc 1 168 0 mov.u64 %r223,%r228; add.u64 %r228,%r228,1; ld.u8 %r68,[%r228+-1]; cvt.u16.u32 %r254,%r68; setp.eq.u16 %r255,%r254,48; @ %r255 bra $L16; bra $L17; $L15: add.u64 %r223,%r67,2; .loc 1 166 0 mov.u32 %r224,0; $L17: .loc 1 175 0 cvta.const.u64 %r534,__hexdig; cvt.s64.s32 %r257,%r68; add.u64 %r258,%r534,%r257; ld.u8 %r259,[%r258]; setp.ne.u16 %r260,%r259,0; @ %r260 bra $L18; .loc 1 177 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r223; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r176; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r249; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r264,[%value_in]; } setp.ne.u32 %r265,%r264,0; @ %r265 bra $L19; .loc 1 180 0 add.u64 %r76,%r223,%r249; .loc 1 181 0 ld.u8 %r73,[%r76]; cvt.s64.s32 %r267,%r73; add.u64 %r268,%r534,%r267; ld.u8 %r237,[%r268]; setp.eq.u32 %r269,%r237,0; @ %r269 bra $L20; .loc 1 183 0 cvt.u16.u32 %r270,%r73; setp.ne.u16 %r271,%r270,48; @ %r271 bra $L88; mov.u64 %r223,%r76; $L22: .loc 1 184 0 add.u64 %r223,%r223,1; .loc 1 183 0 ld.u8 %r75,[%r223]; cvt.u16.u32 %r272,%r75; setp.eq.u16 %r273,%r272,48; @ %r273 bra $L22; cvt.s64.s32 %r275,%r75; add.u64 %r276,%r534,%r275; ld.u8 %r237,[%r276]; bra $L21; $L88: mov.u64 %r223,%r76; $L21: .loc 1 185 0 cvt.u16.u32 %r278,%r237; set.u32.eq.u16 %r279,%r278,0; neg.s32 %r225,%r279; .loc 1 187 0 mov.u32 %r224,1; bra $L23; $L89: .loc 1 190 0 mov.u64 %r181,%r223; $L24: .loc 1 191 0 add.u64 %r181,%r181,1; .loc 1 190 0 ld.u8 %r283,[%r181]; add.u64 %r284,%r534,%r283; ld.u8 %r285,[%r284]; setp.ne.u16 %r286,%r285,0; @ %r286 bra $L24; bra $L25; $L18: ld.u8 %r289,[%r223]; add.u64 %r290,%r534,%r289; ld.u8 %r237,[%r290]; .loc 1 173 0 mov.u32 %r225,0; .loc 1 172 0 mov.u64 %r76,0; $L23: .loc 1 190 0 setp.ne.u32 %r291,%r237,0; @ %r291 bra $L89; mov.u64 %r181,%r223; $L25: .loc 1 192 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r181; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r176; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r249; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r295,[%value_in]; } setp.ne.u32 %r296,%r295,0; @ %r296 bra $L26; .loc 1 194 0 setp.eq.u64 %r297,%r76,0; @ %r297 bra $L27; ld.u8 %r238,[%r181]; bra $L28; $L27: .loc 1 195 0 add.u64 %r76,%r181,%r249; .loc 1 196 0 ld.u8 %r238,[%r76]; cvt.s64.s32 %r299,%r238; add.u64 %r300,%r534,%r299; ld.u8 %r301,[%r300]; setp.eq.u16 %r302,%r301,0; @ %r302 bra $L90; mov.u64 %r181,%r76; $L30: .loc 1 197 0 add.u64 %r181,%r181,1; .loc 1 196 0 ld.u8 %r238,[%r181]; cvt.s64.s32 %r304,%r238; add.u64 %r305,%r534,%r304; ld.u8 %r306,[%r305]; setp.ne.u16 %r307,%r306,0; @ %r307 bra $L30; bra $L28; $L26: ld.u8 %r238,[%r181]; .loc 1 199 0 setp.eq.u64 %r308,%r76,0; @ %r308 bra $L91; $L28: .loc 1 200 0 sub.u64 %r309,%r181,%r76; cvt.u32.u64 %r311,%r309; shl.b32 %r310,%r311,2; neg.s32 %r175,%r310; bra $L31; $L91: .loc 1 174 0 cvt.u32.u64 %r175,%r76; $L31: .loc 1 203 0 cvt.u16.u32 %r312,%r238; setp.eq.u16 %r313,%r312,80; @ %r313 bra $L93; setp.eq.u16 %r315,%r312,112; @ ! %r315 bra $L168; $L93: mov.u64 %r76,%r181; bra $L33; $L106: mov.u32 %r175,0; mov.u32 %r225,1; $L33: .loc 1 207 0 ld.u8 %r233,[%r76+1]; cvt.u16.u32 %r316,%r233; setp.eq.u16 %r317,%r316,43; @ %r317 bra $L94; setp.eq.u16 %r319,%r316,45; @ ! %r319 bra $L169; .loc 1 209 0 mov.u32 %r168,1; bra $L35; $L169: .loc 1 207 0 add.u64 %r167,%r76,1; .loc 1 206 0 mov.u32 %r168,0; bra $L37; $L94: mov.u32 %r168,0; $L35: .loc 1 212 0 add.u64 %r167,%r76,2; ld.u8 %r233,[%r76+2]; $L37: .loc 1 214 0 cvt.s64.s32 %r321,%r233; add.u64 %r322,%r534,%r321; ld.u8 %r89,[%r322]; cvt.u16.u32 %r324,%r89; add.u16 %r323,%r324,-1; cvt.u32.u16 %r326,%r323; cvt.u16.u8 %r325,%r326; setp.gt.u16 %r327,%r325,24; @ %r327 bra $L95; .loc 1 218 0 add.u32 %r184,%r89,-16; .loc 1 219 0 add.u64 %r181,%r167,1; ld.u8 %r330,[%r167+1]; add.u64 %r331,%r534,%r330; ld.u8 %r183,[%r331]; cvt.u16.u32 %r333,%r183; add.u16 %r332,%r333,-1; cvt.u32.u16 %r335,%r332; cvt.u16.u8 %r334,%r335; setp.gt.u16 %r336,%r334,24; @ %r336 bra $L38; $L39: .loc 1 220 0 shl.b32 %r338,%r184,2; add.u32 %r339,%r338,%r184; add.u32 %r340,%r339,%r339; add.u32 %r91,%r340,%r183; add.u32 %r184,%r91,-16; .loc 1 219 0 add.u64 %r181,%r181,1; ld.u8 %r343,[%r181]; add.u64 %r344,%r534,%r343; ld.u8 %r183,[%r344]; cvt.u16.u32 %r346,%r183; add.u16 %r345,%r346,-1; cvt.u32.u16 %r348,%r345; cvt.u16.u8 %r347,%r348; setp.le.u16 %r349,%r347,24; @ %r349 bra $L39; $L38: .loc 1 221 0 setp.eq.u32 %r350,%r168,0; @ %r350 bra $L40; .loc 1 222 0 neg.s32 %r184,%r184; $L40: .loc 1 223 0 add.u32 %r175,%r175,%r184; bra $L32; $L168: .loc 1 203 0 mov.u64 %r76,%r181; bra $L32; $L95: mov.u64 %r181,%r76; $L32: .loc 1 225 0 st.u64 [%r241],%r181; .loc 1 226 0 setp.eq.u32 %r351,%r225,0; @ %r351 bra $L41; $L87: .loc 1 227 0 setp.eq.u32 %r352,%r224,0; selp.u32 %r239,6,0,%r352; bra $L14; $L41: .loc 1 228 0 sub.u64 %r353,%r76,%r223; cvt.u32.u64 %r354,%r353; add.u32 %r197,%r354,-1; .loc 1 229 0 setp.le.s32 %r355,%r197,7; @ %r355 bra $L97; mov.u32 %r196,%r225; $L44: .loc 1 230 0 add.u32 %r196,%r196,1; .loc 1 229 0 shr.s32 %r197,%r197,1; setp.gt.s32 %r356,%r197,7; @ %r356 bra $L44; bra $L43; $L97: mov.u32 %r196,%r225; $L43: .loc 1 231 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r196; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r359,[%value_in]; } mov.u64 %r166,%r359; .loc 1 232 0 add.u64 %r174,%r359,24; .loc 1 235 0 setp.ge.u64 %r360,%r223,%r76; @ %r360 bra $L45; .loc 1 232 0 mov.u64 %r219,%r174; .loc 1 233 0 mov.u32 %r69,%r225; .loc 1 234 0 mov.u32 %r180,0; .loc 1 236 0 cvt.u16.u32 %r362,%r178; $L52: add.u64 %r195,%r76,-1; add.u64 %r232,%r219,4; ld.u8 %r361,[%r76+-1]; setp.eq.u16 %r363,%r361,%r362; @ %r363 bra $L46; $L49: .loc 1 242 0 setp.eq.u32 %r364,%r69,32; @ ! %r364 bra $L170; bra $L47; $L46: .loc 1 236 0 sub.u64 %r365,%r195,%r249; add.u64 %r102,%r365,1; setp.lt.u64 %r367,%r102,%r223; @ %r367 bra $L49; .loc 1 237 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r176; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r249; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r371,[%value_in]; } setp.eq.u32 %r372,%r371,0; @ ! %r372 bra $L49; bra $L98; $L170: .loc 1 242 0 mov.u32 %r169,%r69; add.u32 %r69,%r69,4; bra $L51; $L47: .loc 1 243 0 st.u32 [%r219],%r180; add.u64 %r231,%r219,8; mov.u64 %r219,%r232; mov.u64 %r232,%r231; .loc 1 245 0 mov.u32 %r169,%r225; .loc 1 243 0 mov.u32 %r69,4; .loc 1 244 0 mov.u32 %r180,0; $L51: .loc 1 247 0 ld.u8 %r375,[%r76+-1]; add.u64 %r376,%r534,%r375; ld.u8 %r536,[%r376]; mov.u16 %r379,%r536; and.b16 %r378,%r379,15; cvt.u32.u16 %r381,%r378; cvt.u32.u8 %r380,%r381; shl.b32 %r382,%r380,%r169; or.b32 %r180,%r180,%r382; .loc 1 236 0 mov.u64 %r76,%r195; bra $L50; $L98: mov.u64 %r76,%r102; $L50: .loc 1 235 0 setp.gt.u64 %r383,%r76,%r223; @ %r383 bra $L52; bra $L53; $L45: add.u64 %r232,%r359,28; .loc 1 232 0 mov.u64 %r219,%r174; .loc 1 234 0 mov.u32 %r180,0; $L53: .loc 1 250 0 st.u32 [%r219],%r180; .loc 1 251 0 sub.u64 %r384,%r232,%r174; shr.s64 %r386,%r384,2; cvt.u32.u64 %r185,%r386; st.u32 [%r359+20],%r185; .loc 1 252 0 shl.b32 %r114,%r185,5; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r180; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r388,[%value_in]; } sub.u32 %r186,%r114,%r388; .loc 1 253 0 ld.u32 %r170,[%r242]; .loc 1 256 0 setp.le.s32 %r389,%r186,%r170; @ %r389 bra $L54; .loc 1 257 0 sub.u32 %r189,%r186,%r170; .loc 1 258 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r359; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r189; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r392,[%value_in]; } mov.u32 %r116,%r392; setp.eq.u32 %r393,%r116,0; @ %r393 bra $L55; .loc 1 260 0 add.u32 %r190,%r189,-1; .loc 1 261 0 shr.s32 %r394,%r190,5; cvt.s64.s32 %r395,%r394; shl.b64 %r396,%r395,2; add.u64 %r397,%r174,%r396; and.b32 %r398,%r190,31; mov.u32 %r400,1; shl.b32 %r399,%r400,%r398; ld.u32 %r402,[%r397]; and.b32 %r401,%r399,%r402; setp.eq.u32 %r403,%r401,0; @ %r403 bra $L99; .loc 1 263 0 setp.gt.s32 %r404,%r190,1; @ %r404 bra $L56; $L57: .loc 1 262 0 mov.u32 %r116,2; bra $L55; $L56: .loc 1 263 0 add.u32 %r407,%r189,-2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r359; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r407; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r408,[%value_in]; } setp.eq.u32 %r409,%r408,0; @ %r409 bra $L57; .loc 1 264 0 mov.u32 %r116,3; bra $L55; $L99: .loc 1 259 0 mov.u32 %r116,%r400; $L55: .loc 1 267 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r359; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r189; call rshift,(%out_arg1,%out_arg2); } .loc 1 268 0 add.u32 %r175,%r175,%r189; bra $L58; $L54: .loc 1 270 0 setp.ge.s32 %r412,%r186,%r170; @ %r412 bra $L100; .loc 1 271 0 sub.u32 %r188,%r170,%r186; .loc 1 272 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r359; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r188; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r416,[%value_in]; } mov.u64 %r166,%r416; .loc 1 273 0 sub.u32 %r175,%r175,%r188; .loc 1 274 0 add.u64 %r174,%r166,24; .loc 1 254 0 mov.u32 %r116,0; bra $L58; $L100: mov.u32 %r116,0; $L58: .loc 1 276 0 ld.u32 %r417,[%r242+8]; setp.ge.s32 %r418,%r417,%r175; @ %r418 bra $L59; $L60: .loc 1 278 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r166; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 279 0 mov.u64 %r421,0; st.u64 [%r244],%r421; .loc 1 280 0 mov.u32 %r239,163; bra $L14; $L59: .loc 1 283 0 ld.u32 %r129,[%r242+4]; setp.le.s32 %r422,%r129,%r175; @ %r422 bra $L101; .loc 1 285 0 sub.u32 %r191,%r129,%r175; .loc 1 286 0 setp.gt.s32 %r423,%r170,%r191; @ %r423 bra $L62; .loc 1 287 0 ld.u32 %r424,[%r242+12]; setp.eq.u32 %r425,%r424,2; @ %r425 bra $L64; setp.eq.u32 %r426,%r424,3; @ %r426 bra $L65; setp.eq.u32 %r427,%r424,1; @ ! %r427 bra $L63; .loc 1 289 0 setp.eq.u32 %r428,%r170,%r191; @ ! %r428 bra $L63; setp.le.s32 %r429,%r170,1; @ %r429 bra $L68; add.u32 %r432,%r170,-1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r432; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r433,[%value_in]; } setp.eq.u32 %r434,%r433,0; @ %r434 bra $L63; ld.u32 %r129,[%r242+4]; bra $L68; $L64: .loc 1 293 0 setp.eq.u32 %r435,%r245,0; @ %r435 bra $L68; bra $L63; $L65: .loc 1 297 0 setp.eq.u32 %r436,%r245,0; @ %r436 bra $L63; $L68: .loc 1 299 0 st.u32 [%r243],%r129; .loc 1 300 0 mov.u32 %r437,1; st.u32 [%r166+20],%r437; st.u32 [%r174],%r437; .loc 1 301 0 st.u64 [%r244],%r166; .loc 1 302 0 mov.u32 %r239,98; bra $L14; $L63: .loc 1 306 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r166; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 307 0 mov.u64 %r441,0; st.u64 [%r244],%r441; .loc 1 308 0 mov.u32 %r239,80; bra $L14; $L62: .loc 1 310 0 add.u32 %r192,%r191,-1; .loc 1 311 0 setp.ne.u32 %r442,%r116,0; @ %r442 bra $L102; .loc 1 313 0 setp.eq.u32 %r443,%r192,0; @ %r443 bra $L70; .loc 1 314 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r192; call (%value_in),__any_on,(%out_arg1,%out_arg2); ld.param.u32 %r446,[%value_in]; } mov.u32 %r116,%r446; bra $L70; $L102: .loc 1 312 0 mov.u32 %r116,1; $L70: .loc 1 315 0 shr.s32 %r447,%r192,5; cvt.s64.s32 %r448,%r447; shl.b64 %r449,%r448,2; add.u64 %r450,%r174,%r449; and.b32 %r451,%r192,31; mov.u32 %r453,1; shl.b32 %r452,%r453,%r451; ld.u32 %r455,[%r450]; and.b32 %r454,%r452,%r455; setp.eq.u32 %r456,%r454,0; @ %r456 bra $L71; .loc 1 316 0 or.b32 %r116,%r116,2; $L71: .loc 1 317 0 sub.u32 %r170,%r170,%r191; .loc 1 318 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r191; call rshift,(%out_arg1,%out_arg2); } .loc 1 319 0 ld.u32 %r175,[%r242+4]; .loc 1 284 0 mov.u32 %r239,2; bra $L61; $L101: .loc 1 282 0 mov.u32 %r239,1; $L61: .loc 1 321 0 setp.eq.u32 %r459,%r116,0; @ %r459 bra $L72; .loc 1 323 0 ld.u32 %r460,[%r242+12]; setp.eq.u32 %r461,%r460,2; @ %r461 bra $L74; setp.eq.u32 %r462,%r460,3; @ %r462 bra $L75; setp.eq.u32 %r463,%r460,1; @ ! %r463 bra $L73; .loc 1 327 0 and.b32 %r464,%r116,2; setp.eq.u32 %r465,%r464,0; @ %r465 bra $L73; .loc 1 328 0 ld.u32 %r467,[%r174]; or.b32 %r466,%r116,%r467; and.b32 %r468,%r466,1; setp.ne.u32 %r469,%r468,0; @ %r469 bra $L77; bra $L73; $L74: .loc 1 332 0 mov.u32 %r470,1; sub.u32 %r245,%r470,%r245; $L75: .loc 1 337 0 setp.eq.u32 %r471,%r245,0; @ %r471 bra $L73; $L77: .loc 1 338 0 ld.u32 %r193,[%r166+20]; .loc 1 114 0 add.u64 %r198,%r166,24; .loc 1 115 0 cvt.s64.s32 %r472,%r193; shl.b64 %r201,%r472,2; add.u64 %r202,%r198,%r201; mov.u64 %r172,%r198; .loc 1 122 0 mov.u32 %r535,0; $L80: .loc 1 118 0 ld.u32 %r204,[%r172]; setp.eq.u32 %r473,%r204,-1; @ %r473 bra $L78; .loc 1 119 0 add.u32 %r474,%r204,1; st.u32 [%r172],%r474; bra $L79; $L78: .loc 1 122 0 st.u32 [%r172],%r535; add.u64 %r172,%r172,4; .loc 1 123 0 setp.gt.u64 %r476,%r202,%r172; @ %r476 bra $L80; .loc 1 135 0 ld.u32 %r206,[%r166+20]; ld.u32 %r477,[%r166+12]; setp.lt.s32 %r478,%r206,%r477; @ %r478 bra $L81; .loc 1 136 0 ld.u32 %r482,[%r166+8]; add.u32 %r481,%r482,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r481; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r483,[%value_in]; } .loc 1 137 0 ld.s32 %r487,[%r166+20]; add.u64 %r488,%r487,2; shl.b64 %r489,%r488,2; add.u64 %r490,%r166,16; add.u64 %r491,%r483,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r491; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r490; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r489; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r492,[%value_in]; } .loc 1 138 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r240; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r166; call _Bfree,(%out_arg1,%out_arg2); } ld.u32 %r206,[%r483+20]; add.u64 %r198,%r483,24; mov.u64 %r166,%r483; $L81: .loc 1 141 0 add.u32 %r495,%r206,1; st.u32 [%r166+20],%r495; cvt.s64.s32 %r496,%r206; add.u64 %r497,%r496,6; shl.b64 %r498,%r497,2; add.u64 %r499,%r166,%r498; mov.u32 %r500,1; st.u32 [%r499],%r500; $L79: .loc 1 341 0 setp.ne.u32 %r501,%r239,2; @ %r501 bra $L82; .loc 1 342 0 ld.u32 %r503,[%r242]; add.u32 %r502,%r503,-1; setp.ne.u32 %r504,%r502,%r170; @ %r504 bra $L103; .loc 1 343 0 shr.s32 %r505,%r170,5; cvt.s64.s32 %r506,%r505; shl.b64 %r507,%r506,2; add.u64 %r508,%r198,%r507; and.b32 %r509,%r170,31; mov.u32 %r511,1; shl.b32 %r510,%r511,%r509; ld.u32 %r513,[%r508]; and.b32 %r512,%r510,%r513; setp.ne.u32 %r514,%r512,0; selp.u32 %r239,33,34,%r514; bra $L72; $L82: .loc 1 346 0 ld.u32 %r515,[%r166+20]; setp.le.s32 %r516,%r515,%r193; @ %r516 bra $L84; $L85: .loc 1 349 0 mov.u32 %r518,1; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r166; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r518; call rshift,(%out_arg1,%out_arg2); } .loc 1 350 0 add.u32 %r175,%r175,1; ld.u32 %r519,[%r242+8]; setp.lt.s32 %r520,%r519,%r175; @ %r520 bra $L60; mov.u32 %r239,33; bra $L72; $L84: .loc 1 347 0 and.b32 %r194,%r170,31; setp.eq.u32 %r521,%r194,0; @ %r521 bra $L105; .loc 1 348 0 add.u64 %r523,%r198,%r201; ld.u32 %r522,[%r523+-4]; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r522; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r525,[%value_in]; } mov.u32 %r527,32; sub.u32 %r526,%r527,%r194; setp.lt.s32 %r528,%r525,%r526; @ %r528 bra $L85; mov.u32 %r239,33; bra $L72; $L103: mov.u32 %r239,34; bra $L72; $L105: mov.u32 %r239,33; bra $L72; $L73: .loc 1 356 0 or.b32 %r239,%r239,16; $L72: .loc 1 358 0 st.u64 [%r244],%r166; .loc 1 359 0 st.u32 [%r243],%r175; .loc 1 360 0 bra $L14; $L171: .loc 1 225 0 st.u64 [%r241],%r76; bra $L87; $L19: ld.u8 %r73,[%r223]; .loc 1 177 0 mov.u64 %r76,%r223; $L20: .loc 1 203 0 cvt.u16.u32 %r530,%r73; setp.eq.u16 %r531,%r530,80; @ %r531 bra $L106; setp.eq.u16 %r533,%r530,112; @ ! %r533 bra $L171; bra $L106; $L90: .loc 1 196 0 mov.u64 %r181,%r76; bra $L28; $L14: .loc 1 361 0 mov.u32 %value,%r239; st.param.u32 [%value_out],%value; ret; } /62 0 0 0 644 7400 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __hexnan .visible .func (.param .u32 %value_out) __hexnan (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/stdlib/gdtoa-hexnan.c" // BEGIN GLOBAL VAR DECL: __hexdig .extern .const .align 1 .u8 __hexdig[256]; // BEGIN GLOBAL FUNCTION DEF: __hexnan .visible .func (.param .u32 %value_out) __hexnan (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r85; .reg .u64 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u64 %r99; .reg .u64 %r100; .reg .u32 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u32 %r106; .reg .u64 %r108; .reg .u32 %r109; .reg .u64 %r112; .reg .u32 %r113; .reg .u32 %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .u32 %r118; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u32 %r127; .reg .u32 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u32 %r140; .reg .u32 %r141; .reg .u64 %r142; .reg .u64 %r143; .reg .u64 %r144; .reg .u32 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u32 %r149; .reg .u64 %r151; .reg .u64 %r152; .reg .pred %r153; .reg .pred %r154; .reg .pred %r155; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r160; .reg .u32 %r161; .reg .u16 %r162; .reg .u16 %r163; .reg .u16 %r164; .reg .u32 %r165; .reg .u16 %r166; .reg .pred %r167; .reg .u32 %r169; .reg .u32 %r170; .reg .u32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .pred %r175; .reg .u64 %r176; .reg .pred %r177; .reg .u32 %r178; .reg .pred %r179; .reg .u16 %r181; .reg .u16 %r182; .reg .u32 %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .pred %r186; .reg .pred %r187; .reg .u32 %r189; .reg .u32 %r190; .reg .u32 %r192; .reg .u32 %r193; .reg .u16 %r194; .reg .u16 %r195; .reg .u16 %r196; .reg .u32 %r197; .reg .u16 %r198; .reg .pred %r199; .reg .u32 %r200; .reg .u32 %r201; .reg .u32 %r202; .reg .u32 %r203; .reg .pred %r204; .reg .pred %r205; .reg .pred %r206; .reg .u32 %r207; .reg .pred %r208; .reg .u32 %r210; .reg .u32 %r211; .reg .u32 %r212; .reg .u32 %r213; .reg .pred %r214; .reg .pred %r215; .reg .pred %r216; .reg .u32 %r217; .reg .u32 %r218; .reg .pred %r219; .reg .pred %r221; .reg .u64 %r222; .reg .u32 %r223; .reg .u32 %r225; mov.u64 %r142,%ar0; mov.u64 %r143,%ar1; mov.u64 %r144,%ar2; .loc 1 74 0 ld.u32 %r106,[%r143]; .loc 1 75 0 shr.s32 %r145,%r106,5; cvt.s64.s32 %r146,%r145; shl.b64 %r147,%r146,2; add.u64 %r99,%r144,%r147; .loc 1 76 0 and.b32 %r79,%r106,31; setp.eq.u32 %r221,%r79,0; @ %r221 bra $L2; .loc 1 77 0 add.u64 %r99,%r99,4; $L2: .loc 1 78 0 add.u64 %r112,%r99,-4; mov.u32 %r149,0; st.u32 [%r99+-4],%r149; .loc 1 81 0 ld.u64 %r103,[%r142]; .loc 1 78 0 mov.u64 %r102,%r112; mov.u64 %r100,%r112; .loc 1 80 0 mov.u32 %r105,%r149; mov.u32 %r104,%r149; mov.u32 %r101,%r149; .loc 1 83 0 cvta.const.u64 %r222,__hexdig; .loc 1 110 0 mov.u32 %r223,%r149; .loc 1 55 0 mov.u32 %r225,8; .loc 1 82 0 bra $L3; $L14: .loc 1 83 0 cvt.u64.u32 %r151,%r109; add.u64 %r152,%r222,%r151; ld.u8 %r80,[%r152]; setp.ne.u32 %r153,%r80,0; @ %r153 bra $L4; .loc 1 84 0 setp.gt.u32 %r154,%r109,32; @ %r154 bra $L5; .loc 1 85 0 setp.le.s32 %r155,%r101,%r104; @ %r155 bra $L6; .loc 1 86 0 set.u32.lt.u64 %r157,%r100,%r102; neg.s32 %r158,%r157; set.u32.le.s32 %r160,%r105,7; neg.s32 %r161,%r160; cvt.u16.u32 %r163,%r158; cvt.u16.u32 %r164,%r161; and.b16 %r162,%r163,%r164; cvt.u32.u16 %r165,%r162; cvt.u16.u8 %r166,%r165; setp.eq.u16 %r167,%r166,0; @ %r167 bra $L7; .loc 1 55 0 sub.u32 %r113,%r225,%r105; .loc 1 56 0 shl.b32 %r114,%r113,2; .loc 1 57 0 mov.u32 %r169,32; sub.u32 %r115,%r169,%r114; ld.u32 %r121,[%r100]; add.u64 %r132,%r100,4; mov.u64 %r116,%r100; $L8: .loc 1 59 0 ld.u32 %r118,[%r132]; shl.b32 %r170,%r118,%r115; or.b32 %r171,%r170,%r121; st.u32 [%r116],%r171; .loc 1 60 0 shr.u32 %r121,%r118,%r114; st.u32 [%r132],%r121; .loc 1 61 0 add.u64 %r116,%r116,4; add.u64 %r132,%r132,4; setp.gt.u64 %r172,%r102,%r116; @ %r172 bra $L8; $L7: .loc 1 88 0 setp.le.u64 %r173,%r100,%r144; @ %r173 bra $L25; .loc 1 93 0 add.u64 %r102,%r100,-4; st.u32 [%r100+-4],%r223; mov.u32 %r104,%r101; mov.u64 %r100,%r102; .loc 1 95 0 mov.u32 %r105,0; bra $L6; $L5: .loc 1 99 0 setp.eq.u32 %r175,%r109,41; @ %r175 bra $L9; $L15: .loc 1 103 0 mov.u32 %r141,4; bra $L1; $L9: .loc 1 100 0 add.u64 %r176,%r103,2; st.u64 [%r142],%r176; .loc 1 101 0 bra $L11; $L4: .loc 1 105 0 add.u32 %r101,%r101,1; .loc 1 106 0 add.u32 %r105,%r105,1; setp.gt.s32 %r177,%r105,8; @ %r177 bra $L12; ld.u32 %r178,[%r100]; shl.b32 %r140,%r178,4; bra $L13; $L12: .loc 1 107 0 setp.le.u64 %r179,%r100,%r144; @ %r179 bra $L6; .loc 1 110 0 st.u32 [%r100+-4],%r223; add.u64 %r100,%r100,-4; mov.u32 %r140,%r149; .loc 1 109 0 mov.u32 %r105,1; $L13: .loc 1 112 0 cvt.u16.u32 %r182,%r80; and.b16 %r181,%r182,15; cvt.u32.u16 %r184,%r181; cvt.u32.u8 %r183,%r184; or.b32 %r185,%r183,%r140; st.u32 [%r100],%r185; bra $L6; $L25: .loc 1 89 0 mov.u32 %r105,8; $L6: .loc 1 95 0 mov.u64 %r103,%r108; $L3: .loc 1 82 0 add.u64 %r108,%r103,1; ld.u8 %r109,[%r108]; setp.ne.u32 %r186,%r109,0; @ %r186 bra $L14; $L11: .loc 1 114 0 setp.eq.u32 %r187,%r101,0; @ %r187 bra $L15; .loc 1 116 0 set.u32.lt.u64 %r189,%r100,%r102; neg.s32 %r190,%r189; set.u32.le.s32 %r192,%r105,7; neg.s32 %r193,%r192; cvt.u16.u32 %r195,%r190; cvt.u16.u32 %r196,%r193; and.b16 %r194,%r195,%r196; cvt.u32.u16 %r197,%r194; cvt.u16.u8 %r198,%r197; setp.eq.u16 %r199,%r198,0; @ %r199 bra $L16; .loc 1 55 0 mov.u32 %r200,8; sub.u32 %r122,%r200,%r105; .loc 1 56 0 shl.b32 %r123,%r122,2; .loc 1 57 0 mov.u32 %r201,32; sub.u32 %r124,%r201,%r123; ld.u32 %r130,[%r100]; add.u64 %r131,%r100,4; mov.u64 %r125,%r100; $L17: .loc 1 59 0 ld.u32 %r127,[%r131]; shl.b32 %r202,%r127,%r124; or.b32 %r203,%r202,%r130; st.u32 [%r125],%r203; .loc 1 60 0 shr.u32 %r130,%r127,%r123; st.u32 [%r131],%r130; .loc 1 61 0 add.u64 %r125,%r125,4; add.u64 %r131,%r131,4; setp.gt.u64 %r204,%r102,%r125; @ %r204 bra $L17; $L16: .loc 1 118 0 setp.le.u64 %r205,%r100,%r144; @ %r205 bra $L18; mov.u64 %r126,%r100; mov.u64 %r85,%r144; $L19: add.u64 %r93,%r85,4; .loc 1 120 0 ld.u32 %r94,[%r126]; st.u32 [%r85],%r94; add.u64 %r126,%r126,4; mov.u64 %r85,%r93; .loc 1 121 0 setp.ge.u64 %r206,%r112,%r126; @ %r206 bra $L19; .loc 1 122 0 mov.u32 %r207,0; $L20: st.u32 [%r93],%r207; add.u64 %r93,%r93,4; .loc 1 123 0 setp.ge.u64 %r208,%r112,%r93; @ %r208 bra $L20; ld.u32 %r95,[%r99+-4]; bra $L21; $L18: ld.u32 %r95,[%r99+-4]; .loc 1 127 0 @ %r221 bra $L21; .loc 1 128 0 mov.u32 %r211,32; sub.u32 %r210,%r211,%r79; mov.u32 %r213,-1; shr.u32 %r212,%r213,%r210; and.b32 %r95,%r95,%r212; st.u32 [%r99+-4],%r95; $L21: .loc 1 131 0 setp.ne.u32 %r214,%r95,0; @ %r214 bra $L26; .loc 1 133 0 setp.eq.u64 %r215,%r144,%r112; @ ! %r215 bra $L23; bra $L22; $L24: setp.ne.u64 %r216,%r144,%r112; @ %r216 bra $L23; $L22: .loc 1 134 0 mov.u32 %r217,1; st.u32 [%r144],%r217; .loc 1 138 0 mov.u32 %r141,5; .loc 1 135 0 bra $L1; $L23: .loc 1 130 0 add.u64 %r112,%r112,-4; .loc 1 131 0 ld.u32 %r218,[%r112]; setp.eq.u32 %r219,%r218,0; @ %r219 bra $L24; .loc 1 138 0 mov.u32 %r141,5; bra $L1; $L26: mov.u32 %r141,5; $L1: .loc 1 139 0 mov.u32 %value,%r141; st.param.u32 [%value_out],%value; ret; } lib_a-impure.o/ 0 0 0 644 823 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN VAR DEF: impure_data .global .align 8 .u64 impure_data[233] = {0,0,0,0,0,0,0,0,0,generic($LC0),0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,-1842796655094713586,47245025004,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: _global_impure_ptr .visible .const .align 8 .u64 _global_impure_ptr[1] = {generic(impure_data) }; // BEGIN GLOBAL VAR DEF: _impure_ptr .visible .global .align 8 .u64 _impure_ptr[1] = {generic(impure_data) }; lib_a-index.o/ 0 0 0 644 1008 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: index .visible .func (.param .u64 %value_out) index (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/string/index.c" // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: index .visible .func (.param .u64 %value_out) index (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u64 %r27; mov.u64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 44 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r27,[%value_in]; } .loc 1 45 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } lib_a-isalnum.o/0 0 0 644 908 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isalnum .visible .func (.param .u32 %value_out) isalnum (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isalnum.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isalnum .visible .func (.param .u32 %value_out) isalnum (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 44 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,7; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 45 0 st.param.u32 [%value_out],%value; ret; } lib_a-isalpha.o/0 0 0 644 908 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isalpha .visible .func (.param .u32 %value_out) isalpha (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isalpha.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isalpha .visible .func (.param .u32 %value_out) isalpha (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 42 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,3; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-iscntrl.o/0 0 0 644 909 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: iscntrl .visible .func (.param .u32 %value_out) iscntrl (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/iscntrl.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: iscntrl .visible .func (.param .u32 %value_out) iscntrl (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 45 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,32; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 46 0 st.param.u32 [%value_out],%value; ret; } lib_a-isdigit.o/0 0 0 644 908 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isdigit .visible .func (.param .u32 %value_out) isdigit (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isdigit.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isdigit .visible .func (.param .u32 %value_out) isdigit (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 42 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,4; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-islower.o/0 0 0 644 1026 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: islower .visible .func (.param .u32 %value_out) islower (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/islower.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: islower .visible .func (.param .u32 %value_out) islower (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u16 %r45; mov.u32 %r30,%ar0; .loc 1 42 0 cvt.s64.s32 %r32,%r30; ld.global.u64 %r33,[__ctype_ptr__]; add.u64 %r34,%r33,%r32; ld.u8 %r45,[%r34+1]; mov.u16 %r38,%r45; and.b16 %r37,%r38,3; cvt.u32.u16 %r42,%r37; cvt.s32.s8 %r41,%r42; cvt.u16.u32 %r40,%r41; set.u32.eq.u16 %r43,%r40,2; neg.s32 %value,%r43; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-isprint.o/0 0 0 644 1485 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isgraph .visible .func (.param .u32 %value_out) isgraph (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isprint.c" // BEGIN GLOBAL FUNCTION DECL: isprint .visible .func (.param .u32 %value_out) isprint (.param .u32 %in_ar0); // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isgraph .visible .func (.param .u32 %value_out) isgraph (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 51 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,23; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 52 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: isprint .visible .func (.param .u32 %value_out) isprint (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r35; mov.u32 %r29,%ar0; .loc 1 59 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.s8 %r35,[%r33+1]; and.b32 %value,%r35,151; .loc 1 60 0 st.param.u32 [%value_out],%value; ret; } lib_a-ispunct.o/0 0 0 644 909 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ispunct .visible .func (.param .u32 %value_out) ispunct (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/ispunct.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: ispunct .visible .func (.param .u32 %value_out) ispunct (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 44 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,16; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 45 0 st.param.u32 [%value_out],%value; ret; } lib_a-isspace.o/0 0 0 644 908 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isspace .visible .func (.param .u32 %value_out) isspace (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isspace.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isspace .visible .func (.param .u32 %value_out) isspace (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 42 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,8; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 43 0 st.param.u32 [%value_out],%value; ret; } lib_a-isupper.o/0 0 0 644 1026 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isupper .visible .func (.param .u32 %value_out) isupper (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isupper.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isupper .visible .func (.param .u32 %value_out) isupper (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r30; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u16 %r45; mov.u32 %r30,%ar0; .loc 1 41 0 cvt.s64.s32 %r32,%r30; ld.global.u64 %r33,[__ctype_ptr__]; add.u64 %r34,%r33,%r32; ld.u8 %r45,[%r34+1]; mov.u16 %r38,%r45; and.b16 %r37,%r38,3; cvt.u32.u16 %r42,%r37; cvt.s32.s8 %r41,%r42; cvt.u16.u32 %r40,%r41; set.u32.eq.u16 %r43,%r40,1; neg.s32 %value,%r43; .loc 1 42 0 st.param.u32 [%value_out],%value; ret; } /84 0 0 0 644 914 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isxdigit .visible .func (.param .u32 %value_out) isxdigit (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/isxdigit.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: isxdigit .visible .func (.param .u32 %value_out) isxdigit (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u16 %r39; mov.u32 %r29,%ar0; .loc 1 43 0 cvt.s64.s32 %r31,%r29; ld.global.u64 %r32,[__ctype_ptr__]; add.u64 %r33,%r32,%r31; ld.u8 %r39,[%r33+1]; mov.u16 %r37,%r39; and.b16 %r36,%r37,68; cvt.u32.u16 %r38,%r36; cvt.s32.s8 %value,%r38; .loc 1 44 0 st.param.u32 [%value_out],%value; ret; } lib_a-jrand48.o/0 0 0 644 1886 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _jrand48_r .visible .func (.param .u64 %value_out) _jrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/jrand48.c" // BEGIN GLOBAL FUNCTION DECL: jrand48 .visible .func (.param .u64 %value_out) jrand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _jrand48_r .visible .func (.param .u64 %value_out) _jrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; mov.u64 %r28,%ar0; mov.u64 %r29,%ar1; .loc 1 21 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r29; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r33,[%r29+4]; shl.b64 %r34,%r33,16; ld.u16 %r35,[%r29+2]; add.u64 %value,%r34,%r35; .loc 1 23 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: jrand48 .visible .func (.param .u64 %value_out) jrand48 (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r29; .reg .u64 %r32; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; mov.u64 %r29,%ar0; .loc 1 21 0 ld.global.u64 %r32,[_impure_ptr]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r29; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r34,[%r29+4]; shl.b64 %r35,%r34,16; ld.u16 %r36,[%r29+2]; add.u64 %value,%r35,%r36; .loc 1 31 0 st.param.u64 [%value_out],%value; ret; } lib_a-l64a.o/ 0 0 0 644 3940 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: l64a .visible .func (.param .u64 %value_out) l64a (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/l64a.c" // BEGIN GLOBAL FUNCTION DECL: _l64a_r .visible .func (.param .u64 %value_out) _l64a_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN VAR DEF: R64_ARRAY .const .align 1 .u8 R64_ARRAY[65] = {46,47,48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,0 }; // BEGIN GLOBAL FUNCTION DEF: l64a .visible .func (.param .u64 %value_out) l64a (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r65; .reg .u64 %r67; .reg .u64 %r68; .reg .u64 %r72; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .pred %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .pred %r96; .reg .u64 %r98; mov.u64 %r80,%ar0; .loc 1 33 0 ld.global.u64 %r65,[_impure_ptr]; .loc 1 44 0 and.b64 %r67,%r80,4294967295; .loc 1 47 0 add.u64 %r79,%r65,280; .loc 1 52 0 setp.eq.u64 %r81,%r67,0; @ %r81 bra $L6; .loc 1 59 0 cvta.const.u64 %r98,R64_ARRAY; .loc 1 58 0 cvt.u32.u64 %r84,%r80; and.b32 %r83,%r84,63; .loc 1 59 0 cvt.s64.s32 %r85,%r83; add.u64 %r86,%r98,%r85; ld.u8 %r87,[%r86]; st.u8 [%r65+280],%r87; .loc 1 60 0 shr.u64 %r72,%r67,6; .loc 1 59 0 add.u64 %r77,%r65,281; add.u64 %r68,%r65,286; bra $L3; $L6: .loc 1 48 0 mov.u64 %r78,%r79; $L2: .loc 1 54 0 mov.u32 %r88,0; st.u8 [%r78],%r88; bra $L1; $L10: .loc 1 58 0 cvt.u32.u64 %r91,%r72; and.b32 %r90,%r91,63; .loc 1 59 0 cvt.s64.s32 %r92,%r90; add.u64 %r93,%r98,%r92; ld.u8 %r94,[%r93]; st.u8 [%r77],%r94; .loc 1 60 0 shr.u64 %r72,%r72,6; add.u64 %r77,%r77,1; .loc 1 50 0 setp.eq.u64 %r95,%r68,%r77; @ %r95 bra $L1; $L3: mov.u64 %r78,%r77; .loc 1 52 0 setp.eq.u64 %r96,%r72,0; @ ! %r96 bra $L10; bra $L2; $L1: .loc 1 34 0 mov.u64 %value,%r79; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _l64a_r .visible .func (.param .u64 %value_out) _l64a_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r40; .reg .u64 %r42; .reg .u64 %r44; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .pred %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r69; .reg .u64 %r71; mov.u64 %r52,%ar0; mov.u64 %r53,%ar1; .loc 1 44 0 and.b64 %r42,%r53,4294967295; .loc 1 47 0 add.u64 %r51,%r52,280; .loc 1 52 0 setp.eq.u64 %r54,%r42,0; @ %r54 bra $L16; .loc 1 59 0 cvta.const.u64 %r71,R64_ARRAY; .loc 1 58 0 cvt.u32.u64 %r57,%r53; and.b32 %r56,%r57,63; .loc 1 59 0 cvt.s64.s32 %r58,%r56; add.u64 %r59,%r71,%r58; ld.u8 %r60,[%r59]; st.u8 [%r52+280],%r60; .loc 1 60 0 shr.u64 %r44,%r42,6; .loc 1 59 0 add.u64 %r49,%r52,281; add.u64 %r40,%r52,286; bra $L13; $L16: .loc 1 48 0 mov.u64 %r50,%r51; $L12: .loc 1 54 0 mov.u32 %r61,0; st.u8 [%r50],%r61; .loc 1 55 0 bra $L11; $L20: .loc 1 58 0 cvt.u32.u64 %r64,%r44; and.b32 %r63,%r64,63; .loc 1 59 0 cvt.s64.s32 %r65,%r63; add.u64 %r66,%r71,%r65; ld.u8 %r67,[%r66]; st.u8 [%r49],%r67; .loc 1 60 0 shr.u64 %r44,%r44,6; add.u64 %r49,%r49,1; .loc 1 50 0 setp.eq.u64 %r68,%r40,%r49; @ %r68 bra $L11; $L13: mov.u64 %r50,%r49; .loc 1 52 0 setp.eq.u64 %r69,%r44,0; @ ! %r69 bra $L20; bra $L12; $L11: .loc 1 64 0 mov.u64 %value,%r51; st.param.u64 [%value_out],%value; ret; } lib_a-labs.o/ 0 0 0 644 524 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: labs .visible .func (.param .u64 %value_out) labs (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/labs.c" // BEGIN GLOBAL FUNCTION DEF: labs .visible .func (.param .u64 %value_out) labs (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; mov.u64 %r23,%ar0; .loc 1 48 0 abs.s64 %value,%r23; .loc 1 49 0 st.param.u64 [%value_out],%value; ret; } lib_a-lcong48.o/0 0 0 644 1989 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _lcong48_r .visible .func _lcong48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/lcong48.c" // BEGIN GLOBAL FUNCTION DECL: lcong48 .visible .func lcong48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: _lcong48_r .visible .func _lcong48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r29; .reg .u64 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; .reg .u16 %r34; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; mov.u64 %r29,%ar0; mov.u64 %r30,%ar1; .loc 1 22 0 ld.u16 %r31,[%r30]; st.u16 [%r29+240],%r31; .loc 1 23 0 ld.u16 %r32,[%r30+2]; st.u16 [%r29+242],%r32; .loc 1 24 0 ld.u16 %r33,[%r30+4]; st.u16 [%r29+244],%r33; .loc 1 25 0 ld.u16 %r34,[%r30+6]; st.u16 [%r29+246],%r34; .loc 1 26 0 ld.u16 %r35,[%r30+8]; st.u16 [%r29+248],%r35; .loc 1 27 0 ld.u16 %r36,[%r30+10]; st.u16 [%r29+250],%r36; .loc 1 28 0 ld.u16 %r37,[%r30+12]; st.u16 [%r29+252],%r37; .loc 1 29 0 ret; } // BEGIN GLOBAL FUNCTION DEF: lcong48 .visible .func lcong48 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u64 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; .reg .u16 %r34; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; mov.u64 %r30,%ar0; .loc 1 36 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 22 0 ld.u16 %r31,[%r30]; st.u16 [%r22+240],%r31; .loc 1 23 0 ld.u16 %r32,[%r30+2]; st.u16 [%r22+242],%r32; .loc 1 24 0 ld.u16 %r33,[%r30+4]; st.u16 [%r22+244],%r33; .loc 1 25 0 ld.u16 %r34,[%r30+6]; st.u16 [%r22+246],%r34; .loc 1 26 0 ld.u16 %r35,[%r30+8]; st.u16 [%r22+248],%r35; .loc 1 27 0 ld.u16 %r36,[%r30+10]; st.u16 [%r22+250],%r36; .loc 1 28 0 ld.u16 %r37,[%r30+12]; st.u16 [%r22+252],%r37; .loc 1 37 0 ret; } lib_a-lctype.o/ 0 0 0 644 3343 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __ctype_load_locale .visible .func (.param .u32 %value_out) __ctype_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../../newlib/libc/locale/lctype.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_ctype_locale .visible .func (.param .u64 %value_out) __get_current_ctype_locale; // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {65,83,67,73,73,0 }; // BEGIN VAR DEF: _ctype_using_locale .global .align 4 .u32 _ctype_using_locale[1]; // BEGIN VAR DEF: _ctype_locale .global .align 8 .u64 _ctype_locale[2]; // BEGIN VAR DEF: numone .global .align 1 .u8 numone[2] = {1,0 }; // BEGIN VAR DEF: _C_ctype_locale .const .align 8 .u64 _C_ctype_locale[2] = {generic($LC1),generic(numone) }; // BEGIN VAR DEF: _ctype_locale_buf .global .align 1 .u8 _ctype_locale_buf[34]; // BEGIN GLOBAL FUNCTION DEF: __ctype_load_locale .visible .func (.param .u32 %value_out) __ctype_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %r26; .reg .u64 %r28; .reg .u32 %r29; .reg .u64 %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u64 %r35; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r41; .reg .u64 %r43; .reg .u32 %r44; mov.u64 %r26,%ar0; mov.u64 %r28,%ar2; mov.u32 %r29,%ar3; .loc 1 81 0 cvta.const.u64 %r31,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r32,[%value_in]; } setp.ne.u32 %r33,%r32,0; @ %r33 bra $L2; .loc 1 82 0 st.global.u32 [_ctype_using_locale],%r32; bra $L3; $L2: .loc 1 85 0 cvta.global.u64 %r35,_ctype_locale_buf; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r35; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r28; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r37,[%value_in]; } cvta.global.u64 %r38,_ctype_locale; st.u64 [%r38],%r37; .loc 1 87 0 st.u8 [%r35+32],%r29; .loc 1 88 0 mov.u32 %r41,0; st.u8 [%r35+33],%r41; .loc 1 89 0 add.u64 %r43,%r35,32; st.u64 [%r38+8],%r43; .loc 1 90 0 mov.u32 %r44,1; st.global.u32 [_ctype_using_locale],%r44; $L3: .loc 1 102 0 mov.u32 %value,0; .loc 1 103 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_ctype_locale .visible .func (.param .u64 %value_out) __get_current_ctype_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 110 0 ld.global.u32 %r24,[_ctype_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L6; cvta.const.u64 %r23,_C_ctype_locale; bra $L4; $L6: cvta.global.u64 %r23,_ctype_locale; $L4: .loc 1 111 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-ldiv.o/ 0 0 0 644 1155 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldiv .visible .func ldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/stdlib/ldiv.c" // BEGIN GLOBAL FUNCTION DEF: ldiv .visible .func ldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 98 0 div.s64 %r22,%r25,%r26; .loc 1 99 0 rem.s64 %r23,%r25,%r26; .loc 1 100 0 setp.lt.s64 %r27,%r25,0; @ %r27 bra $L2; setp.ge.s64 %r28,%r23,0; @ %r28 bra $L3; .loc 1 101 0 add.u64 %r22,%r22,1; .loc 1 102 0 sub.u64 %r23,%r23,%r26; bra $L3; $L2: .loc 1 104 0 setp.le.s64 %r29,%r23,0; @ %r29 bra $L3; .loc 1 105 0 add.u64 %r22,%r22,-1; .loc 1 106 0 add.u64 %r23,%r23,%r26; $L3: .loc 1 108 0 st.u64 [%r24],%r22; st.u64 [%r24+8],%r23; .loc 1 109 0 ret; } lib_a-ldpart.o/ 0 0 0 644 13325 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .visible .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); .file 1 "../../../../../../newlib/libc/locale/ldpart.c" // BEGIN GLOBAL VAR DECL: _PathLocale .extern .global .align 8 .u64 _PathLocale[1]; // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcat .extern .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: open .extern .func (.param .u32 %value_out) open (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: fstat .extern .func (.param .u32 %value_out) fstat (.param .u32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __nvptx_realloc .extern .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: read .extern .func (.param .u32 %value_out) read (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: close .extern .func (.param .u32 %value_out) close (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: num_lines$2134 .global .align 4 .u32 num_lines$2134[1]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {80,79,83,73,88,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[2] = {47,0 }; // BEGIN VAR DEF: locale_buf_C$2133 .global .align 1 .u8 locale_buf_C$2133[2] = {67,0 }; // BEGIN GLOBAL FUNCTION DEF: __part_load_locale .visible .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %ar5; ld.param.u32 %ar5,[%in_ar5]; .reg .u64 %ar6; ld.param.u64 %ar6,[%in_ar6]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,1128; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r54; .reg .u64 %r56; .reg .u64 %r59; .reg .u64 %r63; .reg .u32 %r74; .reg .u64 %r76; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r84; .reg .u32 %r85; .reg .u64 %r88; .reg .u64 %r91; .reg .u64 %r93; .reg .u32 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r110; .reg .u32 %r111; .reg .pred %r112; .reg .u64 %r114; .reg .u32 %r115; .reg .pred %r116; .reg .pred %r117; .reg .u32 %r120; .reg .pred %r121; .reg .pred %r122; .reg .u32 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u32 %r131; .reg .u64 %r133; .reg .pred %r134; .reg .u64 %r137; .reg .u64 %r139; .reg .u64 %r140; .reg .u64 %r143; .reg .u64 %r146; .reg .u64 %r149; .reg .u32 %r151; .reg .u32 %r152; .reg .pred %r154; .reg .u64 %r157; .reg .u32 %r158; .reg .pred %r159; .reg .pred %r160; .reg .u64 %r161; .reg .u32 %r163; .reg .u32 %r164; .reg .u64 %r166; .reg .u32 %r167; .reg .u32 %r168; .reg .u16 %r169; .reg .u16 %r170; .reg .u16 %r171; .reg .u32 %r172; .reg .u16 %r173; .reg .pred %r174; .reg .u64 %r176; .reg .pred %r177; .reg .u64 %r180; .reg .pred %r181; .reg .u64 %r185; .reg .u32 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .pred %r192; .reg .u32 %r194; .reg .pred %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u32 %r198; .reg .u16 %r199; .reg .u32 %r200; .reg .pred %r201; .reg .pred %r202; .reg .u32 %r204; .reg .u64 %r205; .reg .u32 %r206; .reg .pred %r207; .reg .pred %r208; .reg .pred %r209; .reg .pred %r210; .reg .u32 %r211; .reg .u64 %r212; .reg .u64 %r213; .reg .u64 %r214; .reg .u64 %r216; .reg .u64 %r217; .reg .pred %r218; .reg .u32 %r221; mov.u64 %r100,%ar0; mov.u64 %r101,%ar1; mov.u64 %r102,%ar2; mov.u64 %r103,%ar3; mov.u32 %r104,%ar4; mov.u32 %r105,%ar5; mov.u64 %r106,%ar6; .loc 1 70 0 ld.u32 %r74,[%r101]; .loc 1 71 0 mov.u32 %r107,0; st.u32 [%r101],%r107; .loc 1 73 0 setp.eq.u64 %r108,%r100,0; @ %r108 bra $L2; .loc 1 76 0 cvta.const.u64 %r110,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r110; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r111,[%value_in]; } setp.ne.u32 %r112,%r111,0; @ %r112 bra $L3; $L5: .loc 1 77 0 mov.u32 %r99,0; bra $L1; $L3: .loc 1 76 0 cvta.const.u64 %r114,$LC1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r114; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r115,[%value_in]; } setp.eq.u32 %r116,%r115,0; @ %r116 bra $L5; .loc 1 83 0 setp.eq.u64 %r117,%r102,0; @ %r117 bra $L6; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r102; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r120,[%value_in]; } setp.ne.u32 %r121,%r120,0; @ %r121 bra $L6; .loc 1 84 0 ld.global.u32 %r54,[num_lines$2134]; .loc 1 189 0 setp.le.s32 %r122,%r54,0; @ %r122 bra $L7; add.u32 %r123,%r54,-1; cvt.u64.u32 %r124,%r123; add.u64 %r125,%r124,1; shl.b64 %r126,%r125,3; add.u64 %r93,%r106,%r126; $L8: .loc 1 190 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r128,[%value_in]; } add.u64 %r129,%r128,1; add.u64 %r102,%r102,%r129; st.u64 [%r106],%r102; .loc 1 189 0 add.u64 %r106,%r106,8; setp.ne.u64 %r130,%r106,%r93; @ %r130 bra $L8; $L7: .loc 1 85 0 mov.u32 %r131,1; st.u32 [%r101],%r131; .loc 1 86 0 mov.u32 %r99,0; bra $L1; $L6: .loc 1 92 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r100; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r133,[%value_in]; } add.u64 %r76,%r133,1; .loc 1 94 0 ld.global.u64 %r56,[_PathLocale]; setp.eq.u64 %r134,%r56,0; @ %r134 bra $L2; .loc 1 97 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r56; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r137,[%value_in]; } .loc 1 98 0 cvta.const.u64 %r139,$LC2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r139; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r140,[%value_in]; } .loc 1 99 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r100; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r143,[%value_in]; } .loc 1 100 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r139; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r146,[%value_in]; } .loc 1 101 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r103; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r149,[%value_in]; } .loc 1 102 0 mov.u32 %r151,0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r151; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),open,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r152,[%value_in]; } .loc 1 103 0 setp.lt.s32 %r154,%r152,0; @ %r154 bra $L2; .loc 1 108 0 add.u64 %r157,%frame,1024; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r157; call (%value_in),fstat,(%out_arg1,%out_arg2); ld.param.u32 %r158,[%value_in]; } setp.ne.u32 %r159,%r158,0; @ %r159 bra $L9; .loc 1 111 0 ld.u64 %r59,[%frame+1040]; setp.le.s64 %r160,%r59,0; @ %r160 bra $L9; .loc 1 113 0 add.u64 %r161,%r59,1; add.u64 %r78,%r161,%r76; .loc 1 116 0 set.u32.eq.u64 %r163,%r102,0; neg.s32 %r164,%r163; cvta.global.u64 %r166,locale_buf_C$2133; set.u32.eq.u64 %r167,%r102,%r166; neg.s32 %r168,%r167; cvt.u16.u32 %r170,%r164; cvt.u16.u32 %r171,%r168; or.b16 %r169,%r170,%r171; cvt.u32.u16 %r172,%r169; cvt.u16.u8 %r173,%r172; setp.eq.u16 %r174,%r173,0; @ %r174 bra $L10; .loc 1 118 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r78; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r176,[%value_in]; } mov.u64 %r88,%r176; .loc 1 128 0 setp.eq.u64 %r177,%r88,0; @ ! %r177 bra $L11; .loc 1 164 0 bra $L9; $L10: .loc 1 122 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r78; call (%value_in),__nvptx_realloc,(%out_arg1,%out_arg2); ld.param.u64 %r180,[%value_in]; } mov.u64 %r88,%r180; .loc 1 123 0 setp.ne.u64 %r181,%r180,0; @ %r181 bra $L11; .loc 1 124 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r102; call __nvptx_free,(%out_arg1); } bra $L9; $L11: .loc 1 130 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r88; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r100; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r185,[%value_in]; } .loc 1 131 0 add.u64 %r84,%r88,%r76; .loc 1 132 0 ld.u64 %r63,[%frame+1040]; add.u64 %r79,%r84,%r63; .loc 1 133 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r84; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r63; call (%value_in),read,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r189,[%value_in]; } cvt.s64.s32 %r190,%r189; ld.u64 %r191,[%frame+1040]; setp.ne.u64 %r192,%r190,%r191; @ %r192 bra $L19; .loc 1 135 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; call (%value_in),close,(%out_arg1); ld.param.u32 %r194,[%value_in]; } setp.ne.u32 %r195,%r194,0; @ %r195 bra $L19; .loc 1 140 0 ld.u64 %r196,[%frame+1040]; add.u64 %r197,%r84,%r196; cvt.u32.u32 %r198,%r194; st.u8 [%r197],%r198; .loc 1 141 0 ld.s8 %r200,[%r79+-1]; cvt.u16.u32 %r199,%r200; setp.ne.u16 %r201,%r199,10; @ %r201 bra $L19; .loc 1 176 0 setp.ge.u64 %r202,%r84,%r79; @ %r202 bra $L20; mov.u32 %r85,%r194; $L14: .loc 1 177 0 mov.u32 %r204,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r84; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r204; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r205,[%value_in]; } .loc 1 178 0 add.u64 %r84,%r205,1; mov.u32 %r206,0; st.u8 [%r205],%r206; .loc 1 176 0 add.u32 %r85,%r85,1; setp.gt.u64 %r207,%r79,%r84; @ %r207 bra $L14; bra $L13; $L20: mov.u32 %r85,%r194; $L13: .loc 1 144 0 setp.gt.s32 %r208,%r104,%r85; @ %r208 bra $L15; .loc 1 145 0 st.global.u32 [num_lines$2134],%r104; bra $L16; $L15: .loc 1 146 0 setp.le.s32 %r209,%r105,%r85; @ %r209 bra $L17; .loc 1 143 0 st.global.u32 [num_lines$2134],%r85; .loc 1 161 0 mov.u32 %r74,%r194; bra $L19; $L17: .loc 1 147 0 st.global.u32 [num_lines$2134],%r105; mov.u32 %r104,%r105; $L16: .loc 1 189 0 setp.le.s32 %r210,%r104,0; @ %r210 bra $L7; add.u32 %r211,%r104,-1; cvt.u64.u32 %r212,%r211; add.u64 %r213,%r212,1; shl.b64 %r214,%r213,3; add.u64 %r91,%r106,%r214; $L18: .loc 1 190 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r88; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r216,[%value_in]; } add.u64 %r217,%r216,1; add.u64 %r88,%r88,%r217; st.u64 [%r106],%r88; .loc 1 189 0 add.u64 %r106,%r106,8; setp.ne.u64 %r218,%r106,%r91; @ %r218 bra $L18; bra $L7; $L12: $L19: .loc 1 163 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r88; call __nvptx_free,(%out_arg1); } $L9: .loc 1 165 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r152; call (%value_in),close,(%out_arg1); ld.param.u32 %r221,[%value_in]; } $L2: .loc 1 167 0 st.u32 [%r101],%r74; .loc 1 168 0 mov.u32 %r99,-1; $L1: .loc 1 169 0 mov.u32 %value,%r99; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-ldtoa.o/ 0 0 0 644 181973 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: eshdn1 .func eshdn1 (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/ldtoa.c" // BEGIN FUNCTION DECL: eshup1 .func eshup1 (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: m16m .func m16m (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: edivm .func (.param .u32 %value_out) edivm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: emulm .func (.param .u32 %value_out) emulm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: eisnan$part$0 .func (.param .u32 %value_out) eisnan$part$0 (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: eneg .func eneg (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: eisneg .func (.param .u32 %value_out) eisneg (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: emovi .func emovi (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: ecmp .func (.param .u32 %value_out) ecmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: eisinf$part$1 .func (.param .u32 %value_out) eisinf$part$1 (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: eshift$part$4 .func (.param .u32 %value_out) eshift$part$4 (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN FUNCTION DECL: enormlz .func (.param .u32 %value_out) enormlz (.param .u64 %in_ar0); // BEGIN FUNCTION DECL: emdnorm .func emdnorm (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5); // BEGIN FUNCTION DECL: eiremain .func eiremain (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: emovo$isra$7 .func emovo$isra$7 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: e53toe$isra$9 .func e53toe$isra$9 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN FUNCTION DECL: emul .func emul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN FUNCTION DECL: ediv .func ediv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _ldtoa_r .visible .func (.param .u64 %value_out) _ldtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: _ldcheck .visible .func (.param .u32 %value_out) _ldcheck (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _strtold .visible .func (.param .f64 %value_out) _strtold (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: sprintf .extern .func (.param .u32 %value_out) sprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: calloc .extern .func (.param .u64 %value_out) calloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: etens .const .align 2 .u16 etens[130] = {25974,19090,32842,5439,51532,38810,35360,20994,50272,29989,27186,52818,12954,10446,42829,24036,50493,15197,40587,23186,21100,20686,61835,15656,25869,3095,33141,30086,51574,19784,40038,22776,48208,23636,52325,37318,42510,41134,58137,18083,34078,60087,39166,36891,56763,56973,40441,60411,43646,17233,565,311,14001,13164,50799,36063,33001,18377,37818,16808,20728,9723,51051,27505,15551,42709,65487,8009,49784,16595,0,0,0,0,61472,46493,11120,44456,40389,16489,0,0,0,0,0,0,1024,51647,36379,16436,0,0,0,0,0,0,0,8192,48828,16409,0,0,0,0,0,0,0,0,40000,16396,0,0,0,0,0,0,0,0,51200,16389,0,0,0,0,0,0,0,0,40960,16386 }; // BEGIN VAR DEF: emtens .const .align 2 .u16 emtens[130] = {8240,53244,41411,33059,11747,40926,53966,1224,42717,2776,33380,53963,62186,4820,18725,11748,13366,21327,52910,9579,62783,63128,27603,344,34726,49341,55895,33445,41638,12981,59185,1236,58354,54066,28978,53788,56099,60978,36937,14682,41534,21256,65275,4437,64145,6457,25466,17189,49201,15532,57965,56286,53341,46070,44156,58528,25788,18044,56784,15957,10784,25124,18355,39127,16163,59813,42297,59943,43135,16170,2907,19186,42369,6381,26590,38074,17721,7853,53169,16276,49009,43443,31113,48744,19502,57691,50253,38078,59029,16329,15693,31805,14010,3371,64962,52988,33889,30481,43980,16356,49493,42152,16462,24851,54211,25899,57881,5976,53687,16369,55050,28835,2621,41943,15728,55050,28835,2621,41943,16376,52429,52428,52428,52428,52428,52428,52428,52428,52428,16379 }; // BEGIN VAR DEF: bmask .const .align 2 .u16 bmask[17] = {65535,65534,65532,65528,65520,65504,65472,65408,65280,65024,64512,63488,61440,57344,49152,32768,0 }; // BEGIN VAR DEF: eone .const .align 2 .u16 eone[10] = {0,0,0,0,0,0,0,0,32768,16383 }; // BEGIN VAR DEF: ezero .const .align 2 .u16 ezero[10]; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {32,78,97,78,32,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[12] = {32,45,73,110,102,105,110,105,116,121,32,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[11] = {32,73,110,102,105,110,105,116,121,32,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {78,97,78,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[4] = {69,37,100,0 }; // BEGIN FUNCTION DEF: eshdn1 .func eshdn1 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r52; .reg .u64 %r55; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u16 %r61; .reg .u16 %r62; .reg .pred %r63; .reg .u16 %r64; .reg .u16 %r65; .reg .u32 %r66; .reg .u16 %r67; .reg .u16 %r68; .reg .u16 %r69; .reg .pred %r70; .reg .u16 %r72; .reg .u16 %r74; .reg .u16 %r75; .reg .pred %r76; mov.u64 %r60,%ar0; .loc 1 778 0 add.u64 %r59,%r60,4; add.u64 %r55,%r60,26; .loc 1 780 0 mov.u32 %r58,0; $L5: .loc 1 783 0 ld.u16 %r52,[%r59]; cvt.u16.u32 %r62,%r52; and.b16 %r61,%r62,1; setp.eq.u16 %r63,%r61,0; @ %r63 bra $L2; .loc 1 784 0 cvt.u16.u32 %r65,%r58; or.b16 %r64,%r65,1; cvt.u32.u16 %r58,%r64; $L2: .loc 1 785 0 shr.u32 %r66,%r52,1; cvt.u16.u32 %r67,%r66; .loc 1 786 0 cvt.u16.u32 %r69,%r58; and.b16 %r68,%r69,2; setp.ne.u16 %r70,%r68,0; @ %r70 bra $L3; .loc 1 785 0 st.u16 [%r59],%r67; bra $L4; $L3: .loc 1 787 0 or.b16 %r72,%r67,-32768; st.u16 [%r59],%r72; $L4: .loc 1 788 0 cvt.u16.u32 %r74,%r58; add.u16 %r75,%r74,%r74; cvt.u32.u16 %r58,%r75; .loc 1 789 0 add.u64 %r59,%r59,2; .loc 1 781 0 setp.ne.u64 %r76,%r55,%r59; @ %r76 bra $L5; .loc 1 791 0 ret; } // BEGIN FUNCTION DEF: eshup1 .func eshup1 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r25; .reg .u64 %r29; .reg .u32 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r34; .reg .pred %r35; .reg .u16 %r36; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u16 %r41; .reg .pred %r42; .reg .u16 %r44; .reg .u16 %r46; .reg .u16 %r47; .reg .pred %r48; mov.u64 %r33,%ar0; .loc 1 804 0 add.u64 %r32,%r33,24; add.u64 %r29,%r33,2; .loc 1 805 0 mov.u32 %r31,0; $L14: .loc 1 809 0 ld.u16 %r25,[%r32]; cvt.u16.u32 %r34,%r25; setp.ge.s16 %r35,%r34,0; @ %r35 bra $L11; .loc 1 810 0 cvt.u16.u32 %r37,%r31; or.b16 %r36,%r37,1; cvt.u32.u16 %r31,%r36; $L11: .loc 1 811 0 cvt.u16.u32 %r38,%r25; add.u16 %r39,%r38,%r38; .loc 1 812 0 cvt.u16.u32 %r41,%r31; and.b16 %r40,%r41,2; setp.ne.u16 %r42,%r40,0; @ %r42 bra $L12; .loc 1 811 0 st.u16 [%r32],%r39; bra $L13; $L12: .loc 1 813 0 or.b16 %r44,%r39,1; st.u16 [%r32],%r44; $L13: .loc 1 814 0 cvt.u16.u32 %r46,%r31; add.u16 %r47,%r46,%r46; cvt.u32.u16 %r31,%r47; .loc 1 815 0 add.u64 %r32,%r32,-2; .loc 1 807 0 setp.ne.u64 %r48,%r29,%r32; @ %r48 bra $L14; .loc 1 817 0 ret; } // BEGIN FUNCTION DEF: m16m .func m16m (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,32; sub.u64 %stack,%frame,0; } .reg .u32 %r34; .reg .u64 %r40; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u16 %r66; .reg .u16 %r67; .reg .pred %r69; .reg .u64 %r71; .reg .u16 %r72; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .pred %r79; .reg .u16 %r80; .reg .pred %r81; .reg .u16 %r82; mov.u32 %r63,%ar0; mov.u64 %r64,%ar1; mov.u64 %r65,%ar2; .loc 1 970 0 cvt.u16.u32 %r66,%r63; cvt.u64.u16 %r52,%r66; .loc 1 972 0 mov.u16 %r67,0; st.u16 [%frame+22],%r67; .loc 1 973 0 st.u16 [%frame+24],%r67; .loc 1 974 0 add.u64 %r57,%r64,24; add.u64 %r58,%r64,4; .loc 1 972 0 add.u64 %r62,%frame,24; .loc 1 982 0 mov.u16 %r82,%r67; $L19: .loc 1 978 0 ld.u16 %r34,[%r57]; add.u64 %r57,%r57,-2; add.u64 %r62,%r62,-2; setp.ne.u32 %r69,%r34,0; @ %r69 bra $L17; .loc 1 982 0 st.u16 [%r62+-2],%r82; bra $L18; $L17: .loc 1 986 0 cvt.u16.u32 %r72,%r34; cvt.u64.u16 %r71,%r72; mul.lo.u64 %r53,%r71,%r52; .loc 1 987 0 and.b64 %r73,%r53,65535; ld.u16 %r74,[%r62+2]; add.u64 %r54,%r73,%r74; .loc 1 988 0 st.u16 [%r62+2],%r54; .loc 1 989 0 shr.u64 %r40,%r54,16; shr.u64 %r75,%r53,16; ld.u16 %r76,[%r62]; add.u64 %r77,%r75,%r76; add.u64 %r55,%r77,%r40; .loc 1 990 0 st.u16 [%r62],%r55; .loc 1 991 0 shr.u64 %r78,%r55,16; st.u16 [%r62+-2],%r78; $L18: .loc 1 976 0 setp.ne.u64 %r79,%r57,%r58; @ %r79 bra $L19; add.u64 %r49,%frame,4; add.u64 %r56,%r65,4; add.u64 %r50,%frame,26; $L20: .loc 1 995 0 ld.u16 %r80,[%r49]; st.u16 [%r56],%r80; add.u64 %r49,%r49,2; add.u64 %r56,%r56,2; .loc 1 994 0 setp.ne.u64 %r81,%r49,%r50; @ %r81 bra $L20; .loc 1 996 0 ret; } // BEGIN FUNCTION DEF: edivm .func (.param .u32 %value_out) edivm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,32; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r68; .reg .u64 %r69; .reg .u32 %r72; .reg .u64 %r74; .reg .u64 %r76; .reg .u64 %r78; .reg .u32 %r79; .reg .u64 %r83; .reg .u32 %r88; .reg .u64 %r89; .reg .u32 %r90; .reg .u64 %r93; .reg .u64 %r96; .reg .u64 %r103; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r116; .reg .u64 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r124; .reg .u64 %r131; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r138; .reg .u64 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .u32 %r142; .reg .u64 %r144; .reg .u64 %r145; .reg .u64 %r147; .reg .u64 %r150; .reg .u64 %r151; .reg .u32 %r154; .reg .u64 %r156; .reg .u64 %r157; .reg .u64 %r158; .reg .u16 %r159; .reg .u16 %r160; .reg .u16 %r161; .reg .pred %r162; .reg .u64 %r165; .reg .u64 %r167; .reg .u64 %r168; .reg .u64 %r169; .reg .pred %r170; .reg .u64 %r172; .reg .u16 %r175; .reg .u16 %r179; .reg .u16 %r180; .reg .pred %r181; .reg .pred %r182; .reg .pred %r185; .reg .u16 %r186; .reg .u16 %r187; .reg .u64 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .u32 %r194; .reg .pred %r196; .reg .u16 %r197; .reg .u16 %r198; .reg .pred %r199; .reg .pred %r200; .reg .pred %r203; .reg .u16 %r204; .reg .u16 %r205; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u32 %r212; .reg .pred %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .u64 %r217; .reg .u64 %r218; .reg .u64 %r219; .reg .u32 %r221; .reg .pred %r222; .reg .u16 %r223; .reg .u16 %r224; .reg .pred %r225; .reg .u16 %r226; .reg .pred %r227; .reg .u16 %r228; .reg .u16 %r229; .reg .u16 %r230; .reg .pred %r231; .reg .u32 %r232; .reg .u16 %r233; .reg .u32 %r234; .reg .u32 %r235; .reg .u16 %r236; .reg .pred %r237; .reg .u64 %r239; .reg .u64 %r241; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u32 %r245; .reg .u64 %r246; mov.u64 %r156,%ar0; mov.u64 %r157,%ar1; mov.u64 %r158,%ar2; .loc 1 1010 0 add.u64 %r83,%r158,52; .loc 1 1013 0 ld.u16 %r159,[%r157]; st.u16 [%r158+52],%r159; .loc 1 1014 0 ld.u16 %r160,[%r157+2]; st.u16 [%r158+54],%r160; add.u64 %r239,%r158,56; mov.u64 %r74,%r239; add.u64 %r140,%r158,78; .loc 1 1018 0 mov.u16 %r161,0; $L24: st.u16 [%r74],%r161; add.u64 %r74,%r74,2; .loc 1 1016 0 setp.ne.u64 %r162,%r140,%r74; @ %r162 bra $L24; .loc 1 1020 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r157; call eshdn1,(%out_arg1); } .loc 1 1028 0 ld.u16 %r68,[%r156+6]; shl.b64 %r165,%r68,16; sub.u64 %r69,%r165,%r68; add.u64 %r144,%r157,4; add.u64 %r145,%r157,24; mov.u64 %r78,%r239; mov.u64 %r151,%r83; add.u64 %r76,%r151,26; add.u64 %r241,%frame,4; add.u64 %r244,%frame,26; add.u64 %r243,%frame,24; add.u64 %r242,%r157,2; .loc 1 940 0 mov.u32 %r245,0; add.u64 %r246,%frame,2; $L35: .loc 1 1025 0 ld.u16 %r167,[%r157+4]; shl.b64 %r168,%r167,16; ld.u16 %r169,[%r157+6]; add.u64 %r89,%r168,%r169; .loc 1 1028 0 setp.lt.u64 %r170,%r69,%r89; @ %r170 bra $L38; .loc 1 1031 0 div.u64 %r172,%r89,%r68; cvt.u16.u64 %r175,%r172; cvt.u32.u16 %r79,%r175; bra $L25; $L38: .loc 1 1029 0 mov.u32 %r79,65535; $L25: .loc 1 1040 0 { .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r79; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r156; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call m16m,(%out_arg1,%out_arg2,%out_arg3); } mov.u64 %r124,%r241; mov.u64 %r147,%r144; mov.u64 %r93,%r144; mov.u64 %r96,%r241; $L27: .loc 1 756 0 ld.u16 %r179,[%r96]; ld.u16 %r180,[%r93]; setp.ne.u16 %r181,%r179,%r180; @ %r181 bra $L26; add.u64 %r96,%r96,2; add.u64 %r93,%r93,2; .loc 1 754 0 setp.ne.u64 %r182,%r244,%r96; @ %r182 bra $L27; bra $L28; $L26: .loc 1 762 0 setp.le.u16 %r185,%r179,%r180; @ %r185 bra $L28; .loc 1 1044 0 cvt.u16.u32 %r187,%r79; add.u16 %r186,%r187,-1; cvt.u32.u16 %r90,%r186; .loc 1 938 0 add.u64 %r119,%r156,24; mov.u64 %r106,%r119; .loc 1 940 0 mov.u32 %r154,%r245; .loc 1 939 0 mov.u64 %r107,%r243; $L29: .loc 1 943 0 ld.u16 %r188,[%r107]; ld.u16 %r189,[%r106]; sub.u64 %r190,%r188,%r189; cvt.u64.u32 %r191,%r154; sub.u64 %r103,%r190,%r191; .loc 1 948 0 st.u16 [%r107],%r103; .loc 1 949 0 add.u64 %r106,%r106,-2; .loc 1 950 0 add.u64 %r107,%r107,-2; .loc 1 944 0 shr.u64 %r192,%r103,16; cvt.u32.u64 %r194,%r192; and.b32 %r154,%r194,1; .loc 1 941 0 setp.ne.u64 %r196,%r107,%r246; @ %r196 bra $L29; mov.u64 %r121,%r144; $L31: .loc 1 756 0 ld.u16 %r197,[%r124]; ld.u16 %r198,[%r121]; setp.ne.u16 %r199,%r197,%r198; @ %r199 bra $L30; add.u64 %r124,%r124,2; add.u64 %r121,%r121,2; .loc 1 754 0 setp.ne.u64 %r200,%r244,%r124; @ %r200 bra $L31; .loc 1 1044 0 mov.u32 %r79,%r90; bra $L28; $L30: .loc 1 762 0 setp.le.u16 %r203,%r197,%r198; @ %r203 bra $L39; .loc 1 1048 0 cvt.u16.u32 %r205,%r79; add.u16 %r204,%r205,-2; cvt.u32.u16 %r79,%r204; .loc 1 940 0 mov.u32 %r142,%r245; .loc 1 939 0 mov.u64 %r120,%r243; $L32: .loc 1 943 0 ld.u16 %r206,[%r120]; ld.u16 %r207,[%r119]; sub.u64 %r208,%r206,%r207; cvt.u64.u32 %r209,%r142; sub.u64 %r116,%r208,%r209; .loc 1 948 0 st.u16 [%r120],%r116; .loc 1 949 0 add.u64 %r119,%r119,-2; .loc 1 950 0 add.u64 %r120,%r120,-2; .loc 1 944 0 shr.u64 %r210,%r116,16; cvt.u32.u64 %r212,%r210; and.b32 %r142,%r212,1; .loc 1 941 0 setp.ne.u64 %r214,%r120,%r246; @ %r214 bra $L32; bra $L28; $L39: .loc 1 1044 0 mov.u32 %r79,%r90; $L28: .loc 1 939 0 mov.u64 %r135,%r145; .loc 1 940 0 mov.u32 %r141,%r245; .loc 1 938 0 mov.u64 %r134,%r243; $L33: .loc 1 943 0 ld.u16 %r215,[%r135]; ld.u16 %r216,[%r134]; sub.u64 %r217,%r215,%r216; cvt.u64.u32 %r218,%r141; sub.u64 %r131,%r217,%r218; .loc 1 948 0 st.u16 [%r135],%r131; .loc 1 949 0 add.u64 %r134,%r134,-2; .loc 1 950 0 add.u64 %r135,%r135,-2; .loc 1 944 0 shr.u64 %r219,%r131,16; cvt.u32.u64 %r221,%r219; and.b32 %r141,%r221,1; .loc 1 941 0 setp.ne.u64 %r222,%r135,%r242; @ %r222 bra $L33; .loc 1 1071 0 cvt.u16.u32 %r223,%r79; st.u16 [%r78],%r223; mov.u64 %r138,%r144; .loc 1 873 0 mov.u64 %r122,%r144; $L34: .loc 1 877 0 add.u64 %r122,%r122,2; ld.u16 %r224,[%r122]; st.u16 [%r138],%r224; add.u64 %r138,%r138,2; .loc 1 876 0 setp.ne.u64 %r225,%r122,%r145; @ %r225 bra $L34; .loc 1 879 0 mov.u16 %r226,0; st.u16 [%r157+24],%r226; add.u64 %r78,%r78,2; .loc 1 1022 0 setp.ne.u64 %r227,%r76,%r78; @ %r227 bra $L35; mov.u64 %r150,%r157; add.u64 %r139,%r150,26; .loc 1 1076 0 mov.u32 %r88,0; $L36: .loc 1 1079 0 ld.u16 %r229,[%r147]; cvt.u16.u32 %r230,%r88; or.b16 %r228,%r229,%r230; cvt.u32.u16 %r88,%r228; add.u64 %r147,%r147,2; .loc 1 1077 0 setp.ne.u64 %r231,%r139,%r147; @ %r231 bra $L36; .loc 1 1081 0 cvt.u16.u32 %r233,%r88; set.u32.ne.u16 %r234,%r233,0; neg.s32 %r235,%r234; cvt.u32.u32 %r232,%r235; cvt.u32.u8 %r72,%r232; $L37: .loc 1 1085 0 ld.u16 %r236,[%r151]; st.u16 [%r150],%r236; add.u64 %r151,%r151,2; add.u64 %r150,%r150,2; .loc 1 1084 0 setp.ne.u64 %r237,%r78,%r151; @ %r237 bra $L37; .loc 1 1088 0 mov.u32 %value,%r72; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: emulm .func (.param .u32 %value_out) emulm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,32; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r48; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r55; .reg .u32 %r57; .reg .u64 %r65; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .u32 %r75; .reg .u64 %r78; .reg .u64 %r81; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .pred %r89; .reg .pred %r90; .reg .u16 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u32 %r103; .reg .pred %r105; .reg .u16 %r106; .reg .pred %r107; .reg .u16 %r108; .reg .pred %r109; .reg .u16 %r110; .reg .pred %r111; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r116; mov.u64 %r83,%ar0; mov.u64 %r84,%ar1; mov.u64 %r85,%ar2; .loc 1 1101 0 ld.u16 %r86,[%r84]; st.u16 [%r85+52],%r86; .loc 1 1102 0 ld.u16 %r87,[%r84+2]; st.u16 [%r85+54],%r87; add.u64 %r113,%r85,56; mov.u64 %r52,%r113; .loc 1 1099 0 add.u64 %r78,%r85,52; add.u64 %r114,%r85,78; .loc 1 1104 0 mov.u16 %r88,0; $L51: st.u16 [%r52],%r88; add.u64 %r52,%r52,2; .loc 1 1103 0 setp.ne.u64 %r89,%r114,%r52; @ %r89 bra $L51; .loc 1 1107 0 add.u64 %r81,%r83,24; add.u64 %r55,%r85,76; add.u64 %r53,%r83,4; .loc 1 1106 0 mov.u32 %r57,0; add.u64 %r116,%frame,2; $L56: .loc 1 1111 0 ld.u16 %r48,[%r81]; add.u64 %r81,%r81,-2; setp.ne.u32 %r90,%r48,0; @ %r90 bra $L52; $L55: .loc 1 1120 0 ld.u16 %r92,[%r85+76]; cvt.u16.u32 %r93,%r57; or.b16 %r91,%r92,%r93; cvt.u32.u16 %r57,%r91; .loc 1 892 0 mov.u64 %r73,%r114; .loc 1 891 0 mov.u64 %r72,%r55; bra $L53; $L52: .loc 1 1117 0 { .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r48; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r84; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call m16m,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 912 0 mov.u64 %r69,%r55; .loc 1 913 0 mov.u32 %r75,0; .loc 1 911 0 add.u64 %r68,%frame,24; $L54: .loc 1 916 0 ld.u16 %r97,[%r68]; ld.u16 %r98,[%r69]; add.u64 %r99,%r97,%r98; cvt.u64.u32 %r100,%r75; add.u64 %r65,%r99,%r100; .loc 1 921 0 st.u16 [%r69],%r65; .loc 1 922 0 add.u64 %r68,%r68,-2; .loc 1 923 0 add.u64 %r69,%r69,-2; .loc 1 917 0 shr.u64 %r101,%r65,16; cvt.u32.u64 %r103,%r101; and.b32 %r75,%r103,1; .loc 1 914 0 setp.ne.u64 %r105,%r68,%r116; @ %r105 bra $L54; bra $L55; $L53: .loc 1 895 0 add.u64 %r72,%r72,-2; add.u64 %r73,%r73,-2; ld.u16 %r106,[%r72]; st.u16 [%r73],%r106; .loc 1 894 0 setp.ne.u64 %r107,%r113,%r72; @ %r107 bra $L53; .loc 1 897 0 mov.u16 %r108,0; st.u16 [%r85+56],%r108; .loc 1 1109 0 setp.ne.u64 %r109,%r53,%r81; @ %r109 bra $L56; mov.u64 %r71,%r84; $L57: .loc 1 1125 0 ld.u16 %r110,[%r78]; st.u16 [%r71],%r110; add.u64 %r78,%r78,2; add.u64 %r71,%r71,2; .loc 1 1124 0 setp.ne.u64 %r111,%r52,%r78; @ %r111 bra $L57; .loc 1 1129 0 mov.u32 %value,%r57; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eisnan$part$0 .func (.param .u32 %value_out) eisnan$part$0 (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r25; .reg .u64 %r28; .reg .u32 %r29; .reg .u16 %r31; .reg .pred %r32; .reg .pred %r33; mov.u64 %r25,%ar0; add.u64 %r28,%r25,18; $L65: .loc 1 526 0 ld.u16 %r31,[%r25]; setp.ne.u16 %r32,%r31,0; @ %r32 bra $L66; add.u64 %r25,%r25,2; .loc 1 524 0 setp.ne.u64 %r33,%r25,%r28; @ %r33 bra $L65; .loc 1 530 0 mov.u32 %r29,0; bra $L63; $L66: .loc 1 527 0 mov.u32 %r29,1; $L63: .loc 1 531 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eneg .func eneg (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u64 %r26; .reg .u16 %r27; .reg .u16 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .u16 %r33; .reg .u16 %r34; mov.u64 %r26,%ar0; .loc 1 521 0 ld.u16 %r23,[%r26+18]; cvt.u16.u32 %r28,%r23; and.b16 %r27,%r28,32767; setp.ne.u16 %r29,%r27,32767; @ %r29 bra $L69; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r31,[%value_in]; } .loc 1 470 0 setp.ne.u32 %r32,%r31,0; @ %r32 bra $L68; $L69: .loc 1 473 0 cvt.u16.u32 %r34,%r23; add.u16 %r33,%r34,-32768; st.u16 [%r26+18],%r33; $L68: .loc 1 474 0 ret; } // BEGIN FUNCTION DEF: eisneg .func (.param .u32 %value_out) eisneg (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u16 %r30; .reg .pred %r31; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .u16 %r37; mov.u64 %r28,%ar0; .loc 1 521 0 ld.u16 %r23,[%r28+18]; cvt.u16.u32 %r30,%r23; and.b16 %r29,%r30,32767; setp.ne.u16 %r31,%r29,32767; @ %r31 bra $L72; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r33,[%value_in]; } .loc 1 485 0 setp.ne.u32 %r34,%r33,0; @ %r34 bra $L74; $L72: .loc 1 488 0 cvt.u16.u32 %r37,%r23; cvt.s32.s16 %r36,%r37; shr.u32 %r27,%r36,31; bra $L71; $L74: .loc 1 486 0 mov.u32 %r27,0; $L71: .loc 1 492 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: emovi .func emovi (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r33; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r51; .reg .u64 %r53; .reg .u64 %r55; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u16 %r60; .reg .pred %r61; .reg .u16 %r62; .reg .u16 %r63; .reg .u16 %r64; .reg .u16 %r65; .reg .pred %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .pred %r71; .reg .u32 %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; .reg .pred %r77; .reg .u16 %r78; .reg .pred %r79; .reg .u16 %r80; .reg .u16 %r81; .reg .pred %r82; .reg .u16 %r83; mov.u64 %r58,%ar0; mov.u64 %r59,%ar1; .loc 1 592 0 ld.u16 %r60,[%r58+18]; setp.ge.s16 %r61,%r60,0; @ %r61 bra $L76; .loc 1 593 0 mov.u16 %r62,-1; st.u16 [%r59],%r62; bra $L77; $L76: .loc 1 595 0 mov.u16 %r63,0; st.u16 [%r59],%r63; $L77: .loc 1 597 0 add.u64 %r44,%r58,16; .loc 1 598 0 ld.u16 %r65,[%r58+18]; and.b16 %r64,%r65,32767; st.u16 [%r59+2],%r64; .loc 1 600 0 setp.ne.u16 %r68,%r64,32767; @ %r68 bra $L78; .loc 1 521 0 ld.u16 %r70,[%r58+18]; and.b16 %r69,%r70,32767; setp.ne.u16 %r71,%r69,32767; @ %r71 bra $L79; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r58; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r73,[%value_in]; } .loc 1 603 0 setp.eq.u32 %r74,%r73,0; @ %r74 bra $L79; .loc 1 605 0 mov.u16 %r75,0; st.u16 [%r59+4],%r75; mov.u64 %r55,%r44; add.u64 %r53,%r59,6; add.u64 %r43,%r58,-4; $L80: .loc 1 607 0 ld.u16 %r76,[%r55]; st.u16 [%r53],%r76; add.u64 %r55,%r55,-2; add.u64 %r53,%r53,2; .loc 1 606 0 setp.ne.u64 %r77,%r43,%r55; @ %r77 bra $L80; bra $L75; $L79: add.u64 %r40,%r59,4; add.u64 %r39,%r59,26; .loc 1 612 0 mov.u16 %r78,0; $L82: st.u16 [%r40],%r78; add.u64 %r40,%r40,2; .loc 1 611 0 setp.ne.u64 %r79,%r39,%r40; @ %r79 bra $L82; bra $L75; $L78: .loc 1 617 0 mov.u16 %r80,0; st.u16 [%r59+4],%r80; mov.u64 %r33,%r44; add.u64 %r51,%r59,6; add.u64 %r57,%r58,-2; $L84: .loc 1 620 0 ld.u16 %r81,[%r33]; st.u16 [%r51],%r81; add.u64 %r33,%r33,-2; add.u64 %r51,%r51,2; .loc 1 619 0 setp.ne.u64 %r82,%r33,%r57; @ %r82 bra $L84; .loc 1 622 0 mov.u16 %r83,0; st.u16 [%r59+24],%r83; $L75: .loc 1 623 0 ret; } // BEGIN FUNCTION DEF: ecmp .func (.param .u32 %value_out) ecmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,56; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r34; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u64 %r47; .reg .u64 %r50; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r55; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u16 %r61; .reg .u16 %r62; .reg .pred %r63; .reg .u32 %r65; .reg .pred %r66; .reg .u16 %r67; .reg .u16 %r68; .reg .pred %r69; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r75; .reg .u16 %r78; .reg .u16 %r79; .reg .pred %r80; .reg .u16 %r83; .reg .pred %r84; .reg .u16 %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .pred %r89; .reg .u16 %r91; .reg .u16 %r92; .reg .pred %r93; .reg .pred %r94; .reg .pred %r97; mov.u64 %r59,%ar0; mov.u64 %r60,%ar1; .loc 1 521 0 ld.u16 %r62,[%r59+18]; and.b16 %r61,%r62,32767; setp.ne.u16 %r63,%r61,32767; @ %r63 bra $L92; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r59; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r65,[%value_in]; } .loc 1 2356 0 setp.ne.u32 %r66,%r65,0; @ %r66 bra $L102; $L92: .loc 1 521 0 ld.u16 %r68,[%r60+18]; and.b16 %r67,%r68,32767; setp.ne.u16 %r69,%r67,32767; @ %r69 bra $L94; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r60; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r71,[%value_in]; } .loc 1 2356 0 setp.ne.u32 %r72,%r71,0; @ %r72 bra $L103; $L94: .loc 1 2359 0 add.u64 %r75,%frame,26; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r59; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r75; call emovi,(%out_arg1,%out_arg2); } .loc 1 2361 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r60; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call emovi,(%out_arg1,%out_arg2); } .loc 1 2364 0 ld.u16 %r34,[%frame+26]; ld.u16 %r78,[%frame]; cvt.u16.u32 %r79,%r34; setp.eq.u16 %r80,%r78,%r79; @ %r80 bra $L95; add.u64 %r40,%frame,28; add.u64 %r47,%frame,2; add.u64 %r50,%frame,50; $L97: .loc 1 2369 0 ld.u16 %r83,[%r40]; setp.ne.u16 %r84,%r83,0; @ %r84 bra $L96; .loc 1 2371 0 ld.u16 %r85,[%r47]; setp.ne.u16 %r86,%r85,0; @ %r86 bra $L96; add.u64 %r40,%r40,2; add.u64 %r47,%r47,2; .loc 1 2367 0 setp.ne.u64 %r87,%r40,%r50; @ %r87 bra $L97; .loc 1 2374 0 mov.u32 %r58,0; bra $L91; $L96: .loc 1 2376 0 setp.eq.u32 %r88,%r34,0; .loc 1 2379 0 selp.u32 %r58,1,-1,%r88; bra $L91; $L95: .loc 1 2382 0 setp.eq.u32 %r89,%r34,0; .loc 1 2385 0 selp.u32 %r58,1,-1,%r89; add.u64 %r52,%frame,2; add.u64 %r53,%frame,28; add.u64 %r55,%frame,24; bra $L99; $L101: .loc 1 2389 0 ld.u16 %r38,[%r53]; ld.u16 %r39,[%r52]; add.u64 %r52,%r52,2; add.u64 %r53,%r53,2; cvt.u16.u32 %r91,%r38; cvt.u16.u32 %r92,%r39; setp.ne.u16 %r93,%r91,%r92; @ %r93 bra $L100; $L99: .loc 1 2394 0 setp.ne.u64 %r94,%r52,%r55; @ %r94 bra $L101; .loc 1 2374 0 mov.u32 %r58,0; bra $L91; $L100: .loc 1 2402 0 setp.gt.u16 %r97,%r91,%r92; @ %r97 bra $L91; .loc 1 2405 0 neg.s32 %r58,%r58; bra $L91; $L102: .loc 1 2357 0 mov.u32 %r58,-2; bra $L91; $L103: mov.u32 %r58,-2; $L91: .loc 1 2406 0 mov.u32 %value,%r58; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eisinf$part$1 .func (.param .u32 %value_out) eisinf$part$1 (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r25; .reg .u32 %r27; .reg .u32 %r30; mov.u64 %r25,%ar0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r27,[%value_in]; } .loc 1 504 0 set.u32.eq.u32 %r30,%r27,0; neg.s32 %value,%r30; .loc 1 511 0 st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: eshift$part$4 .func (.param .u32 %value_out) eshift$part$4 (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u32 %r59; .reg .u64 %r62; .reg .u64 %r64; .reg .u32 %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u32 %r75; .reg .u64 %r80; .reg .u32 %r83; .reg .u64 %r90; .reg .u64 %r95; .reg .u64 %r97; .reg .u64 %r103; .reg .u32 %r104; .reg .u64 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .u16 %r113; .reg .u16 %r114; .reg .u16 %r115; .reg .u16 %r116; .reg .pred %r117; .reg .u16 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u16 %r121; .reg .u16 %r123; .reg .u16 %r124; .reg .u32 %r126; .reg .u16 %r127; .reg .u16 %r128; .reg .u16 %r129; .reg .u32 %r130; .reg .u16 %r131; .reg .pred %r132; .reg .pred %r137; .reg .u16 %r138; .reg .u16 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .pred %r144; .reg .u16 %r145; .reg .pred %r146; .reg .u16 %r147; .reg .pred %r148; .reg .pred %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .u16 %r156; .reg .u16 %r157; .reg .u32 %r158; .reg .u16 %r159; .reg .pred %r160; .reg .pred %r165; .reg .pred %r167; .reg .u16 %r169; .reg .u32 %r170; .reg .u64 %r173; .reg .u64 %r174; mov.u64 %r108,%ar0; mov.u32 %r109,%ar1; .loc 1 2426 0 setp.lt.s32 %r110,%r109,0; @ %r110 bra $L109; .loc 1 2452 0 setp.gt.s32 %r111,%r109,15; @ %r111 bra $L110; bra $L111; $L109: .loc 1 2428 0 neg.s32 %r72,%r109; .loc 1 2429 0 setp.ge.s32 %r112,%r109,-15; @ %r112 bra $L126; add.u64 %r97,%r108,26; add.u64 %r95,%r108,24; .loc 1 2423 0 mov.u32 %r71,0; add.u64 %r173,%r108,4; .loc 1 897 0 cvt.u16.u32 %r118,%r71; $L114: .loc 1 2431 0 ld.u16 %r114,[%r108+24]; cvt.u16.u32 %r115,%r71; or.b16 %r113,%r114,%r115; cvt.u32.u16 %r71,%r113; .loc 1 892 0 mov.u64 %r52,%r97; .loc 1 891 0 mov.u64 %r50,%r95; $L113: .loc 1 895 0 add.u64 %r50,%r50,-2; add.u64 %r52,%r52,-2; ld.u16 %r116,[%r50]; st.u16 [%r52],%r116; .loc 1 894 0 setp.ne.u64 %r117,%r173,%r50; @ %r117 bra $L113; .loc 1 897 0 st.u16 [%r108+4],%r118; .loc 1 2433 0 add.u32 %r72,%r72,-16; .loc 1 2429 0 setp.gt.s32 %r119,%r72,15; @ %r119 bra $L114; bra $L112; $L126: .loc 1 2423 0 mov.u32 %r71,0; $L112: .loc 1 2436 0 setp.le.s32 %r120,%r72,7; @ %r120 bra $L115; add.u64 %r64,%r108,4; .loc 1 2438 0 ld.u8 %r121,[%r108+24]; cvt.u16.u32 %r124,%r71; or.b16 %r123,%r121,%r124; cvt.u32.u16 %r71,%r123; add.u64 %r90,%r108,26; .loc 1 831 0 mov.u32 %r83,0; $L116: .loc 1 834 0 ld.u16 %r59,[%r64]; .loc 1 835 0 shr.u32 %r126,%r59,8; .loc 1 836 0 cvt.u16.u32 %r128,%r126; cvt.u16.u32 %r129,%r83; or.b16 %r127,%r128,%r129; st.u16 [%r64],%r127; .loc 1 838 0 add.u64 %r64,%r64,2; .loc 1 834 0 shl.b32 %r130,%r59,8; .loc 1 837 0 cvt.u16.u32 %r131,%r130; cvt.u32.u16 %r83,%r131; .loc 1 832 0 setp.ne.u64 %r132,%r64,%r90; @ %r132 bra $L116; and.b32 %r72,%r72,7; $L115: .loc 1 2443 0 setp.eq.u32 %r137,%r72,0; @ %r137 bra $L117; $L118: .loc 1 2445 0 ld.u16 %r139,[%r108+24]; and.b16 %r138,%r139,1; cvt.u16.u32 %r141,%r71; or.b16 %r140,%r138,%r141; cvt.u32.u16 %r71,%r140; .loc 1 2446 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshdn1,(%out_arg1); } .loc 1 2447 0 add.u32 %r72,%r72,-1; .loc 1 2443 0 setp.ne.u32 %r144,%r72,0; @ %r144 bra $L118; bra $L117; $L110: add.u64 %r106,%r108,4; .loc 1 2452 0 mov.u32 %r51,%r109; add.u64 %r174,%r108,24; .loc 1 879 0 mov.u16 %r147,0; $L120: mov.u64 %r62,%r106; .loc 1 873 0 mov.u64 %r73,%r106; $L119: .loc 1 877 0 add.u64 %r73,%r73,2; ld.u16 %r145,[%r73]; st.u16 [%r62],%r145; add.u64 %r62,%r62,2; .loc 1 876 0 setp.ne.u64 %r146,%r73,%r174; @ %r146 bra $L119; .loc 1 879 0 st.u16 [%r108+24],%r147; .loc 1 2455 0 add.u32 %r51,%r51,-16; .loc 1 2452 0 setp.gt.s32 %r148,%r51,15; @ %r148 bra $L120; and.b32 %r109,%r109,15; $L111: .loc 1 2458 0 setp.le.s32 %r153,%r109,7; @ %r153 bra $L121; add.u64 %r80,%r108,24; add.u64 %r103,%r108,2; .loc 1 852 0 mov.u32 %r104,0; $L122: .loc 1 856 0 ld.u16 %r75,[%r80]; .loc 1 857 0 shl.b32 %r154,%r75,8; .loc 1 858 0 cvt.u16.u32 %r156,%r154; cvt.u16.u32 %r157,%r104; or.b16 %r155,%r156,%r157; st.u16 [%r80],%r155; .loc 1 860 0 add.u64 %r80,%r80,-2; .loc 1 856 0 shr.u32 %r158,%r75,8; .loc 1 859 0 cvt.u16.u32 %r159,%r158; cvt.u32.u16 %r104,%r159; .loc 1 854 0 setp.ne.u64 %r160,%r80,%r103; @ %r160 bra $L122; and.b32 %r109,%r109,7; $L121: .loc 1 2464 0 setp.ne.u32 %r165,%r109,0; @ %r165 bra $L123; $L125: .loc 1 852 0 mov.u32 %r107,0; bra $L108; $L123: .loc 1 2466 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshup1,(%out_arg1); } .loc 1 2467 0 add.u32 %r109,%r109,-1; .loc 1 2464 0 setp.ne.u32 %r167,%r109,0; @ %r167 bra $L123; bra $L125; $L117: .loc 1 2470 0 cvt.u16.u32 %r169,%r71; set.u32.ne.u16 %r170,%r169,0; neg.s32 %r107,%r170; $L108: .loc 1 2473 0 mov.u32 %value,%r107; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: enormlz .func (.param .u32 %value_out) enormlz (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r82; .reg .u32 %r84; .reg .u64 %r87; .reg .u32 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u32 %r94; .reg .u64 %r98; .reg .u64 %r101; .reg .u32 %r102; .reg .u32 %r105; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u16 %r110; .reg .pred %r111; .reg .u16 %r112; .reg .pred %r113; .reg .pred %r115; .reg .pred %r116; .reg .u16 %r117; .reg .u16 %r118; .reg .pred %r119; .reg .u32 %r120; .reg .u16 %r121; .reg .u16 %r122; .reg .u16 %r123; .reg .u32 %r124; .reg .u16 %r125; .reg .pred %r126; .reg .u16 %r127; .reg .u16 %r128; .reg .pred %r129; .reg .pred %r131; .reg .u16 %r132; .reg .pred %r133; .reg .u16 %r134; .reg .u16 %r135; .reg .pred %r136; .reg .u32 %r137; .reg .u16 %r138; .reg .u32 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .u16 %r142; .reg .pred %r143; .reg .pred %r145; .reg .u64 %r148; .reg .pred %r149; .reg .u64 %r151; .reg .u16 %r152; mov.u64 %r108,%ar0; .loc 1 2490 0 ld.u16 %r106,[%r108+4]; setp.ne.u32 %r149,%r106,0; @ %r149 bra $L140; .loc 1 2493 0 ld.u16 %r102,[%r108+6]; cvt.u16.u32 %r110,%r102; setp.lt.s16 %r111,%r110,0; @ %r111 bra $L156; .loc 1 2488 0 mov.u32 %r107,%r106; add.u64 %r151,%r108,26; .loc 1 879 0 cvt.u16.u32 %r152,%r107; bra $L142; $L145: .loc 1 874 0 add.u64 %r90,%r108,6; .loc 1 873 0 add.u64 %r91,%r108,4; $L144: .loc 1 877 0 add.u64 %r90,%r90,2; cvt.u16.u32 %r112,%r102; st.u16 [%r91],%r112; add.u64 %r91,%r91,2; .loc 1 876 0 setp.eq.u64 %r113,%r90,%r151; @ %r113 bra $L143; ld.u16 %r102,[%r90]; bra $L144; $L143: .loc 1 879 0 st.u16 [%r108+24],%r152; .loc 1 2498 0 add.u32 %r107,%r107,16; .loc 1 2502 0 setp.eq.u32 %r115,%r107,160; @ %r115 bra $L139; ld.u16 %r102,[%r108+6]; $L142: .loc 1 2495 0 setp.eq.u32 %r116,%r102,0; @ %r116 bra $L145; cvt.u16.u32 %r118,%r102; and.b16 %r117,%r118,-256; cvt.u32.u16 %r88,%r117; .loc 1 2506 0 setp.ne.u32 %r119,%r88,0; @ %r119 bra $L149; add.u64 %r101,%r108,24; add.u64 %r148,%r108,2; $L148: .loc 1 852 0 mov.u32 %r105,%r88; .loc 1 851 0 mov.u64 %r98,%r101; $L147: .loc 1 856 0 ld.u16 %r94,[%r98]; .loc 1 857 0 shl.b32 %r120,%r94,8; .loc 1 858 0 cvt.u16.u32 %r122,%r120; cvt.u16.u32 %r123,%r105; or.b16 %r121,%r122,%r123; st.u16 [%r98],%r121; .loc 1 860 0 add.u64 %r98,%r98,-2; .loc 1 856 0 shr.u32 %r124,%r94,8; .loc 1 859 0 cvt.u16.u32 %r125,%r124; cvt.u32.u16 %r105,%r125; .loc 1 854 0 setp.ne.u64 %r126,%r148,%r98; @ %r126 bra $L147; .loc 1 2509 0 add.u32 %r107,%r107,8; .loc 1 2506 0 ld.u16 %r102,[%r108+6]; cvt.u16.u32 %r128,%r102; and.b16 %r127,%r128,-256; setp.eq.u16 %r129,%r127,0; @ %r129 bra $L148; bra $L149; $L150: .loc 1 2514 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshup1,(%out_arg1); } .loc 1 2515 0 add.u32 %r107,%r107,1; .loc 1 2516 0 setp.gt.s32 %r131,%r107,160; @ %r131 bra $L139; ld.u16 %r102,[%r108+6]; $L149: .loc 1 2512 0 cvt.u16.u32 %r132,%r102; setp.ge.s16 %r133,%r132,0; @ %r133 bra $L150; bra $L139; $L140: .loc 1 2528 0 cvt.u16.u32 %r135,%r106; and.b16 %r134,%r135,-256; setp.eq.u16 %r136,%r134,0; @ %r136 bra $L157; .loc 1 830 0 add.u64 %r87,%r108,4; add.u64 %r92,%r108,26; .loc 1 831 0 mov.u32 %r82,0; $L153: .loc 1 834 0 shl.b32 %r137,%r106,8; cvt.u16.u32 %r138,%r137; cvt.u32.u16 %r84,%r138; .loc 1 835 0 shr.u32 %r139,%r106,8; .loc 1 836 0 cvt.u16.u32 %r141,%r139; cvt.u16.u32 %r142,%r82; or.b16 %r140,%r141,%r142; st.u16 [%r87],%r140; .loc 1 838 0 add.u64 %r87,%r87,2; .loc 1 832 0 setp.ne.u64 %r143,%r87,%r92; @ %r143 bra $L152; ld.u16 %r106,[%r108+4]; .loc 1 2531 0 mov.u32 %r107,-8; setp.ne.u32 %r149,%r106,0; bra $L154; $L152: ld.u16 %r106,[%r87]; .loc 1 837 0 mov.u32 %r82,%r84; bra $L153; $L155: .loc 1 2535 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r108; call eshdn1,(%out_arg1); } .loc 1 2536 0 add.u32 %r107,%r107,-1; .loc 1 2538 0 setp.eq.u32 %r145,%r107,-145; @ %r145 bra $L139; ld.u16 %r106,[%r108+4]; setp.ne.u32 %r149,%r106,0; bra $L154; $L157: .loc 1 2488 0 mov.u32 %r107,0; $L154: .loc 1 2533 0 @ %r149 bra $L155; bra $L139; $L156: .loc 1 2494 0 mov.u32 %r107,%r106; $L139: .loc 1 2545 0 mov.u32 %value,%r107; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: emdnorm .func emdnorm (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u64 %in_ar5) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u32 %r52; .reg .u32 %r57; .reg .u64 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .u64 %r80; .reg .u32 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u32 %r88; .reg .u32 %r89; .reg .u64 %r102; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r132; .reg .u32 %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .u32 %r142; .reg .u64 %r143; .reg .u32 %r144; .reg .u64 %r145; .reg .u32 %r147; .reg .u64 %r148; .reg .u32 %r150; .reg .u32 %r151; .reg .u32 %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .u16 %r156; .reg .u16 %r157; .reg .u32 %r158; .reg .u16 %r159; .reg .pred %r160; .reg .u16 %r161; .reg .pred %r162; .reg .pred %r163; .reg .pred %r164; .reg .u32 %r166; .reg .u32 %r167; .reg .pred %r168; .reg .u16 %r169; .reg .pred %r170; .reg .pred %r171; .reg .u32 %r172; .reg .pred %r173; .reg .u16 %r174; .reg .pred %r175; .reg .pred %r176; .reg .pred %r177; .reg .pred %r178; .reg .pred %r179; .reg .pred %r180; .reg .pred %r181; .reg .u32 %r182; .reg .u32 %r183; .reg .u16 %r184; .reg .u32 %r185; .reg .u32 %r186; .reg .u32 %r187; .reg .u16 %r188; .reg .u32 %r190; .reg .u32 %r191; .reg .u16 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .u32 %r195; .reg .u16 %r196; .reg .u32 %r198; .reg .u32 %r199; .reg .u16 %r200; .reg .u32 %r202; .reg .u32 %r203; .reg .u16 %r204; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u16 %r211; .reg .pred %r212; .reg .pred %r213; .reg .u16 %r214; .reg .u16 %r215; .reg .u32 %r216; .reg .u64 %r218; .reg .u64 %r219; .reg .u16 %r220; .reg .u16 %r221; .reg .u16 %r222; .reg .pred %r223; .reg .pred %r224; .reg .u64 %r225; .reg .u32 %r226; .reg .u32 %r227; .reg .u64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u16 %r233; .reg .pred %r234; .reg .u16 %r235; .reg .u16 %r236; .reg .u16 %r237; .reg .pred %r238; .reg .u16 %r239; .reg .u16 %r240; .reg .u16 %r241; .reg .u16 %r242; .reg .u16 %r243; .reg .u16 %r244; .reg .u16 %r245; .reg .pred %r246; .reg .pred %r249; .reg .pred %r250; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .u16 %r254; .reg .u16 %r255; .reg .u16 %r256; .reg .pred %r257; .reg .pred %r258; .reg .u64 %r259; .reg .u64 %r260; .reg .u64 %r261; .reg .u64 %r262; .reg .u64 %r263; .reg .u32 %r265; .reg .pred %r266; .reg .u32 %r268; .reg .u32 %r269; .reg .u32 %r271; .reg .u32 %r272; .reg .u16 %r273; .reg .u16 %r274; .reg .u16 %r275; .reg .u32 %r276; .reg .u16 %r277; .reg .pred %r278; .reg .u16 %r280; .reg .pred %r281; .reg .u16 %r283; .reg .pred %r284; .reg .u16 %r285; .reg .u16 %r286; .reg .pred %r287; .reg .pred %r288; .reg .u64 %r290; .reg .u64 %r291; .reg .u16 %r292; .reg .u16 %r293; .reg .u16 %r294; mov.u64 %r140,%ar0; mov.u32 %r141,%ar1; mov.u32 %r142,%ar2; mov.u64 %r143,%ar3; mov.u32 %r144,%ar4; mov.u64 %r145,%ar5; .loc 1 1172 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r147,[%value_in]; } .loc 1 1182 0 cvt.s64.s32 %r148,%r147; sub.u64 %r80,%r143,%r148; .loc 1 1187 0 set.u32.gt.s32 %r150,%r147,144; neg.s32 %r151,%r150; set.u32.le.s64 %r153,%r80,32766; neg.s32 %r154,%r153; cvt.u16.u32 %r156,%r151; cvt.u16.u32 %r157,%r154; and.b16 %r155,%r156,%r157; cvt.u32.u16 %r158,%r155; cvt.u16.u8 %r159,%r158; setp.eq.u16 %r160,%r159,0; @ %r160 bra $L168; .loc 1 681 0 add.u64 %r132,%r140,2; add.u64 %r129,%r140,26; .loc 1 683 0 mov.u16 %r161,0; $L169: st.u16 [%r132],%r161; add.u64 %r132,%r132,2; .loc 1 682 0 setp.ne.u64 %r162,%r129,%r132; @ %r162 bra $L169; bra $L167; $L168: .loc 1 1193 0 setp.ge.s64 %r163,%r80,0; @ %r163 bra $L173; .loc 1 1195 0 setp.lt.s64 %r164,%r80,-144; @ %r164 bra $L172; cvt.u32.u64 %r166,%r80; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r166; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r167,[%value_in]; } .loc 1 1199 0 setp.ne.u32 %r168,%r167,0; .loc 1 1200 0 selp.u32 %r141,1,%r141,%r168; bra $L173; $L172: .loc 1 681 0 add.u64 %r84,%r140,2; add.u64 %r122,%r140,26; .loc 1 683 0 mov.u16 %r169,%r159; $L174: st.u16 [%r84],%r169; add.u64 %r84,%r84,2; .loc 1 682 0 setp.ne.u64 %r170,%r122,%r84; @ %r170 bra $L174; bra $L167; $L173: .loc 1 1209 0 setp.eq.u32 %r171,%r144,0; @ %r171 bra $L176; .loc 1 1212 0 ld.u32 %r52,[%r145+4]; ld.u32 %r172,[%r145]; setp.eq.u32 %r173,%r52,%r172; @ %r173 bra $L177; .loc 1 1214 0 add.u64 %r108,%r145,26; add.u64 %r85,%r145,52; .loc 1 672 0 mov.u16 %r174,0; $L178: st.u16 [%r108],%r174; add.u64 %r108,%r108,2; .loc 1 671 0 setp.ne.u64 %r175,%r85,%r108; @ %r175 bra $L178; .loc 1 1215 0 setp.eq.u32 %r176,%r52,56; @ %r176 bra $L180; setp.gt.s32 %r177,%r52,56; @ %r177 bra $L181; setp.eq.u32 %r178,%r52,24; @ %r178 bra $L182; setp.eq.u32 %r179,%r52,53; @ %r179 bra $L183; bra $L179; $L181: setp.eq.u32 %r180,%r52,64; @ %r180 bra $L184; setp.eq.u32 %r181,%r52,113; @ %r181 bra $L185; $L179: .loc 1 1219 0 mov.u32 %r182,12; st.u32 [%r145+8],%r182; .loc 1 1220 0 mov.u32 %r183,-2147418113; st.u32 [%r145+20],%r183; .loc 1 1221 0 mov.u16 %r184,1; st.u16 [%r145+24],%r184; .loc 1 1223 0 mov.u32 %r185,11; st.u32 [%r145+12],%r185; .loc 1 1224 0 mov.u32 %r139,1; mov.u32 %r138,%r185; bra $L186; $L185: .loc 1 1226 0 mov.u32 %r186,10; st.u32 [%r145+8],%r186; .loc 1 1227 0 mov.u32 %r187,1073774591; st.u32 [%r145+20],%r187; .loc 1 1228 0 mov.u16 %r188,-32768; st.u16 [%r145+24],%r188; .loc 1 1230 0 st.u32 [%r145+12],%r186; .loc 1 1231 0 mov.u32 %r139,32768; mov.u32 %r138,%r186; bra $L186; $L184: .loc 1 1233 0 mov.u32 %r190,7; st.u32 [%r145+8],%r190; .loc 1 1234 0 mov.u32 %r191,-2147418113; st.u32 [%r145+20],%r191; .loc 1 1235 0 mov.u16 %r192,1; st.u16 [%r145+24],%r192; .loc 1 1237 0 mov.u32 %r193,6; st.u32 [%r145+12],%r193; .loc 1 1238 0 mov.u32 %r139,1; mov.u32 %r138,%r193; bra $L186; $L180: .loc 1 1241 0 mov.u32 %r194,6; st.u32 [%r145+8],%r194; .loc 1 1242 0 mov.u32 %r195,8388863; st.u32 [%r145+20],%r195; .loc 1 1243 0 mov.u16 %r196,256; st.u16 [%r145+24],%r196; .loc 1 1245 0 st.u32 [%r145+12],%r194; .loc 1 1246 0 mov.u32 %r139,256; mov.u32 %r138,%r194; bra $L186; $L183: .loc 1 1248 0 mov.u32 %r198,6; st.u32 [%r145+8],%r198; .loc 1 1249 0 mov.u32 %r199,67110911; st.u32 [%r145+20],%r199; .loc 1 1250 0 mov.u16 %r200,2048; st.u16 [%r145+24],%r200; .loc 1 1252 0 st.u32 [%r145+12],%r198; .loc 1 1253 0 mov.u32 %r139,2048; mov.u32 %r138,%r198; bra $L186; $L182: .loc 1 1255 0 mov.u32 %r202,4; st.u32 [%r145+8],%r202; .loc 1 1256 0 mov.u32 %r203,8388863; st.u32 [%r145+20],%r203; .loc 1 1257 0 mov.u16 %r204,256; st.u16 [%r145+24],%r204; .loc 1 1259 0 st.u32 [%r145+12],%r202; .loc 1 1260 0 mov.u32 %r139,256; mov.u32 %r138,%r202; $L186: .loc 1 1262 0 cvt.s64.s32 %r206,%r138; add.u64 %r207,%r206,12; add.u64 %r208,%r207,%r207; add.u64 %r209,%r145,%r208; cvt.u16.u32 %r211,%r139; st.u16 [%r209+2],%r211; .loc 1 1263 0 st.u32 [%r145],%r52; $L177: .loc 1 1272 0 setp.gt.s64 %r212,%r80,0; @ %r212 bra $L187; setp.eq.u32 %r213,%r52,144; @ %r213 bra $L188; .loc 1 1277 0 ld.u16 %r215,[%r140+24]; and.b16 %r214,%r215,1; cvt.u32.u16 %r216,%r214; or.b32 %r141,%r141,%r216; .loc 1 1278 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call eshdn1,(%out_arg1); } ld.u32 %r52,[%r145+4]; $L187: .loc 1 1283 0 ld.u32 %r57,[%r145+8]; cvt.s64.s32 %r218,%r57; add.u64 %r219,%r218,%r218; add.u64 %r60,%r140,%r219; ld.u16 %r61,[%r60]; ld.u16 %r62,[%r145+20]; cvt.u16.u32 %r221,%r61; cvt.u16.u32 %r222,%r62; and.b16 %r220,%r221,%r222; cvt.u32.u16 %r83,%r220; .loc 1 1284 0 setp.gt.s32 %r223,%r52,143; @ %r223 bra $L189; .loc 1 1286 0 add.u32 %r89,%r57,1; .loc 1 1287 0 setp.gt.s32 %r224,%r89,12; @ %r224 bra $L189; add.u64 %r225,%r219,2; add.u64 %r121,%r140,%r225; mov.u32 %r227,11; sub.u32 %r226,%r227,%r57; cvt.u64.u32 %r228,%r226; cvt.s64.s32 %r229,%r89; add.u64 %r230,%r228,%r229; add.u64 %r231,%r230,%r230; add.u64 %r232,%r140,2; add.u64 %r109,%r231,%r232; .loc 1 1291 0 mov.u16 %r237,0; $L191: .loc 1 1289 0 ld.u16 %r233,[%r121]; setp.eq.u16 %r234,%r233,0; @ %r234 bra $L190; .loc 1 1290 0 cvt.u16.u32 %r236,%r83; or.b16 %r235,%r236,1; cvt.u32.u16 %r83,%r235; $L190: .loc 1 1291 0 st.u16 [%r121],%r237; add.u64 %r121,%r121,2; .loc 1 1287 0 setp.ne.u64 %r238,%r109,%r121; @ %r238 bra $L191; ld.u16 %r61,[%r60]; ld.u16 %r62,[%r145+20]; $L189: .loc 1 1295 0 cvt.u16.u32 %r240,%r62; not.b16 %r239,%r240; cvt.u16.u32 %r242,%r61; and.b16 %r241,%r239,%r242; st.u16 [%r60],%r241; .loc 1 1296 0 ld.u16 %r244,[%r145+22]; cvt.u16.u32 %r245,%r83; and.b16 %r243,%r244,%r245; setp.eq.u16 %r246,%r243,0; @ %r246 bra $L192; .loc 1 1298 0 setp.ne.u16 %r249,%r244,%r245; @ %r249 bra $L193; .loc 1 1300 0 setp.ne.u32 %r250,%r141,0; @ %r250 bra $L194; .loc 1 1302 0 ld.s32 %r251,[%r145+12]; add.u64 %r252,%r251,%r251; add.u64 %r253,%r140,%r252; ld.u16 %r255,[%r253]; ld.u16 %r256,[%r145+24]; and.b16 %r254,%r255,%r256; setp.eq.u16 %r257,%r254,0; @ %r257 bra $L192; bra $L193; $L194: .loc 1 1307 0 setp.ne.u32 %r258,%r142,0; @ %r258 bra $L192; $L193: .loc 1 911 0 add.u64 %r105,%r145,50; .loc 1 912 0 add.u64 %r106,%r140,24; add.u64 %r123,%r140,2; .loc 1 913 0 mov.u32 %r88,0; $L195: .loc 1 916 0 ld.u16 %r259,[%r105]; ld.u16 %r260,[%r106]; add.u64 %r261,%r259,%r260; cvt.u64.u32 %r262,%r88; add.u64 %r102,%r261,%r262; .loc 1 921 0 st.u16 [%r106],%r102; .loc 1 922 0 add.u64 %r105,%r105,-2; .loc 1 923 0 add.u64 %r106,%r106,-2; .loc 1 917 0 shr.u64 %r263,%r102,16; cvt.u32.u64 %r265,%r263; and.b32 %r88,%r265,1; .loc 1 914 0 setp.ne.u64 %r266,%r106,%r123; @ %r266 bra $L195; $L192: .loc 1 1315 0 set.u32.ne.u32 %r268,%r52,144; neg.s32 %r269,%r268; set.u32.le.s64 %r271,%r80,0; neg.s32 %r272,%r271; cvt.u16.u32 %r274,%r269; cvt.u16.u32 %r275,%r272; and.b16 %r273,%r274,%r275; cvt.u32.u16 %r276,%r273; cvt.u16.u8 %r277,%r276; setp.eq.u16 %r278,%r277,0; @ %r278 bra $L196; .loc 1 1320 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call eshup1,(%out_arg1); } $L196: .loc 1 1322 0 ld.u16 %r280,[%r140+4]; setp.eq.u16 %r281,%r280,0; @ %r281 bra $L176; .loc 1 1324 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call eshdn1,(%out_arg1); } .loc 1 1325 0 add.u64 %r80,%r80,1; $L176: .loc 1 1328 0 mov.u16 %r283,0; st.u16 [%r140+24],%r283; .loc 1 1329 0 setp.le.s64 %r284,%r80,32766; @ %r284 bra $L197; .loc 1 1335 0 mov.u16 %r285,32767; st.u16 [%r140+2],%r285; add.u64 %r128,%r140,4; add.u64 %r124,%r140,24; .loc 1 1337 0 mov.u16 %r286,%r283; $L198: st.u16 [%r128],%r286; add.u64 %r128,%r128,2; .loc 1 1336 0 setp.ne.u64 %r287,%r124,%r128; @ %r287 bra $L198; bra $L167; $L197: .loc 1 1356 0 setp.ge.s64 %r288,%r80,0; @ %r288 bra $L199; .loc 1 1357 0 st.u16 [%r140+2],%r283; bra $L167; $L199: .loc 1 1359 0 st.u16 [%r140+2],%r80; bra $L167; $L188: .loc 1 1283 0 ld.s32 %r290,[%r145+8]; add.u64 %r291,%r290,%r290; add.u64 %r60,%r140,%r291; ld.u16 %r61,[%r60]; ld.u16 %r62,[%r145+20]; cvt.u16.u32 %r293,%r62; cvt.u16.u32 %r294,%r61; and.b16 %r292,%r293,%r294; cvt.u32.u16 %r83,%r292; bra $L189; $L167: .loc 1 1360 0 ret; } // BEGIN FUNCTION DEF: eiremain .func eiremain (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r35; .reg .u32 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r42; .reg .u64 %r43; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r59; .reg .u64 %r62; .reg .u64 %r63; .reg .u32 %r66; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r71; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u32 %r79; .reg .u64 %r80; .reg .u32 %r82; .reg .u64 %r83; .reg .u16 %r84; .reg .pred %r85; .reg .pred %r86; .reg .u16 %r87; .reg .u16 %r88; .reg .pred %r89; .reg .pred %r90; .reg .pred %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u32 %r100; .reg .pred %r101; .reg .u16 %r103; .reg .u16 %r104; .reg .u16 %r105; .reg .pred %r107; .reg .u32 %r112; .reg .u64 %r114; .reg .u64 %r115; mov.u64 %r75,%ar0; mov.u64 %r76,%ar1; mov.u64 %r77,%ar2; .loc 1 3653 0 add.u64 %r39,%r77,52; .loc 1 3655 0 ld.u16 %r40,[%r75+2]; .loc 1 3656 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r75; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r79,[%value_in]; } cvt.s64.s32 %r80,%r79; sub.u64 %r42,%r40,%r80; .loc 1 3657 0 ld.u16 %r43,[%r76+2]; .loc 1 3658 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r82,[%value_in]; } cvt.s64.s32 %r83,%r82; sub.u64 %r46,%r43,%r83; mov.u64 %r69,%r39; add.u64 %r68,%r77,78; .loc 1 672 0 mov.u16 %r84,0; $L226: st.u16 [%r69],%r84; add.u64 %r69,%r69,2; .loc 1 671 0 setp.ne.u64 %r85,%r68,%r69; @ %r85 bra $L226; .loc 1 3660 0 setp.gt.s64 %r86,%r42,%r46; @ %r86 bra $L227; add.u64 %r74,%r75,4; add.u64 %r73,%r76,4; add.u64 %r71,%r42,-1; add.u64 %r114,%r75,26; add.u64 %r115,%r76,2; $L233: mov.u64 %r45,%r74; mov.u64 %r35,%r73; $L229: .loc 1 756 0 ld.u16 %r87,[%r45]; ld.u16 %r88,[%r35]; setp.ne.u16 %r89,%r87,%r88; @ %r89 bra $L228; add.u64 %r45,%r45,2; add.u64 %r35,%r35,2; .loc 1 754 0 setp.ne.u64 %r90,%r114,%r45; @ %r90 bra $L229; bra $L230; $L228: .loc 1 762 0 setp.gt.u16 %r93,%r87,%r88; @ %r93 bra $L234; $L230: .loc 1 938 0 add.u64 %r62,%r75,24; .loc 1 939 0 add.u64 %r63,%r76,24; .loc 1 940 0 mov.u32 %r66,0; $L232: .loc 1 943 0 ld.u16 %r94,[%r63]; ld.u16 %r95,[%r62]; sub.u64 %r96,%r94,%r95; cvt.u64.u32 %r97,%r66; sub.u64 %r59,%r96,%r97; .loc 1 948 0 st.u16 [%r63],%r59; .loc 1 949 0 add.u64 %r62,%r62,-2; .loc 1 950 0 add.u64 %r63,%r63,-2; .loc 1 944 0 shr.u64 %r98,%r59,16; cvt.u32.u64 %r100,%r98; and.b32 %r66,%r100,1; .loc 1 941 0 setp.ne.u64 %r101,%r115,%r63; @ %r101 bra $L232; .loc 1 3665 0 mov.u32 %r38,1; bra $L231; $L234: .loc 1 3669 0 mov.u32 %r38,0; $L231: .loc 1 3671 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; call eshup1,(%out_arg1); } .loc 1 3672 0 ld.u16 %r104,[%r77+76]; cvt.u16.u32 %r105,%r38; or.b16 %r103,%r104,%r105; st.u16 [%r77+76],%r103; .loc 1 3673 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; call eshup1,(%out_arg1); } .loc 1 3674 0 add.u64 %r46,%r46,-1; .loc 1 3660 0 setp.ne.u64 %r107,%r46,%r71; @ %r107 bra $L233; $L227: .loc 1 3676 0 mov.u32 %r112,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r112; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r112; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r46; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r112; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r77; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3677 0 ret; } // BEGIN FUNCTION DEF: emovo$isra$7 .func emovo$isra$7 (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r44; .reg .u64 %r45; .reg .u64 %r47; .reg .u64 %r50; .reg .u32 %r53; .reg .u64 %r55; .reg .u64 %r62; .reg .u64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u16 %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; .reg .u16 %r77; .reg .u16 %r78; .reg .pred %r79; .reg .u16 %r80; .reg .pred %r81; .reg .pred %r82; .reg .u16 %r83; .reg .pred %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u16 %r87; .reg .pred %r88; .reg .u16 %r89; .reg .u16 %r90; .reg .u16 %r91; .reg .pred %r92; mov.u64 %r71,%ar0; mov.u64 %r72,%ar1; add.u64 %r65,%r71,4; ld.u16 %r53,[%r71+2]; .loc 1 638 0 ld.u16 %r73,[%r71]; setp.eq.u16 %r74,%r73,0; @ %r74 bra $L240; .loc 1 639 0 cvt.u16.u32 %r76,%r53; or.b16 %r75,%r76,-32768; st.u16 [%r72+18],%r75; bra $L241; $L240: .loc 1 641 0 cvt.u16.u32 %r77,%r53; st.u16 [%r72+18],%r77; $L241: .loc 1 643 0 ld.u16 %r78,[%r71+2]; setp.ne.u16 %r79,%r78,32767; @ %r79 bra $L242; add.u64 %r62,%r71,6; add.u64 %r50,%r71,26; $L244: .loc 1 712 0 ld.u16 %r80,[%r62]; setp.ne.u16 %r81,%r80,0; @ %r81 bra $L243; add.u64 %r62,%r62,2; .loc 1 710 0 setp.ne.u64 %r82,%r50,%r62; @ %r82 bra $L244; mov.u64 %r45,%r72; add.u64 %r64,%r72,18; .loc 1 548 0 mov.u16 %r83,%r80; $L245: st.u16 [%r45],%r83; add.u64 %r45,%r45,2; .loc 1 547 0 setp.ne.u64 %r84,%r45,%r64; @ %r84 bra $L245; .loc 1 549 0 ld.u16 %r86,[%r72+18]; or.b16 %r85,%r86,32767; st.u16 [%r72+18],%r85; bra $L239; $L243: mov.u64 %r47,%r72; add.u64 %r44,%r72,16; .loc 1 3750 0 mov.u16 %r87,0; $L247: st.u16 [%r47],%r87; add.u64 %r47,%r47,2; .loc 1 3749 0 setp.ne.u64 %r88,%r44,%r47; @ %r88 bra $L247; .loc 1 3751 0 mov.u16 %r89,-16384; st.u16 [%r72+16],%r89; .loc 1 3757 0 mov.u16 %r90,32767; st.u16 [%r72+18],%r90; bra $L239; $L242: .loc 1 657 0 add.u64 %r55,%r71,6; add.u64 %r66,%r72,16; add.u64 %r70,%r65,20; $L248: .loc 1 660 0 ld.u16 %r91,[%r55]; st.u16 [%r66],%r91; add.u64 %r55,%r55,2; add.u64 %r66,%r66,-2; .loc 1 659 0 setp.ne.u64 %r92,%r55,%r70; @ %r92 bra $L248; $L239: .loc 1 661 0 ret; } // BEGIN FUNCTION DEF: e53toe$isra$9 .func e53toe$isra$9 (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,32; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r39; .reg .u32 %r44; .reg .u64 %r49; .reg .u64 %r51; .reg .u32 %r56; .reg .u64 %r62; .reg .u64 %r63; .reg .u32 %r64; .reg .u64 %r67; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u64 %r72; .reg .u64 %r75; .reg .u64 %r76; .reg .u16 %r77; .reg .pred %r78; .reg .u16 %r79; .reg .pred %r81; .reg .u16 %r83; .reg .u16 %r84; .reg .u16 %r86; .reg .u16 %r88; .reg .u16 %r89; .reg .pred %r91; .reg .u16 %r92; .reg .pred %r94; .reg .u16 %r95; .reg .pred %r96; .reg .u16 %r97; .reg .pred %r98; .reg .u16 %r99; .reg .pred %r100; .reg .u16 %r101; .reg .pred %r102; .reg .u16 %r103; .reg .u16 %r104; .reg .u16 %r105; .reg .pred %r106; .reg .u16 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .u16 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .u32 %r114; .reg .u16 %r115; .reg .pred %r116; .reg .u16 %r117; .reg .u16 %r119; .reg .u16 %r120; .reg .u16 %r121; .reg .u16 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r127; .reg .pred %r128; .reg .u16 %r129; .reg .pred %r130; .reg .u16 %r131; .reg .u16 %r132; .reg .u16 %r133; .reg .u16 %r134; .reg .u16 %r137; .reg .u16 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .u32 %r143; .reg .u32 %r144; mov.u64 %r75,%ar0; mov.u64 %r76,%ar1; mov.u64 %r62,%frame; add.u64 %r63,%frame,26; .loc 1 672 0 mov.u16 %r77,0; $L254: st.u16 [%r62],%r77; add.u64 %r62,%r62,2; .loc 1 671 0 setp.ne.u64 %r78,%r62,%r63; @ %r78 bra $L254; .loc 1 2006 0 ld.u16 %r39,[%r75+6]; .loc 1 2008 0 cvt.u16.u32 %r79,%r39; setp.lt.s16 %r81,%r79,0; @ %r81 bra $L255; .loc 1 2007 0 st.u16 [%frame],%r77; bra $L256; $L255: .loc 1 2009 0 mov.u16 %r83,-1; st.u16 [%frame],%r83; $L256: .loc 1 2010 0 and.b16 %r84,%r79,15; or.b16 %r86,%r84,16; st.u16 [%frame+4],%r86; .loc 1 2011 0 cvt.u16.u32 %r89,%r39; and.b16 %r88,%r89,32752; cvt.u32.u16 %r44,%r88; .loc 1 2013 0 setp.ne.u16 %r91,%r88,32752; @ %r91 bra $L257; .loc 1 2017 0 and.b16 %r92,%r89,15; setp.ne.u16 %r94,%r92,0; @ %r94 bra $L258; ld.u16 %r95,[%r75+4]; setp.ne.u16 %r96,%r95,0; @ %r96 bra $L258; .loc 1 2018 0 ld.u16 %r97,[%r75+2]; setp.ne.u16 %r98,%r97,0; @ %r98 bra $L258; ld.u16 %r99,[%r75]; setp.eq.u16 %r100,%r99,0; @ %r100 bra $L259; $L258: mov.u64 %r67,%r76; add.u64 %r51,%r76,16; .loc 1 3750 0 mov.u16 %r101,0; $L260: st.u16 [%r67],%r101; add.u64 %r67,%r67,2; .loc 1 3749 0 setp.ne.u64 %r102,%r51,%r67; @ %r102 bra $L260; .loc 1 3751 0 mov.u16 %r103,-16384; st.u16 [%r76+16],%r103; .loc 1 3757 0 mov.u16 %r104,32767; st.u16 [%r76+18],%r104; bra $L253; $L259: mov.u64 %r49,%r76; add.u64 %r72,%r76,20; .loc 1 2018 0 mov.u64 %r37,%r76; .loc 1 440 0 mov.u16 %r105,%r99; $L262: st.u16 [%r37],%r105; add.u64 %r37,%r37,2; .loc 1 439 0 setp.ne.u64 %r106,%r72,%r37; @ %r106 bra $L262; add.u64 %r38,%r76,18; .loc 1 548 0 mov.u16 %r107,0; $L263: st.u16 [%r49],%r107; add.u64 %r49,%r49,2; .loc 1 547 0 setp.ne.u64 %r108,%r38,%r49; @ %r108 bra $L263; .loc 1 549 0 ld.u16 %r110,[%r76+18]; or.b16 %r109,%r110,32767; st.u16 [%r76+18],%r109; .loc 1 2034 0 ld.u16 %r111,[%frame]; setp.eq.u16 %r112,%r111,0; @ %r112 bra $L253; .loc 1 2035 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r76; call eneg,(%out_arg1); } bra $L253; $L257: .loc 1 2039 0 shr.u32 %r114,%r44,4; cvt.u16.u32 %r115,%r114; cvt.u32.u16 %r56,%r115; ld.u16 %r70,[%r75+4]; ld.u16 %r71,[%r75+2]; ld.u16 %r64,[%r75]; .loc 1 2042 0 setp.ne.u32 %r116,%r56,0; @ %r116 bra $L264; .loc 1 2045 0 and.b16 %r117,%r86,-17; st.u16 [%frame+4],%r117; .loc 1 2048 0 mov.u16 %r119,15360; st.u16 [%frame+2],%r119; .loc 1 2051 0 cvt.u16.u32 %r120,%r70; st.u16 [%frame+6],%r120; .loc 1 2052 0 cvt.u16.u32 %r121,%r71; st.u16 [%frame+8],%r121; .loc 1 2053 0 cvt.u16.u32 %r122,%r64; st.u16 [%frame+10],%r122; mov.u32 %r124,-5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r124; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r125,[%value_in]; } .loc 1 2063 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r127,[%value_in]; } setp.le.s32 %r128,%r127,144; @ %r128 bra $L265; add.u64 %r69,%frame,2; .loc 1 683 0 cvt.u16.u32 %r129,%r56; $L266: st.u16 [%r69],%r129; add.u64 %r69,%r69,2; .loc 1 682 0 setp.ne.u64 %r130,%r62,%r69; @ %r130 bra $L266; bra $L267; $L265: .loc 1 2066 0 ld.u16 %r132,[%frame+2]; add.u16 %r131,%r132,1; cvt.u16.u32 %r134,%r127; sub.u16 %r133,%r131,%r134; st.u16 [%frame+2],%r133; $L267: .loc 1 2068 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r76; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L253; $L264: .loc 1 2047 0 add.u16 %r137,%r115,15360; .loc 1 2048 0 st.u16 [%frame+2],%r137; .loc 1 2051 0 cvt.u16.u32 %r139,%r70; st.u16 [%frame+6],%r139; .loc 1 2052 0 cvt.u16.u32 %r140,%r71; st.u16 [%frame+8],%r140; .loc 1 2053 0 cvt.u16.u32 %r141,%r64; st.u16 [%frame+10],%r141; mov.u32 %r143,-5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r143; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r144,[%value_in]; } bra $L267; $L253: .loc 1 2070 0 st.shared.u64 [%sspslot],%sspprev; ret; } // BEGIN FUNCTION DEF: emul .func emul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,56; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r58; .reg .u32 %r64; .reg .u32 %r65; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r90; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r139; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r142; .reg .u64 %r143; .reg .u16 %r144; .reg .pred %r146; .reg .u32 %r148; .reg .pred %r149; .reg .u16 %r150; .reg .pred %r151; .reg .u16 %r152; .reg .pred %r154; .reg .u32 %r156; .reg .pred %r157; .reg .u16 %r158; .reg .pred %r159; .reg .u16 %r160; .reg .pred %r162; .reg .u32 %r164; .reg .pred %r165; .reg .u64 %r167; .reg .u32 %r168; .reg .pred %r169; .reg .u32 %r171; .reg .pred %r172; .reg .u64 %r174; .reg .u32 %r175; .reg .pred %r176; .reg .u16 %r177; .reg .pred %r178; .reg .u16 %r179; .reg .u16 %r180; .reg .u16 %r181; .reg .u16 %r182; .reg .pred %r183; .reg .u16 %r184; .reg .pred %r186; .reg .u32 %r188; .reg .pred %r189; .reg .u32 %r191; .reg .u32 %r193; .reg .pred %r194; .reg .u32 %r196; .reg .pred %r197; .reg .u16 %r198; .reg .u16 %r199; .reg .u16 %r200; .reg .pred %r201; .reg .u16 %r202; .reg .u16 %r203; .reg .pred %r209; .reg .u16 %r210; .reg .pred %r211; .reg .u32 %r214; .reg .u64 %r215; .reg .pred %r218; .reg .u16 %r219; .reg .pred %r220; .reg .u16 %r221; .reg .u16 %r222; .reg .pred %r223; .reg .u16 %r224; .reg .pred %r225; .reg .u32 %r227; .reg .u64 %r228; .reg .pred %r229; .reg .u16 %r230; .reg .pred %r231; .reg .u32 %r236; .reg .u32 %r239; .reg .u32 %r241; .reg .u64 %r243; .reg .u64 %r244; .reg .u16 %r245; .reg .u16 %r246; .reg .pred %r247; .reg .u16 %r248; .reg .u16 %r249; .reg .u16 %r252; .reg .pred %r254; .reg .u16 %r255; .reg .pred %r257; .reg .u16 %r258; .reg .u16 %r259; .reg .pred %r260; .reg .u32 %r262; .reg .pred %r263; .reg .u32 %r268; .reg .pred %r269; .reg .u32 %r271; .reg .pred %r272; .reg .u32 %r274; .reg .pred %r275; .reg .u64 %r276; .reg .u16 %r277; .reg .u16 %r278; mov.u64 %r140,%ar0; mov.u64 %r141,%ar1; mov.u64 %r142,%ar2; mov.u64 %r143,%ar3; .loc 1 521 0 ld.u16 %r277,[%r140+18]; and.b16 %r144,%r277,32767; setp.ne.u16 %r146,%r144,32767; @ %r146 bra $L278; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r148,[%value_in]; } .loc 1 1622 0 setp.eq.u32 %r149,%r148,0; @ %r149 bra $L279; mov.u64 %r135,%r142; mov.u64 %r136,%r140; add.u64 %r139,%r135,20; $L280: .loc 1 455 0 ld.u16 %r150,[%r136]; st.u16 [%r135],%r150; add.u64 %r135,%r135,2; add.u64 %r136,%r136,2; .loc 1 454 0 setp.ne.u64 %r151,%r135,%r139; @ %r151 bra $L280; bra $L277; $L279: .loc 1 521 0 ld.u16 %r278,[%r141+18]; and.b16 %r152,%r278,32767; setp.ne.u16 %r154,%r152,32767; @ %r154 bra $L282; bra $L350; $L354: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r156,[%value_in]; } .loc 1 1627 0 setp.eq.u32 %r157,%r156,0; @ %r157 bra $L286; $L320: mov.u64 %r114,%r141; mov.u64 %r75,%r142; add.u64 %r131,%r114,20; $L285: .loc 1 455 0 ld.u16 %r158,[%r114]; st.u16 [%r75],%r158; add.u64 %r114,%r114,2; add.u64 %r75,%r75,2; .loc 1 454 0 setp.ne.u64 %r159,%r114,%r131; @ %r159 bra $L285; bra $L277; $L288: .loc 1 501 0 and.b16 %r160,%r278,32767; setp.eq.u16 %r162,%r160,32767; @ %r162 bra $L286; ld.u16 %r277,[%r140+18]; bra $L287; $L355: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r164,[%value_in]; } .loc 1 1633 0 setp.eq.u32 %r165,%r164,0; @ %r165 bra $L288; $L322: cvta.const.u64 %r167,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r167; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r168,[%value_in]; } setp.ne.u32 %r169,%r168,0; @ ! %r169 bra $L291; ld.u16 %r278,[%r141+18]; bra $L288; $L291: mov.u64 %r132,%r142; add.u64 %r134,%r142,16; .loc 1 3750 0 mov.u16 %r177,0; bra $L289; $L286: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r171,[%value_in]; } .loc 1 1634 0 setp.eq.u32 %r172,%r171,0; @ %r172 bra $L290; cvta.const.u64 %r174,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r174; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r175,[%value_in]; } setp.eq.u32 %r176,%r175,0; @ %r176 bra $L291; bra $L351; $L289: .loc 1 3750 0 st.u16 [%r132],%r177; add.u64 %r132,%r132,2; .loc 1 3749 0 setp.ne.u64 %r178,%r132,%r134; @ %r178 bra $L289; .loc 1 3751 0 mov.u16 %r179,-16384; st.u16 [%r142+16],%r179; .loc 1 3757 0 mov.u16 %r180,32767; st.u16 [%r142+18],%r180; bra $L277; $L351: .loc 1 501 0 ld.u16 %r182,[%r140+18]; and.b16 %r181,%r182,32767; setp.eq.u16 %r183,%r181,32767; @ %r183 bra $L294; ld.u16 %r278,[%r141+18]; $L297: and.b16 %r184,%r278,32767; setp.eq.u16 %r186,%r184,32767; @ ! %r186 bra $L296; bra $L295; $L294: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r188,[%value_in]; } .loc 1 1643 0 setp.eq.u32 %r189,%r188,0; @ ! %r189 bra $L300; ld.u16 %r278,[%r141+18]; bra $L297; $L300: .loc 1 1645 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r191,[%value_in]; } { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r193,[%value_in]; } setp.ne.u32 %r194,%r191,%r193; @ %r194 bra $L298; bra $L352; $L295: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r196,[%value_in]; } .loc 1 1643 0 setp.ne.u32 %r197,%r196,0; @ %r197 bra $L300; bra $L296; $L298: .loc 1 1646 0 mov.u16 %r198,-32768; st.u16 [%r142+18],%r198; bra $L301; $L352: .loc 1 1648 0 mov.u16 %r199,0; st.u16 [%r142+18],%r199; $L301: mov.u64 %r90,%r142; add.u64 %r96,%r142,18; .loc 1 548 0 mov.u16 %r200,0; $L302: st.u16 [%r90],%r200; add.u64 %r90,%r90,2; .loc 1 547 0 setp.ne.u64 %r201,%r90,%r96; @ %r201 bra $L302; .loc 1 549 0 ld.u16 %r203,[%r142+18]; or.b16 %r202,%r203,32767; st.u16 [%r142+18],%r202; bra $L277; $L296: .loc 1 1653 0 add.u64 %r276,%frame,26; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r276; call emovi,(%out_arg1,%out_arg2); } .loc 1 1654 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call emovi,(%out_arg1,%out_arg2); } .loc 1 1655 0 ld.u16 %r64,[%frame+28]; .loc 1 1656 0 ld.u16 %r65,[%frame+2]; .loc 1 1657 0 setp.eq.u32 %r209,%r64,0; @ %r209 bra $L303; .loc 1 1670 0 bra $L353; $L307: add.u64 %r113,%r113,2; .loc 1 1661 0 ld.u16 %r210,[%r113+-2]; setp.eq.u16 %r211,%r210,0; @ %r211 bra $L305; .loc 1 1663 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r276; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r214,[%value_in]; } cvt.s64.s32 %r215,%r214; neg.s64 %r73,%r215; ld.u16 %r58,[%frame+2]; .loc 1 1664 0 bra $L306; $L303: add.u64 %r113,%frame,30; add.u64 %r110,%frame,50; $L305: .loc 1 1659 0 setp.ne.u64 %r218,%r110,%r113; @ %r218 bra $L307; mov.u64 %r111,%r142; add.u64 %r117,%r111,20; .loc 1 440 0 mov.u16 %r219,0; $L308: st.u16 [%r111],%r219; add.u64 %r111,%r111,2; .loc 1 439 0 setp.ne.u64 %r220,%r117,%r111; @ %r220 bra $L308; bra $L277; $L353: .loc 1 1655 0 cvt.u16.u32 %r221,%r64; cvt.u64.u16 %r73,%r221; mov.u32 %r58,%r65; $L306: .loc 1 1656 0 cvt.u16.u32 %r222,%r65; cvt.u64.u16 %r74,%r222; .loc 1 1672 0 setp.eq.u32 %r223,%r58,0; @ %r223 bra $L309; .loc 1 1685 0 bra $L310; $L312: add.u64 %r107,%r107,2; .loc 1 1676 0 ld.u16 %r224,[%r107+-2]; setp.eq.u16 %r225,%r224,0; @ %r225 bra $L311; .loc 1 1678 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r227,[%value_in]; } cvt.s64.s32 %r228,%r227; sub.u64 %r74,%r74,%r228; .loc 1 1679 0 bra $L310; $L309: add.u64 %r107,%frame,4; add.u64 %r118,%frame,24; $L311: .loc 1 1674 0 setp.ne.u64 %r229,%r107,%r118; @ %r229 bra $L312; mov.u64 %r97,%r142; add.u64 %r108,%r97,20; .loc 1 440 0 mov.u16 %r230,0; $L313: st.u16 [%r97],%r230; add.u64 %r97,%r97,2; .loc 1 439 0 setp.ne.u64 %r231,%r97,%r108; @ %r231 bra $L313; bra $L277; $L310: .loc 1 1688 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r276; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r143; call (%value_in),emulm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r236,[%value_in]; } .loc 1 1690 0 add.u64 %r243,%r73,%r74; add.u64 %r244,%r243,-16382; .loc 1 1691 0 mov.u32 %r241,64; mov.u32 %r239,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r236; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r239; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r244; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r241; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r143; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 1693 0 ld.u16 %r245,[%frame+26]; ld.u16 %r246,[%frame]; setp.ne.u16 %r247,%r245,%r246; @ %r247 bra $L314; .loc 1 1694 0 cvt.u16.u32 %r248,%r239; st.u16 [%frame],%r248; bra $L315; $L314: .loc 1 1696 0 mov.u16 %r249,-1; st.u16 [%frame],%r249; $L315: .loc 1 1697 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r142; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L277; $L278: .loc 1 521 0 ld.u16 %r278,[%r141+18]; and.b16 %r252,%r278,32767; setp.ne.u16 %r254,%r252,32767; @ %r254 bra $L297; bra $L354; $L287: .loc 1 501 0 and.b16 %r255,%r277,32767; setp.eq.u16 %r257,%r255,32767; @ ! %r257 bra $L296; bra $L318; $L290: ld.u16 %r259,[%r140+18]; and.b16 %r258,%r259,32767; setp.eq.u16 %r260,%r258,32767; @ ! %r260 bra $L296; bra $L319; $L350: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r141; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r262,[%value_in]; } .loc 1 1627 0 setp.ne.u32 %r263,%r262,0; @ %r263 bra $L320; bra $L355; $L282: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r268,[%value_in]; } .loc 1 1633 0 setp.ne.u32 %r269,%r268,0; @ %r269 bra $L322; bra $L287; $L319: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r271,[%value_in]; } .loc 1 1643 0 setp.ne.u32 %r272,%r271,0; @ ! %r272 bra $L295; bra $L300; $L318: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r140; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r274,[%value_in]; } setp.ne.u32 %r275,%r274,0; @ %r275 bra $L300; bra $L296; $L277: .loc 1 1698 0 st.shared.u64 [%sspslot],%sspprev; ret; } // BEGIN FUNCTION DEF: ediv .func ediv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,56; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r66; .reg .u32 %r67; .reg .u32 %r74; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r93; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r134; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .u64 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .pred %r142; .reg .u32 %r144; .reg .pred %r145; .reg .u16 %r146; .reg .pred %r147; .reg .u16 %r148; .reg .u16 %r149; .reg .pred %r150; .reg .u32 %r152; .reg .pred %r153; .reg .u16 %r154; .reg .pred %r155; .reg .u64 %r157; .reg .u32 %r158; .reg .pred %r159; .reg .u16 %r160; .reg .u16 %r161; .reg .u16 %r162; .reg .u16 %r163; .reg .pred %r164; .reg .u32 %r167; .reg .pred %r168; .reg .u32 %r170; .reg .pred %r171; .reg .pred %r173; .reg .u32 %r175; .reg .pred %r176; .reg .u16 %r177; .reg .pred %r178; .reg .u16 %r179; .reg .u16 %r180; .reg .pred %r182; .reg .u32 %r184; .reg .pred %r185; .reg .u32 %r187; .reg .u32 %r189; .reg .pred %r190; .reg .u16 %r191; .reg .u16 %r192; .reg .u16 %r193; .reg .pred %r194; .reg .u16 %r195; .reg .u16 %r196; .reg .u16 %r197; .reg .pred %r198; .reg .pred %r204; .reg .u16 %r205; .reg .pred %r206; .reg .u32 %r208; .reg .u64 %r209; .reg .pred %r210; .reg .u16 %r211; .reg .pred %r212; .reg .u16 %r213; .reg .u16 %r214; .reg .pred %r215; .reg .u16 %r216; .reg .pred %r217; .reg .u32 %r220; .reg .u64 %r221; .reg .pred %r224; .reg .u16 %r225; .reg .u16 %r226; .reg .pred %r227; .reg .u16 %r228; .reg .u16 %r229; .reg .u16 %r230; .reg .pred %r231; .reg .u16 %r232; .reg .u16 %r233; .reg .u32 %r238; .reg .u32 %r241; .reg .u32 %r243; .reg .u64 %r245; .reg .u64 %r246; .reg .u16 %r247; .reg .u16 %r248; .reg .pred %r249; .reg .u16 %r250; .reg .u16 %r251; .reg .pred %r255; .reg .u32 %r257; .reg .pred %r258; .reg .u64 %r259; mov.u64 %r136,%ar0; mov.u64 %r137,%ar1; mov.u64 %r138,%ar2; mov.u64 %r139,%ar3; .loc 1 521 0 ld.u16 %r141,[%r136+18]; and.b16 %r140,%r141,32767; setp.ne.u16 %r142,%r140,32767; @ %r142 bra $L357; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r144,[%value_in]; } .loc 1 1518 0 setp.eq.u32 %r145,%r144,0; @ %r145 bra $L357; mov.u64 %r118,%r138; mov.u64 %r117,%r136; add.u64 %r98,%r118,20; $L358: .loc 1 455 0 ld.u16 %r146,[%r117]; st.u16 [%r118],%r146; add.u64 %r118,%r118,2; add.u64 %r117,%r117,2; .loc 1 454 0 setp.ne.u64 %r147,%r98,%r118; @ %r147 bra $L358; bra $L356; $L357: .loc 1 521 0 ld.u16 %r149,[%r137+18]; and.b16 %r148,%r149,32767; setp.ne.u16 %r150,%r148,32767; @ %r150 bra $L360; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r152,[%value_in]; } .loc 1 1523 0 setp.eq.u32 %r153,%r152,0; @ %r153 bra $L360; mov.u64 %r114,%r137; mov.u64 %r123,%r138; add.u64 %r124,%r114,20; $L361: .loc 1 455 0 ld.u16 %r154,[%r114]; st.u16 [%r123],%r154; add.u64 %r114,%r114,2; add.u64 %r123,%r123,2; .loc 1 454 0 setp.ne.u64 %r155,%r114,%r124; @ %r155 bra $L361; bra $L356; $L360: .loc 1 1529 0 cvta.const.u64 %r157,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r157; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r158,[%value_in]; } setp.eq.u32 %r159,%r158,0; @ %r159 bra $L362; $L365: ld.u16 %r161,[%r137+18]; and.b16 %r160,%r161,32767; .loc 1 501 0 ld.u16 %r163,[%r136+18]; and.b16 %r162,%r163,32767; setp.eq.u16 %r164,%r162,32767; @ ! %r164 bra $L413; bra $L363; $L362: .loc 1 1529 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r157; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r167,[%value_in]; } setp.ne.u32 %r168,%r167,0; @ %r168 bra $L365; $L369: mov.u64 %r125,%r138; add.u64 %r99,%r138,16; .loc 1 3750 0 mov.u16 %r177,0; bra $L366; $L363: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r170,[%value_in]; } .loc 1 1530 0 setp.eq.u32 %r171,%r170,0; @ %r171 bra $L367; .loc 1 501 0 setp.ne.u16 %r173,%r160,32767; @ %r173 bra $L368; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r175,[%value_in]; } .loc 1 1530 0 setp.ne.u32 %r176,%r175,0; @ %r176 bra $L369; bra $L368; $L366: .loc 1 3750 0 st.u16 [%r125],%r177; add.u64 %r125,%r125,2; .loc 1 3749 0 setp.ne.u64 %r178,%r99,%r125; @ %r178 bra $L366; .loc 1 3751 0 mov.u16 %r179,-16384; st.u16 [%r138+16],%r179; .loc 1 3757 0 mov.u16 %r180,32767; st.u16 [%r138+18],%r180; bra $L356; $L367: .loc 1 501 0 setp.ne.u16 %r182,%r160,32767; @ %r182 bra $L371; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r184,[%value_in]; } .loc 1 1539 0 setp.eq.u32 %r185,%r184,0; @ %r185 bra $L371; $L392: .loc 1 1541 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r187,[%value_in]; } { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r189,[%value_in]; } setp.eq.u32 %r190,%r187,%r189; @ %r190 bra $L372; .loc 1 1542 0 mov.u16 %r191,-32768; st.u16 [%r138+18],%r191; bra $L373; $L372: .loc 1 1544 0 mov.u16 %r192,0; st.u16 [%r138+18],%r192; $L373: mov.u64 %r103,%r138; add.u64 %r104,%r138,18; .loc 1 548 0 mov.u16 %r193,0; $L374: st.u16 [%r103],%r193; add.u64 %r103,%r103,2; .loc 1 547 0 setp.ne.u64 %r194,%r104,%r103; @ %r194 bra $L374; .loc 1 549 0 ld.u16 %r196,[%r138+18]; or.b16 %r195,%r196,32767; st.u16 [%r138+18],%r195; bra $L356; $L368: mov.u64 %r128,%r138; add.u64 %r126,%r128,20; .loc 1 440 0 mov.u16 %r197,0; $L375: st.u16 [%r128],%r197; add.u64 %r128,%r128,2; .loc 1 439 0 setp.ne.u64 %r198,%r126,%r128; @ %r198 bra $L375; bra $L356; $L371: .loc 1 1554 0 add.u64 %r259,%frame,26; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r259; call emovi,(%out_arg1,%out_arg2); } .loc 1 1555 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call emovi,(%out_arg1,%out_arg2); } .loc 1 1556 0 ld.u16 %r66,[%frame+28]; .loc 1 1557 0 ld.u16 %r67,[%frame+2]; .loc 1 1558 0 setp.eq.u32 %r204,%r67,0; @ %r204 bra $L376; .loc 1 1571 0 bra $L414; $L380: add.u64 %r110,%r110,2; .loc 1 1562 0 ld.u16 %r205,[%r110+-2]; setp.eq.u16 %r206,%r205,0; @ %r206 bra $L378; .loc 1 1564 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r208,[%value_in]; } cvt.s64.s32 %r209,%r208; neg.s64 %r79,%r209; ld.u16 %r74,[%frame+28]; .loc 1 1565 0 bra $L379; $L376: add.u64 %r110,%frame,4; add.u64 %r115,%frame,24; $L378: .loc 1 1560 0 setp.ne.u64 %r210,%r110,%r115; @ %r210 bra $L380; mov.u64 %r113,%r138; add.u64 %r111,%r113,20; .loc 1 440 0 mov.u16 %r211,0; $L381: st.u16 [%r113],%r211; add.u64 %r113,%r113,2; .loc 1 439 0 setp.ne.u64 %r212,%r111,%r113; @ %r212 bra $L381; bra $L356; $L414: .loc 1 1557 0 cvt.u16.u32 %r213,%r67; cvt.u64.u16 %r79,%r213; mov.u32 %r74,%r66; $L379: .loc 1 1556 0 cvt.u16.u32 %r214,%r66; cvt.u64.u16 %r78,%r214; .loc 1 1573 0 setp.eq.u32 %r215,%r74,0; @ %r215 bra $L382; .loc 1 1591 0 bra $L383; $L385: add.u64 %r134,%r134,2; .loc 1 1577 0 ld.u16 %r216,[%r134+-2]; setp.eq.u16 %r217,%r216,0; @ %r217 bra $L384; .loc 1 1579 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r259; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r220,[%value_in]; } cvt.s64.s32 %r221,%r220; sub.u64 %r78,%r78,%r221; .loc 1 1580 0 bra $L383; $L382: add.u64 %r134,%frame,30; add.u64 %r129,%frame,50; $L384: .loc 1 1575 0 setp.ne.u64 %r224,%r129,%r134; @ %r224 bra $L385; .loc 1 1583 0 ld.u16 %r225,[%frame+26]; ld.u16 %r226,[%frame]; setp.ne.u16 %r227,%r225,%r226; @ %r227 bra $L386; .loc 1 1584 0 mov.u16 %r228,0; st.u16 [%r138+18],%r228; bra $L387; $L386: .loc 1 1586 0 mov.u16 %r229,-32768; st.u16 [%r138+18],%r229; $L387: mov.u64 %r93,%r138; add.u64 %r80,%r138,18; .loc 1 548 0 mov.u16 %r230,0; $L388: st.u16 [%r93],%r230; add.u64 %r93,%r93,2; .loc 1 547 0 setp.ne.u64 %r231,%r80,%r93; @ %r231 bra $L388; .loc 1 549 0 ld.u16 %r233,[%r138+18]; or.b16 %r232,%r233,32767; st.u16 [%r138+18],%r232; bra $L356; $L383: .loc 1 1593 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r259; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r139; call (%value_in),edivm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r238,[%value_in]; } .loc 1 1595 0 sub.u64 %r245,%r79,%r78; add.u64 %r246,%r245,16383; .loc 1 1596 0 mov.u32 %r243,64; mov.u32 %r241,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r238; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r241; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r246; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r243; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r139; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 1598 0 ld.u16 %r247,[%frame+26]; ld.u16 %r248,[%frame]; setp.ne.u16 %r249,%r247,%r248; @ %r249 bra $L389; .loc 1 1599 0 cvt.u16.u32 %r250,%r241; st.u16 [%frame],%r250; bra $L390; $L389: .loc 1 1601 0 mov.u16 %r251,-1; st.u16 [%frame],%r251; $L390: .loc 1 1602 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r138; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L356; $L413: .loc 1 501 0 setp.ne.u16 %r255,%r160,32767; @ %r255 bra $L371; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r137; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r257,[%value_in]; } .loc 1 1539 0 setp.ne.u32 %r258,%r257,0; @ %r258 bra $L392; bra $L371; $L356: .loc 1 1603 0 st.shared.u64 [%sspslot],%sspprev; ret; } // BEGIN GLOBAL FUNCTION DEF: _ldtoa_r .visible .func (.param .u64 %value_out) _ldtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %ar5; ld.param.u64 %ar5,[%in_ar5]; .reg .u64 %ar6; ld.param.u64 %ar6,[%in_ar6]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,352; sub.u64 %stack,%frame,8; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r271; .reg .u32 %r272; .reg .u64 %r273; .reg .u32 %r275; .reg .u32 %r278; .reg .u32 %r279; .reg .u64 %r293; .reg .u32 %r294; .reg .u32 %r304; .reg .u32 %r305; .reg .u64 %r306; .reg .u32 %r308; .reg .u64 %r310; .reg .u32 %r313; .reg .u64 %r316; .reg .u64 %r317; .reg .u32 %r319; .reg .u64 %r320; .reg .u32 %r323; .reg .u64 %r327; .reg .u32 %r329; .reg .u64 %r331; .reg .u64 %r332; .reg .u32 %r335; .reg .u64 %r341; .reg .u64 %r344; .reg .u64 %r347; .reg .u32 %r348; .reg .u64 %r355; .reg .u64 %r356; .reg .u64 %r357; .reg .u32 %r359; .reg .u64 %r370; .reg .u64 %r376; .reg .u64 %r378; .reg .u64 %r381; .reg .u64 %r382; .reg .u64 %r390; .reg .u64 %r395; .reg .u64 %r397; .reg .u64 %r398; .reg .u32 %r401; .reg .u32 %r402; .reg .u64 %r406; .reg .u64 %r409; .reg .u32 %r411; .reg .u32 %r416; .reg .u64 %r417; .reg .u64 %r421; .reg .u32 %r422; .reg .u32 %r427; .reg .u64 %r428; .reg .u64 %r429; .reg .u32 %r430; .reg .u32 %r435; .reg .u64 %r436; .reg .u64 %r445; .reg .u64 %r448; .reg .u64 %r449; .reg .u64 %r450; .reg .u64 %r452; .reg .u64 %r455; .reg .u32 %r462; .reg .u32 %r467; .reg .u64 %r468; .reg .u32 %r473; .reg .u64 %r475; .reg .u32 %r479; .reg .u64 %r480; .reg .u32 %r482; .reg .u32 %r484; .reg .u32 %r488; .reg .u64 %r489; .reg .u64 %r490; .reg .u64 %r497; .reg .u64 %r500; .reg .u64 %r501; .reg .u32 %r502; .reg .u64 %r506; .reg .u32 %r507; .reg .u64 %r508; .reg .u64 %r510; .reg .u32 %r512; .reg .u32 %r520; .reg .u64 %r522; .reg .u32 %r524; .reg .u32 %r525; .reg .u32 %r527; .reg .u32 %r529; .reg .u64 %r531; .reg .u64 %r533; .reg .u32 %r535; .reg .u32 %r538; .reg .u32 %r539; .reg .u64 %r540; .reg .u64 %r549; .reg .u64 %r550; .reg .u64 %r552; .reg .u64 %r558; .reg .u64 %r559; .reg .u64 %r560; .reg .u64 %r564; .reg .u64 %r565; .reg .u64 %r568; .reg .u64 %r573; .reg .u64 %r574; .reg .u64 %r578; .reg .u64 %r579; .reg .u64 %r581; .reg .u64 %r588; .reg .u64 %r589; .reg .u32 %r591; .reg .u64 %r592; .reg .u32 %r596; .reg .u32 %r602; .reg .u64 %r603; .reg .u64 %r604; .reg .u64 %r609; .reg .u64 %r610; .reg .u64 %r615; .reg .u32 %r620; .reg .u64 %r625; .reg .u64 %r628; .reg .u64 %r629; .reg .u64 %r637; .reg .u64 %r640; .reg .u64 %r641; .reg .u32 %r642; .reg .u32 %r643; .reg .u64 %r644; .reg .u64 %r645; .reg .u32 %r646; .reg .u64 %r647; .reg .u32 %r648; .reg .u64 %r653; .reg .u64 %r654; .reg .u64 %r656; .reg .u32 %r658; .reg .u64 %r661; .reg .u64 %r662; .reg .u32 %r663; .reg .u32 %r664; .reg .u64 %r668; .reg .u64 %r671; .reg .u64 %r672; .reg .u64 %r674; .reg .u32 %r676; .reg .u64 %r679; .reg .u64 %r681; .reg .u64 %r682; .reg .u64 %r683; .reg .u32 %r685; .reg .u64 %r687; .reg .u32 %r688; .reg .u64 %r689; .reg .u32 %r693; .reg .u64 %r694; .reg .u64 %r695; .reg .u64 %r698; .reg .u64 %r699; .reg .u64 %r701; .reg .u32 %r704; .reg .u64 %r705; .reg .u64 %r706; .reg .u32 %r713; .reg .u64 %r719; .reg .u32 %r722; .reg .u32 %r723; .reg .u64 %r727; .reg .u32 %r732; .reg .u32 %r734; .reg .u64 %r740; .reg .f64 %r741; .reg .u32 %r742; .reg .u32 %r743; .reg .u64 %r744; .reg .u64 %r745; .reg .u64 %r746; .reg .u32 %r771; .reg .u32 %r772; .reg .pred %r773; .reg .u32 %r774; .reg .u32 %r775; .reg .u64 %r778; .reg .u64 %r782; .reg .u32 %r785; .reg .pred %r786; .reg .u32 %r787; .reg .pred %r789; .reg .pred %r790; .reg .u16 %r791; .reg .u16 %r792; .reg .pred %r793; .reg .u32 %r796; .reg .pred %r797; .reg .u64 %r799; .reg .u32 %r801; .reg .u32 %r803; .reg .u16 %r804; .reg .pred %r805; .reg .u16 %r806; .reg .pred %r807; .reg .u16 %r808; .reg .u16 %r811; .reg .pred %r812; .reg .pred %r813; .reg .u16 %r814; .reg .pred %r815; .reg .pred %r816; .reg .pred %r817; .reg .u64 %r819; .reg .u32 %r821; .reg .u64 %r824; .reg .u32 %r826; .reg .u16 %r828; .reg .pred %r829; .reg .u64 %r831; .reg .u32 %r833; .reg .u32 %r838; .reg .pred %r839; .reg .pred %r840; .reg .u16 %r841; .reg .pred %r842; .reg .u16 %r843; .reg .u16 %r850; .reg .pred %r851; .reg .u16 %r852; .reg .u16 %r853; .reg .u32 %r854; .reg .pred %r855; .reg .u16 %r856; .reg .u32 %r866; .reg .u16 %r867; .reg .pred %r868; .reg .pred %r869; .reg .pred %r870; .reg .u32 %r871; .reg .u64 %r872; .reg .u16 %r874; .reg .pred %r875; .reg .u64 %r877; .reg .u64 %r878; .reg .u32 %r879; .reg .u32 %r881; .reg .u64 %r883; .reg .u64 %r884; .reg .u64 %r885; .reg .u64 %r886; .reg .u16 %r887; .reg .u16 %r888; .reg .u16 %r889; .reg .u16 %r890; .reg .pred %r891; .reg .u16 %r892; .reg .u16 %r893; .reg .pred %r894; .reg .u16 %r895; .reg .u16 %r896; .reg .pred %r897; .reg .u32 %r900; .reg .pred %r901; .reg .u32 %r904; .reg .pred %r905; .reg .u16 %r913; .reg .u16 %r914; .reg .u16 %r916; .reg .u64 %r917; .reg .pred %r918; .reg .u16 %r919; .reg .pred %r920; .reg .u16 %r921; .reg .u16 %r922; .reg .pred %r923; .reg .u16 %r924; .reg .u16 %r925; .reg .pred %r926; .reg .u16 %r927; .reg .pred %r928; .reg .pred %r929; .reg .u32 %r931; .reg .u32 %r933; .reg .u16 %r936; .reg .u16 %r937; .reg .pred %r938; .reg .pred %r939; .reg .pred %r942; .reg .u16 %r943; .reg .pred %r945; .reg .u16 %r946; .reg .pred %r956; .reg .u16 %r957; .reg .pred %r958; .reg .u16 %r959; .reg .pred %r960; .reg .u16 %r961; .reg .u16 %r962; .reg .u16 %r963; .reg .u16 %r964; .reg .u16 %r966; .reg .u16 %r967; .reg .pred %r968; .reg .u16 %r969; .reg .u16 %r971; .reg .u16 %r972; .reg .pred %r975; .reg .u16 %r978; .reg .pred %r979; .reg .pred %r980; .reg .u16 %r981; .reg .pred %r982; .reg .u16 %r983; .reg .u16 %r984; .reg .pred %r985; .reg .u16 %r986; .reg .u16 %r987; .reg .pred %r988; .reg .u16 %r989; .reg .u16 %r990; .reg .u16 %r991; .reg .pred %r992; .reg .u64 %r993; .reg .u64 %r994; .reg .u64 %r995; .reg .u64 %r996; .reg .u64 %r997; .reg .u32 %r999; .reg .pred %r1002; .reg .u64 %r1003; .reg .u64 %r1004; .reg .u64 %r1005; .reg .u64 %r1006; .reg .u64 %r1007; .reg .u32 %r1009; .reg .pred %r1012; .reg .u32 %r1017; .reg .pred %r1024; .reg .u16 %r1025; .reg .u16 %r1026; .reg .pred %r1027; .reg .pred %r1028; .reg .u16 %r1029; .reg .pred %r1030; .reg .u32 %r1031; .reg .u16 %r1032; .reg .pred %r1034; .reg .u16 %r1035; .reg .u16 %r1036; .reg .u16 %r1037; .reg .u16 %r1038; .reg .u16 %r1039; .reg .pred %r1040; .reg .u16 %r1041; .reg .pred %r1042; .reg .u32 %r1046; .reg .pred %r1047; .reg .u32 %r1060; .reg .u16 %r1061; .reg .pred %r1063; .reg .u32 %r1068; .reg .pred %r1069; .reg .u16 %r1070; .reg .pred %r1071; .reg .u16 %r1072; .reg .pred %r1073; .reg .u16 %r1081; .reg .pred %r1082; .reg .u16 %r1087; .reg .u16 %r1088; .reg .pred %r1089; .reg .u16 %r1090; .reg .pred %r1091; .reg .u16 %r1092; .reg .u64 %r1097; .reg .u64 %r1098; .reg .u64 %r1099; .reg .u64 %r1100; .reg .u64 %r1101; .reg .u32 %r1103; .reg .pred %r1106; .reg .u16 %r1109; .reg .pred %r1110; .reg .u16 %r1115; .reg .pred %r1116; .reg .u16 %r1117; .reg .pred %r1118; .reg .pred %r1120; .reg .u16 %r1121; .reg .pred %r1122; .reg .u16 %r1123; .reg .pred %r1124; .reg .u16 %r1129; .reg .pred %r1130; .reg .u16 %r1131; .reg .pred %r1132; .reg .u32 %r1136; .reg .pred %r1137; .reg .u32 %r1151; .reg .u32 %r1152; .reg .pred %r1154; .reg .u32 %r1160; .reg .pred %r1161; .reg .u16 %r1172; .reg .pred %r1173; .reg .u16 %r1174; .reg .u16 %r1179; .reg .pred %r1180; .reg .u16 %r1181; .reg .pred %r1187; .reg .u16 %r1188; .reg .pred %r1189; .reg .u16 %r1190; .reg .u16 %r1191; .reg .u16 %r1192; .reg .u16 %r1193; .reg .u16 %r1194; .reg .u16 %r1195; .reg .pred %r1196; .reg .u16 %r1198; .reg .u16 %r1200; .reg .u16 %r1201; .reg .pred %r1204; .reg .u16 %r1205; .reg .pred %r1206; .reg .u16 %r1207; .reg .u16 %r1208; .reg .pred %r1209; .reg .u16 %r1210; .reg .u16 %r1211; .reg .u16 %r1212; .reg .u16 %r1213; .reg .u16 %r1214; .reg .u16 %r1215; .reg .pred %r1216; .reg .u16 %r1218; .reg .u16 %r1220; .reg .u16 %r1221; .reg .pred %r1224; .reg .u16 %r1225; .reg .pred %r1226; .reg .u16 %r1227; .reg .u16 %r1228; .reg .u16 %r1229; .reg .u16 %r1230; .reg .u16 %r1231; .reg .u16 %r1232; .reg .pred %r1233; .reg .u16 %r1235; .reg .u16 %r1237; .reg .u16 %r1238; .reg .pred %r1241; .reg .u64 %r1242; .reg .u64 %r1243; .reg .u64 %r1244; .reg .u64 %r1245; .reg .u64 %r1246; .reg .u32 %r1248; .reg .pred %r1251; .reg .pred %r1257; .reg .u32 %r1261; .reg .pred %r1262; .reg .pred %r1263; .reg .u32 %r1264; .reg .u32 %r1265; .reg .pred %r1266; .reg .pred %r1267; .reg .pred %r1268; .reg .u32 %r1269; .reg .u32 %r1270; .reg .u32 %r1271; .reg .pred %r1272; .reg .u32 %r1273; .reg .u32 %r1274; .reg .pred %r1275; .reg .u32 %r1276; .reg .pred %r1277; .reg .u16 %r1279; .reg .u16 %r1280; .reg .u32 %r1281; .reg .u32 %r1282; .reg .u16 %r1284; .reg .u16 %r1285; .reg .u32 %r1286; .reg .u32 %r1287; .reg .pred %r1288; .reg .u16 %r1289; .reg .pred %r1290; .reg .u16 %r1291; .reg .u16 %r1292; .reg .u16 %r1293; .reg .u16 %r1294; .reg .u16 %r1295; .reg .u16 %r1296; .reg .pred %r1297; .reg .u16 %r1299; .reg .u16 %r1301; .reg .u16 %r1302; .reg .pred %r1305; .reg .u16 %r1306; .reg .pred %r1307; .reg .u16 %r1308; .reg .u16 %r1309; .reg .pred %r1310; .reg .u16 %r1311; .reg .u16 %r1312; .reg .u16 %r1313; .reg .u16 %r1314; .reg .u16 %r1315; .reg .u16 %r1316; .reg .pred %r1317; .reg .u16 %r1319; .reg .u16 %r1321; .reg .u16 %r1322; .reg .pred %r1325; .reg .u16 %r1326; .reg .pred %r1327; .reg .u16 %r1328; .reg .u16 %r1329; .reg .u16 %r1330; .reg .u16 %r1331; .reg .u16 %r1332; .reg .u16 %r1333; .reg .pred %r1334; .reg .u16 %r1336; .reg .u16 %r1338; .reg .u16 %r1339; .reg .pred %r1342; .reg .u64 %r1343; .reg .u64 %r1344; .reg .u64 %r1345; .reg .u64 %r1346; .reg .u64 %r1347; .reg .u32 %r1349; .reg .pred %r1352; .reg .u16 %r1359; .reg .u16 %r1360; .reg .u32 %r1361; .reg .pred %r1362; .reg .u64 %r1363; .reg .u64 %r1364; .reg .u16 %r1365; .reg .pred %r1366; .reg .pred %r1367; .reg .u64 %r1373; .reg .u32 %r1375; .reg .pred %r1376; .reg .pred %r1377; .reg .u64 %r1378; .reg .u16 %r1379; .reg .u32 %r1380; .reg .u64 %r1383; .reg .u16 %r1385; .reg .u16 %r1386; .reg .u32 %r1387; .reg .u16 %r1388; .reg .u32 %r1389; .reg .pred %r1390; .reg .u16 %r1392; .reg .u16 %r1393; .reg .u32 %r1394; .reg .pred %r1395; .reg .u16 %r1396; .reg .pred %r1397; .reg .pred %r1398; .reg .u32 %r1399; .reg .pred %r1400; .reg .u32 %r1401; .reg .pred %r1402; .reg .u32 %r1403; .reg .u16 %r1405; .reg .u16 %r1406; .reg .u32 %r1407; .reg .u16 %r1408; .reg .pred %r1409; .reg .u64 %r1411; .reg .u32 %r1412; .reg .u16 %r1414; .reg .u16 %r1415; .reg .pred %r1416; .reg .u32 %r1419; .reg .pred %r1420; .reg .u32 %r1423; .reg .pred %r1424; .reg .u32 %r1425; .reg .u32 %r1426; .reg .pred %r1427; .reg .u16 %r1428; .reg .pred %r1429; .reg .u16 %r1430; .reg .pred %r1431; .reg .pred %r1432; .reg .u32 %r1433; .reg .pred %r1434; .reg .u16 %r1436; .reg .u32 %r1437; .reg .u32 %r1438; .reg .u32 %r1439; .reg .u32 %r1442; .reg .u32 %r1443; .reg .u16 %r1444; .reg .u16 %r1445; .reg .u16 %r1446; .reg .u32 %r1447; .reg .u16 %r1448; .reg .pred %r1449; .reg .pred %r1451; .reg .u32 %r1452; .reg .u16 %r1454; .reg .u32 %r1455; .reg .u32 %r1456; .reg .u32 %r1459; .reg .u32 %r1460; .reg .u16 %r1461; .reg .u16 %r1462; .reg .u16 %r1463; .reg .u32 %r1464; .reg .u16 %r1465; .reg .pred %r1466; .reg .u16 %r1468; .reg .u32 %r1469; .reg .u32 %r1470; .reg .u32 %r1473; .reg .u32 %r1474; .reg .u16 %r1475; .reg .u16 %r1476; .reg .u16 %r1477; .reg .u32 %r1478; .reg .u16 %r1479; .reg .pred %r1480; .reg .u32 %r1481; .reg .pred %r1482; .reg .pred %r1483; .reg .u32 %r1484; .reg .u16 %r1485; .reg .pred %r1486; .reg .u32 %r1487; .reg .u16 %r1488; .reg .u32 %r1489; .reg .pred %r1490; .reg .u64 %r1491; .reg .pred %r1492; .reg .u64 %r1493; .reg .pred %r1494; .reg .pred %r1495; .reg .u32 %r1496; .reg .u32 %r1497; .reg .pred %r1498; .reg .u32 %r1499; .reg .u32 %r1500; .reg .u32 %r1501; .reg .pred %r1502; .reg .u64 %r1504; .reg .u64 %r1505; .reg .pred %r1506; .reg .u64 %r1509; .reg .u64 %r1513; .reg .pred %r1514; .reg .u64 %r1516; .reg .u64 %r1517; .reg .u16 %r1519; .reg .pred %r1520; .reg .u32 %r1521; .reg .u16 %r1522; .reg .u32 %r1524; .reg .u16 %r1525; .reg .pred %r1526; .reg .u64 %r1527; .reg .pred %r1528; .reg .u64 %r1529; .reg .u64 %r1530; .reg .u64 %r1532; .reg .u64 %r1533; .reg .u64 %r1534; .reg .u64 %r1535; .reg .u64 %r1536; .reg .u64 %r1537; .reg .u16 %r1538; .reg .u64 %r1539; .reg .u64 %r1540; .reg .u64 %r1541; .reg .u64 %r1542; .reg .u64 %r1543; .reg .u64 %r1544; .reg .u64 %r1545; .reg .u64 %r1546; .reg .u64 %r1547; .reg .u64 %r1548; .reg .u64 %r1549; .reg .u64 %r1550; .reg .u64 %r1551; .reg .u64 %r1552; .reg .u32 %r1568; .reg .u64 %r1569; .reg .u64 %r1570; .reg .u64 %r1571; .reg .u64 %r1572; .reg .u64 %r1573; .reg .u64 %r1574; .reg .u64 %r1575; .reg .u64 %r1576; .reg .u64 %r1577; .reg .u64 %r1578; .reg .u64 %r1579; .reg .u64 %r1580; .reg .u64 %r1581; .reg .u64 %r1582; .reg .u64 %r1583; .reg .u64 %r1584; .reg .u64 %r1585; .reg .u16 %r1596; mov.u64 %r740,%ar0; mov.f64 %r741,%ar1; mov.u32 %r742,%ar2; mov.u32 %r743,%ar3; mov.u64 %r744,%ar4; mov.u64 %r745,%ar5; mov.u64 %r746,%ar6; .loc 1 2721 0 st.f64 [%frame+344],%r741; .loc 1 2724 0 mov.u32 %r771,-1; st.u32 [%frame],%r771; .loc 1 2725 0 mov.u32 %r772,144; st.u32 [%frame+4],%r772; .loc 1 2730 0 ld.u64 %r271,[%r740+96]; setp.eq.u64 %r773,%r271,0; @ %r773 bra $L416; .loc 1 2732 0 ld.u32 %r272,[%r740+104]; st.u32 [%r271+8],%r272; .loc 1 2733 0 mov.u32 %r775,1; shl.b32 %r774,%r775,%r272; st.u32 [%r271+12],%r774; .loc 1 2734 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r740; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r271; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 2735 0 mov.u64 %r778,0; st.u64 [%r740+96],%r778; $L416: .loc 1 2741 0 add.u64 %r1542,%frame,294; add.u64 %r782,%frame,344; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r782; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1542; call e53toe$isra$9,(%out_arg1,%out_arg2); } .loc 1 2748 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisneg,(%out_arg1); ld.param.u32 %r785,[%value_in]; } setp.eq.u32 %r786,%r785,0; @ %r786 bra $L417; .loc 1 2749 0 mov.u32 %r787,1; st.u32 [%r745],%r787; bra $L418; $L417: .loc 1 2751 0 st.u32 [%r745],%r785; $L418: .loc 1 2753 0 setp.eq.u32 %r789,%r742,3; @ %r789 bra $L582; .loc 1 2758 0 setp.eq.u32 %r790,%r742,0; @ %r790 bra $L583; .loc 1 2754 0 add.u32 %r313,%r743,-1; bra $L419; $L582: mov.u32 %r313,%r743; $L419: min.s32 %r304,%r313,42; bra $L420; $L583: .loc 1 2759 0 mov.u32 %r304,20; $L420: .loc 1 2910 0 ld.u32 %r323,[%frame+4]; .loc 1 521 0 ld.u16 %r792,[%frame+312]; and.b16 %r791,%r792,32767; setp.ne.u16 %r793,%r791,32767; @ %r793 bra $L421; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r796,[%value_in]; } .loc 1 2912 0 setp.eq.u32 %r797,%r796,0; @ %r797 bra $L421; .loc 1 2914 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r799,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r799; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r801,[%value_in]; } .loc 1 2915 0 mov.u32 %r529,9999; bra $L422; $L421: .loc 1 2919 0 mov.u32 %r803,144; st.u32 [%frame+4],%r803; mov.u64 %r699,%r1542; add.u64 %r1539,%frame,268; add.u64 %r695,%frame,314; mov.u64 %r698,%r1539; $L423: .loc 1 455 0 ld.u16 %r804,[%r699]; st.u16 [%r698],%r804; add.u64 %r699,%r699,2; add.u64 %r698,%r698,2; .loc 1 454 0 setp.ne.u64 %r805,%r695,%r699; @ %r805 bra $L423; .loc 1 2921 0 ld.u16 %r329,[%frame+286]; cvt.u16.u32 %r806,%r329; setp.ge.s16 %r807,%r806,0; @ %r807 bra $L584; .loc 1 2924 0 and.b16 %r808,%r806,32767; cvt.u32.u16 %r329,%r808; st.u16 [%frame+286],%r808; .loc 1 2923 0 mov.u32 %r335,65535; bra $L424; $L584: .loc 1 2928 0 mov.u32 %r335,0; $L424: add.u64 %r1537,%frame,242; mov.u64 %r421,%r1537; add.u64 %r701,%frame,262; .loc 1 2923 0 mov.u64 %r588,%r1537; mov.u32 %r658,0; cvta.const.u64 %r1532,eone; mov.u64 %r331,%r1532; $L426: .loc 1 455 0 add.u64 %r331,%r331,2; cvt.u16.u32 %r811,%r658; st.u16 [%r588],%r811; add.u64 %r588,%r588,2; .loc 1 454 0 setp.eq.u64 %r812,%r701,%r588; @ %r812 bra $L425; ld.u16 %r658,[%r331]; bra $L426; $L425: .loc 1 2934 0 setp.ne.u32 %r813,%r329,0; @ %r813 bra $L427; add.u64 %r564,%r1539,18; mov.u64 %r592,%r1539; $L429: .loc 1 2938 0 ld.u16 %r814,[%r592]; setp.ne.u16 %r815,%r814,0; @ %r815 bra $L428; add.u64 %r592,%r592,2; .loc 1 2936 0 setp.ne.u64 %r816,%r564,%r592; @ %r816 bra $L429; $L432: .loc 1 2930 0 mov.u32 %r529,0; add.u64 %r1550,%frame,80; add.u64 %r1530,%frame,190; add.u64 %r1533,%frame,214; bra $L430; $L578: .loc 1 2949 0 setp.eq.u32 %r817,%r335,0; @ %r817 bra $L431; .loc 1 2950 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r819,$LC1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r819; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r821,[%value_in]; } .loc 1 2953 0 mov.u32 %r529,9999; bra $L422; $L431: .loc 1 2952 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r824,$LC2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r824; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r826,[%value_in]; } .loc 1 2953 0 mov.u32 %r529,9999; bra $L422; $L689: .loc 1 2960 0 ld.u16 %r828,[%frame+284]; setp.lt.s16 %r829,%r828,0; @ %r829 bra $L428; .loc 1 2963 0 add.u64 %r1550,%frame,80; cvta.const.u64 %r831,$LC3; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1550; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r831; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r833,[%value_in]; } .loc 1 2964 0 mov.u32 %r529,9999; bra $L422; $L428: .loc 1 2969 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1532; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r838,[%value_in]; } .loc 1 2970 0 setp.eq.u32 %r839,%r838,0; @ %r839 bra $L432; .loc 1 2973 0 setp.ge.s32 %r840,%r838,0; @ %r840 bra $L433; add.u64 %r1534,%frame,216; mov.u64 %r397,%r1534; add.u64 %r552,%r1539,20; mov.u64 %r560,%r1534; mov.u64 %r558,%r1539; $L434: .loc 1 455 0 ld.u16 %r841,[%r558]; st.u16 [%r560],%r841; add.u64 %r558,%r558,2; add.u64 %r560,%r560,2; .loc 1 454 0 setp.ne.u64 %r842,%r552,%r558; @ %r842 bra $L434; .loc 1 2977 0 mov.u16 %r843,16526; st.u16 [%frame+234],%r843; .loc 1 2980 0 mov.u32 %r348,16; .loc 1 2930 0 mov.u32 %r529,0; .loc 1 2979 0 cvta.const.u64 %r341,etens+160; add.u64 %r1550,%frame,80; add.u64 %r1544,%frame,320; add.u64 %r1530,%frame,190; add.u64 %r1548,%r1537,18; add.u64 %r1547,%r341,100; add.u64 %r1574,%frame,338; .loc 1 1421 0 add.u64 %r1575,%frame,164; .loc 1 1422 0 add.u64 %r1576,%frame,138; add.u64 %r1577,%frame,140; add.u64 %r1578,%frame,166; add.u64 %r1579,%frame,162; add.u64 %r1580,%frame,188; add.u64 %r1581,%frame,104; add.u64 %r1582,%frame,340; $L480: .loc 1 2983 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r341; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call ediv,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } mov.u64 %r344,%r1544; mov.u64 %r687,%r1544; mov.u64 %r689,%r1537; $L435: .loc 1 455 0 ld.u16 %r850,[%r689]; st.u16 [%r687],%r850; add.u64 %r689,%r689,2; add.u64 %r687,%r687,2; .loc 1 454 0 setp.ne.u64 %r851,%r689,%r588; @ %r851 bra $L435; .loc 1 3610 0 ld.u16 %r535,[%frame+338]; .loc 1 3611 0 cvt.u16.u32 %r853,%r535; and.b16 %r852,%r853,32767; cvt.u32.u16 %r854,%r852; add.u32 %r538,%r854,-16382; .loc 1 3612 0 setp.gt.s32 %r855,%r538,0; @ %r855 bra $L436; .loc 1 440 0 mov.u16 %r856,0; st.u16 [%frame+190],%r856; st.u16 [%frame+192],%r856; st.u16 [%frame+194],%r856; st.u16 [%frame+196],%r856; st.u16 [%frame+198],%r856; st.u16 [%frame+200],%r856; st.u16 [%frame+202],%r856; st.u16 [%frame+204],%r856; st.u16 [%frame+206],%r856; st.u16 [%frame+208],%r856; mov.u32 %r693,0; bra $L437; $L436: .loc 1 3618 0 mov.u32 %r866,144; sub.u32 %r704,%r866,%r538; mov.u64 %r506,%r1530; mov.u64 %r531,%r1530; mov.u64 %r293,%r1544; $L438: .loc 1 455 0 ld.u16 %r867,[%r293]; st.u16 [%r531],%r867; add.u64 %r293,%r293,2; add.u64 %r531,%r531,2; .loc 1 454 0 setp.ne.u64 %r868,%r293,%r1582; @ %r868 bra $L438; .loc 1 3620 0 setp.le.s32 %r869,%r704,0; @ %r869 bra $L439; .loc 1 3624 0 setp.le.s32 %r870,%r704,15; @ %r870 bra $L585; add.u32 %r871,%r704,-16; shr.u32 %r648,%r871,4; cvt.u64.u32 %r719,%r648; add.u64 %r872,%r719,%r719; add.u64 %r1549,%r1530,2; add.u64 %r565,%r872,%r1549; .loc 1 3626 0 mov.u16 %r874,0; $L441: st.u16 [%r506],%r874; mov.u64 %r506,%r1549; .loc 1 3624 0 setp.ne.u64 %r875,%r1549,%r565; @ ! %r875 bra $L684; add.u64 %r1549,%r1549,2; bra $L441; $L684: add.u64 %r877,%r719,1; add.u64 %r878,%r877,%r877; add.u64 %r705,%r1530,%r878; mov.u32 %r879,128; sub.u32 %r723,%r879,%r538; shl.b32 %r881,%r648,4; sub.u32 %r704,%r723,%r881; bra $L440; $L585: .loc 1 3623 0 mov.u64 %r705,%r1530; $L440: .loc 1 3630 0 cvta.const.u64 %r883,bmask; cvt.s64.s32 %r884,%r704; add.u64 %r885,%r884,%r884; add.u64 %r886,%r883,%r885; ld.u16 %r888,[%r705]; ld.u16 %r889,[%r886]; and.b16 %r887,%r888,%r889; st.u16 [%r705],%r887; ld.u16 %r693,[%frame+190]; $L437: .loc 1 3634 0 cvt.u16.u32 %r890,%r535; setp.ge.s16 %r891,%r890,0; @ %r891 bra $L476; mov.u64 %r589,%r1530; mov.u32 %r539,%r693; $L475: .loc 1 3638 0 ld.u16 %r892,[%r344]; cvt.u16.u32 %r893,%r539; setp.eq.u16 %r894,%r892,%r893; @ %r894 bra $L443; .loc 1 521 0 ld.u16 %r896,[%frame+208]; and.b16 %r895,%r896,32767; setp.ne.u16 %r897,%r895,32767; @ %r897 bra $L444; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r900,[%value_in]; } .loc 1 1381 0 setp.ne.u32 %r901,%r900,0; @ %r901 bra $L476; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r904,[%value_in]; } .loc 1 1415 0 setp.ne.u32 %r905,%r904,0; @ %r905 bra $L476; $L444: .loc 1 1421 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1532; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1575; call emovi,(%out_arg1,%out_arg2); } .loc 1 1422 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1576; call emovi,(%out_arg1,%out_arg2); } .loc 1 1424 0 ld.u16 %r914,[%frame+164]; not.b16 %r913,%r914; cvt.u32.u16 %r275,%r913; st.u16 [%frame+164],%r913; .loc 1 1428 0 ld.u16 %r602,[%frame+140]; cvt.u16.u32 %r916,%r602; cvt.u64.u16 %r573,%r916; .loc 1 1427 0 ld.u16 %r917,[%frame+166]; .loc 1 1429 0 sub.u64 %r574,%r917,%r573; .loc 1 1430 0 setp.le.s64 %r918,%r574,0; @ %r918 bra $L446; mov.u64 %r306,%r1576; mov.u64 %r332,%r1550; mov.u64 %r681,%r1550; mov.u64 %r694,%r1576; $L447: .loc 1 696 0 ld.u16 %r919,[%r694]; st.u16 [%r681],%r919; add.u64 %r694,%r694,2; add.u64 %r681,%r681,2; .loc 1 695 0 setp.ne.u64 %r920,%r1579,%r694; @ %r920 bra $L447; .loc 1 698 0 mov.u16 %r921,0; st.u16 [%frame+104],%r921; mov.u64 %r578,%r1575; $L449: .loc 1 696 0 add.u64 %r578,%r578,2; cvt.u16.u32 %r922,%r275; st.u16 [%r306],%r922; add.u64 %r306,%r306,2; .loc 1 695 0 setp.eq.u64 %r923,%r306,%r694; @ %r923 bra $L448; ld.u16 %r275,[%r578]; bra $L449; $L448: .loc 1 698 0 mov.u16 %r924,0; st.u16 [%frame+162],%r924; mov.u64 %r327,%r1575; $L450: .loc 1 696 0 ld.u16 %r925,[%r332]; st.u16 [%r327],%r925; add.u64 %r332,%r332,2; add.u64 %r327,%r327,2; .loc 1 695 0 setp.ne.u64 %r926,%r1581,%r332; @ %r926 bra $L450; .loc 1 698 0 mov.u16 %r927,0; st.u16 [%frame+188],%r927; .loc 1 1435 0 ld.u16 %r573,[%frame+140]; .loc 1 1436 0 neg.s64 %r574,%r574; bra $L451; $L446: .loc 1 1439 0 setp.eq.u64 %r928,%r574,0; @ %r928 bra $L452; $L451: .loc 1 1441 0 setp.ge.s64 %r929,%r574,-145; @ ! %r929 bra $L454; cvt.u32.u64 %r931,%r574; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1575; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r931; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r933,[%value_in]; } mov.u32 %r642,%r933; ld.u16 %r275,[%frame+164]; bra $L455; $L452: add.u64 %r549,%frame,168; add.u64 %r727,%frame,142; mov.u64 %r661,%r1575; $L457: .loc 1 756 0 ld.u16 %r936,[%r549]; ld.u16 %r937,[%r727]; setp.ne.u16 %r938,%r936,%r937; @ %r938 bra $L456; add.u64 %r549,%r549,2; add.u64 %r727,%r727,2; .loc 1 754 0 setp.ne.u64 %r939,%r1530,%r549; @ %r939 bra $L457; bra $L685; $L456: .loc 1 762 0 setp.gt.u16 %r942,%r936,%r937; @ %r942 bra $L459; .loc 1 1438 0 mov.u32 %r642,0; bra $L455; $L685: .loc 1 1453 0 ld.u16 %r943,[%frame+138]; setp.eq.u16 %r945,%r943,%r913; @ %r945 bra $L460; .loc 1 440 0 mov.u16 %r946,0; st.u16 [%frame+190],%r946; st.u16 [%frame+192],%r946; st.u16 [%frame+194],%r946; st.u16 [%frame+196],%r946; st.u16 [%frame+198],%r946; st.u16 [%frame+200],%r946; st.u16 [%frame+202],%r946; st.u16 [%frame+204],%r946; st.u16 [%frame+206],%r946; st.u16 [%frame+208],%r946; mov.u32 %r693,0; bra $L476; $L460: .loc 1 1460 0 setp.ne.u32 %r956,%r602,0; @ %r956 bra $L461; ld.u16 %r957,[%frame+144]; setp.lt.s16 %r958,%r957,0; @ %r958 bra $L461; .loc 1 804 0 add.u64 %r603,%frame,162; $L464: .loc 1 809 0 ld.u16 %r596,[%r603]; cvt.u16.u32 %r959,%r596; setp.ge.s16 %r960,%r959,0; @ %r960 bra $L462; .loc 1 810 0 cvt.u16.u32 %r962,%r602; or.b16 %r961,%r962,1; cvt.u32.u16 %r602,%r961; $L462: .loc 1 811 0 cvt.u16.u32 %r963,%r596; add.u16 %r964,%r963,%r963; st.u16 [%r603],%r964; .loc 1 812 0 cvt.u16.u32 %r967,%r602; and.b16 %r966,%r967,2; setp.eq.u16 %r968,%r966,0; @ %r968 bra $L463; .loc 1 813 0 or.b16 %r969,%r964,1; st.u16 [%r603],%r969; $L463: .loc 1 814 0 cvt.u16.u32 %r971,%r602; add.u16 %r972,%r971,%r971; cvt.u32.u16 %r602,%r972; .loc 1 815 0 add.u64 %r603,%r603,-2; .loc 1 807 0 setp.ne.u64 %r975,%r603,%r1577; @ %r975 bra $L464; bra $L454; $L461: add.u64 %r273,%frame,140; $L468: .loc 1 1468 0 ld.u16 %r978,[%r273]; setp.eq.u16 %r979,%r978,0; @ %r979 bra $L466; .loc 1 1471 0 add.u64 %r573,%r573,1; bra $L467; $L466: add.u64 %r273,%r273,2; .loc 1 1466 0 setp.ne.u64 %r980,%r1579,%r273; @ %r980 bra $L468; $L467: .loc 1 1475 0 st.u16 [%frame+140],%r573; bra $L454; $L459: mov.u64 %r653,%r1576; mov.u64 %r662,%r1550; .loc 1 762 0 mov.u64 %r568,%r1550; mov.u64 %r647,%r1576; $L469: .loc 1 696 0 ld.u16 %r981,[%r647]; st.u16 [%r568],%r981; add.u64 %r647,%r647,2; add.u64 %r568,%r568,2; .loc 1 695 0 setp.ne.u64 %r982,%r1579,%r647; @ %r982 bra $L469; .loc 1 698 0 mov.u16 %r983,0; st.u16 [%frame+104],%r983; mov.u64 %r654,%r1575; $L470: .loc 1 696 0 ld.u16 %r984,[%r654]; st.u16 [%r653],%r984; add.u64 %r654,%r654,2; add.u64 %r653,%r653,2; .loc 1 695 0 setp.ne.u64 %r985,%r1580,%r654; @ %r985 bra $L470; .loc 1 698 0 mov.u16 %r986,0; st.u16 [%frame+162],%r986; $L471: .loc 1 696 0 ld.u16 %r987,[%r662]; st.u16 [%r661],%r987; add.u64 %r662,%r662,2; add.u64 %r661,%r661,2; .loc 1 695 0 setp.ne.u64 %r988,%r1581,%r662; @ %r988 bra $L471; .loc 1 698 0 mov.u16 %r989,0; st.u16 [%frame+188],%r989; ld.u16 %r275,[%frame+164]; .loc 1 1438 0 mov.u32 %r642,0; $L455: .loc 1 1485 0 ld.u16 %r990,[%frame+138]; cvt.u16.u32 %r991,%r275; setp.ne.u16 %r992,%r990,%r991; @ %r992 bra $L586; .loc 1 913 0 mov.u32 %r732,0; .loc 1 912 0 mov.u64 %r629,%r1579; .loc 1 911 0 add.u64 %r628,%frame,188; $L473: .loc 1 916 0 ld.u16 %r993,[%r628]; ld.u16 %r994,[%r629]; add.u64 %r995,%r993,%r994; cvt.u64.u32 %r996,%r732; add.u64 %r625,%r995,%r996; .loc 1 921 0 st.u16 [%r629],%r625; .loc 1 922 0 add.u64 %r628,%r628,-2; .loc 1 923 0 add.u64 %r629,%r629,-2; .loc 1 917 0 shr.u64 %r997,%r625,16; cvt.u32.u64 %r999,%r997; and.b32 %r732,%r999,1; .loc 1 914 0 setp.ne.u64 %r1002,%r628,%r1578; @ %r1002 bra $L473; .loc 1 1488 0 mov.u32 %r643,0; bra $L474; $L586: .loc 1 940 0 mov.u32 %r401,0; .loc 1 938 0 add.u64 %r640,%frame,188; .loc 1 939 0 mov.u64 %r641,%r1579; $L472: .loc 1 943 0 ld.u16 %r1003,[%r641]; ld.u16 %r1004,[%r640]; sub.u64 %r1005,%r1003,%r1004; cvt.u64.u32 %r1006,%r401; sub.u64 %r637,%r1005,%r1006; .loc 1 948 0 st.u16 [%r641],%r637; .loc 1 949 0 add.u64 %r640,%r640,-2; .loc 1 950 0 add.u64 %r641,%r641,-2; .loc 1 944 0 shr.u64 %r1007,%r637,16; cvt.u32.u64 %r1009,%r1007; and.b32 %r401,%r1009,1; .loc 1 941 0 setp.ne.u64 %r1012,%r641,%r1577; @ %r1012 bra $L472; .loc 1 1493 0 mov.u32 %r643,1; $L474: .loc 1 1495 0 mov.u32 %r1017,64; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1576; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r642; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r643; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r573; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r1017; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%frame; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } $L454: .loc 1 1498 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1576; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovo$isra$7,(%out_arg1,%out_arg2); } ld.u16 %r693,[%frame+190]; bra $L476; $L443: add.u64 %r344,%r344,2; add.u64 %r589,%r589,2; .loc 1 3636 0 setp.eq.u64 %r1024,%r344,%r1574; @ %r1024 bra $L476; ld.u16 %r539,[%r589]; bra $L475; $L439: ld.u16 %r693,[%frame+190]; $L476: mov.u64 %r347,%r1530; .loc 1 440 0 mov.u64 %r355,%r1537; $L479: .loc 1 2987 0 ld.u16 %r1025,[%r355]; cvt.u16.u32 %r1026,%r693; setp.ne.u16 %r1027,%r1025,%r1026; @ %r1027 bra $L477; add.u64 %r355,%r355,2; add.u64 %r347,%r347,2; .loc 1 2985 0 setp.eq.u64 %r1028,%r1548,%r355; @ %r1028 bra $L587; ld.u16 %r693,[%r347]; bra $L479; $L587: mov.u64 %r370,%r1534; mov.u64 %r376,%r1537; $L478: .loc 1 455 0 ld.u16 %r1029,[%r376]; st.u16 [%r370],%r1029; add.u64 %r376,%r376,2; add.u64 %r370,%r370,2; .loc 1 454 0 setp.ne.u64 %r1030,%r376,%r689; @ %r1030 bra $L478; .loc 1 2991 0 add.u32 %r529,%r529,%r348; $L477: .loc 1 2993 0 add.u64 %r341,%r341,20; .loc 1 2994 0 shr.u32 %r1031,%r348,1; cvt.u16.u32 %r1032,%r1031; cvt.u32.u16 %r348,%r1032; .loc 1 2996 0 setp.ne.u64 %r1034,%r341,%r1547; @ %r1034 bra $L480; .loc 1 2999 0 ld.u16 %r1036,[%frame+234]; ld.u16 %r1037,[%frame+286]; add.u16 %r1035,%r1036,%r1037; add.u16 %r1038,%r1035,-16526; st.u16 [%frame+234],%r1038; add.u64 %r390,%r1534,20; mov.u64 %r395,%r1539; $L481: .loc 1 455 0 ld.u16 %r1039,[%r397]; st.u16 [%r395],%r1039; add.u64 %r397,%r397,2; add.u64 %r395,%r395,2; .loc 1 454 0 setp.ne.u64 %r1040,%r390,%r397; @ %r1040 bra $L481; mov.u64 %r406,%r1537; mov.u32 %r646,0; cvta.const.u64 %r356,eone; $L483: .loc 1 455 0 add.u64 %r356,%r356,2; cvt.u16.u32 %r1041,%r646; st.u16 [%r406],%r1041; add.u64 %r406,%r406,2; .loc 1 454 0 setp.eq.u64 %r1042,%r406,%r689; @ %r1042 bra $L588; ld.u16 %r646,[%r356]; bra $L483; $L485: .loc 1 3007 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r357; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1046,[%value_in]; } setp.gt.s32 %r1047,%r1046,0; @ %r1047 bra $L484; .loc 1 3009 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r357; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1534; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call ediv,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3010 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r357; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1537; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3011 0 add.u32 %r529,%r529,%r359; $L484: .loc 1 3013 0 shr.u32 %r1060,%r359,1; cvt.u16.u32 %r1061,%r1060; cvt.u32.u16 %r359,%r1061; .loc 1 3014 0 setp.eq.u64 %r1063,%r357,%r1546; @ ! %r1063 bra $L686; add.u64 %r1533,%frame,214; bra $L430; $L686: .loc 1 3016 0 add.u64 %r357,%r357,20; bra $L482; $L588: .loc 1 3003 0 mov.u32 %r359,4096; .loc 1 3004 0 cvta.const.u64 %r357,etens; add.u64 %r1546,%r357,240; $L482: .loc 1 3005 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1546; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1534; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1068,[%value_in]; } setp.le.s32 %r1069,%r1068,0; @ %r1069 bra $L485; add.u64 %r1533,%frame,214; bra $L430; $L433: .loc 1 3022 0 ld.u16 %r1070,[%frame+286]; setp.ne.u16 %r1071,%r1070,0; @ %r1071 bra $L486; .loc 1 3024 0 ld.u16 %r1072,[%frame+284]; setp.lt.s16 %r1073,%r1072,0; @ %r1073 bra $L589; .loc 1 2930 0 mov.u32 %r529,0; cvta.const.u64 %r1546,etens+240; $L488: .loc 1 3026 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1546; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1539; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3027 0 add.u32 %r529,%r529,-1; .loc 1 3024 0 ld.u16 %r1081,[%frame+284]; setp.ge.s16 %r1082,%r1081,0; @ %r1082 bra $L488; add.u64 %r1530,%frame,190; add.u64 %r1533,%frame,214; bra $L487; $L486: .loc 1 3032 0 add.u64 %r1530,%frame,190; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovi,(%out_arg1,%out_arg2); } .loc 1 2930 0 mov.u32 %r529,0; add.u64 %r1533,%frame,214; add.u64 %r1583,%frame,216; add.u64 %r1584,%frame,192; add.u64 %r1585,%frame,240; $L495: .loc 1 3035 0 ld.u16 %r1088,[%frame+214]; and.b16 %r1087,%r1088,7; setp.ne.u16 %r1089,%r1087,0; @ %r1089 bra $L489; mov.u64 %r682,%r1530; mov.u64 %r679,%r1583; mov.u64 %r559,%r1583; mov.u64 %r540,%r1530; $L490: .loc 1 696 0 ld.u16 %r1090,[%r540]; st.u16 [%r559],%r1090; add.u64 %r540,%r540,2; add.u64 %r559,%r559,2; .loc 1 695 0 setp.ne.u64 %r1091,%r540,%r1533; @ %r1091 bra $L490; .loc 1 698 0 mov.u16 %r1092,0; st.u16 [%frame+240],%r1092; .loc 1 3039 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1583; call eshdn1,(%out_arg1); } .loc 1 3040 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1583; call eshdn1,(%out_arg1); } .loc 1 913 0 mov.u32 %r685,0; .loc 1 912 0 add.u64 %r382,%frame,240; .loc 1 911 0 mov.u64 %r381,%r1533; $L491: .loc 1 916 0 ld.u16 %r1097,[%r381]; ld.u16 %r1098,[%r382]; add.u64 %r1099,%r1097,%r1098; cvt.u64.u32 %r1100,%r685; add.u64 %r378,%r1099,%r1100; .loc 1 921 0 st.u16 [%r382],%r378; .loc 1 922 0 add.u64 %r381,%r381,-2; .loc 1 923 0 add.u64 %r382,%r382,-2; .loc 1 917 0 shr.u64 %r1101,%r378,16; cvt.u32.u64 %r1103,%r1101; and.b32 %r685,%r1103,1; .loc 1 914 0 setp.ne.u64 %r1106,%r381,%r1584; @ %r1106 bra $L491; .loc 1 3042 0 ld.u16 %r1538,[%frame+218]; add.u16 %r1538,%r1538,3; st.u16 [%frame+218],%r1538; .loc 1 3043 0 ld.u16 %r1109,[%frame+220]; setp.eq.u16 %r1110,%r1109,0; @ %r1110 bra $L492; $L493: .loc 1 3045 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1583; call eshdn1,(%out_arg1); } .loc 1 3046 0 ld.u16 %r1538,[%frame+218]; add.u16 %r1538,%r1538,1; st.u16 [%frame+218],%r1538; .loc 1 3043 0 ld.u16 %r1115,[%frame+220]; setp.ne.u16 %r1116,%r1115,0; @ %r1116 bra $L493; $L492: .loc 1 3048 0 ld.u16 %r1117,[%frame+240]; setp.ne.u16 %r1118,%r1117,0; @ %r1118 bra $L489; .loc 1 3050 0 setp.gt.u16 %r1120,%r1538,16382; @ %r1120 bra $L489; $L494: .loc 1 696 0 ld.u16 %r1121,[%r679]; st.u16 [%r682],%r1121; add.u64 %r679,%r679,2; add.u64 %r682,%r682,2; .loc 1 695 0 setp.ne.u64 %r1122,%r1585,%r679; @ %r1122 bra $L494; .loc 1 698 0 mov.u16 %r1123,0; st.u16 [%frame+214],%r1123; .loc 1 3053 0 add.u32 %r529,%r529,-1; .loc 1 3033 0 setp.ne.u32 %r1124,%r529,-43; @ %r1124 bra $L495; $L489: .loc 1 3055 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1530; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; call emovo$isra$7,(%out_arg1,%out_arg2); } bra $L487; $L589: .loc 1 2930 0 mov.u32 %r529,0; add.u64 %r1530,%frame,190; add.u64 %r1533,%frame,214; $L487: mov.u64 %r674,%r1530; add.u64 %r672,%r1539,20; mov.u64 %r671,%r1539; $L496: .loc 1 455 0 ld.u16 %r1129,[%r671]; st.u16 [%r674],%r1129; add.u64 %r671,%r671,2; add.u64 %r674,%r674,2; .loc 1 454 0 setp.ne.u64 %r1130,%r671,%r672; @ %r1130 bra $L496; mov.u64 %r644,%r1537; mov.u32 %r676,0; cvta.const.u64 %r398,eone; $L498: .loc 1 455 0 add.u64 %r398,%r398,2; cvt.u16.u32 %r1131,%r676; st.u16 [%r644],%r1131; add.u64 %r644,%r644,2; .loc 1 454 0 setp.eq.u64 %r1132,%r644,%r588; @ %r1132 bra $L590; ld.u16 %r676,[%r398]; bra $L498; $L501: .loc 1 3064 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r522; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1136,[%value_in]; } setp.lt.s32 %r1137,%r1136,0; @ %r1137 bra $L499; .loc 1 3066 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r668; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1530; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3067 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r668; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1537; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } .loc 1 3068 0 add.u32 %r529,%r529,%r402; $L499: .loc 1 3070 0 shr.u32 %r1151,%r402,31; add.u32 %r1152,%r1151,%r402; shr.s32 %r402,%r1152,1; add.u64 %r683,%r683,20; .loc 1 3071 0 setp.eq.u64 %r1154,%r683,260; @ ! %r1154 bra $L497; bra $L500; $L590: .loc 1 454 0 mov.u64 %r683,0; .loc 1 3057 0 mov.u32 %r402,-4096; cvta.const.u64 %r1551,etens; cvta.const.u64 %r1545,emtens; $L497: add.u64 %r668,%r1551,%r683; add.u64 %r522,%r1545,%r683; .loc 1 3062 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1532; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1160,[%value_in]; } setp.gt.s32 %r1161,%r1160,0; @ %r1161 bra $L501; $L500: .loc 1 3076 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1532; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1537; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call ediv,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } add.u64 %r1550,%frame,80; $L430: .loc 1 3080 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovi,(%out_arg1,%out_arg2); } mov.u64 %r455,%r1530; mov.u64 %r429,%r1530; $L502: .loc 1 696 0 ld.u16 %r1172,[%r429]; st.u16 [%r421],%r1172; add.u64 %r429,%r429,2; add.u64 %r421,%r421,2; .loc 1 695 0 setp.ne.u64 %r1173,%r1533,%r429; @ %r1173 bra $L502; .loc 1 698 0 mov.u16 %r1174,0; st.u16 [%frame+266],%r1174; .loc 1 3082 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1530; call emovi,(%out_arg1,%out_arg2); } mov.u64 %r450,%r1539; $L503: .loc 1 696 0 ld.u16 %r1179,[%r455]; st.u16 [%r450],%r1179; add.u64 %r455,%r455,2; add.u64 %r450,%r450,2; .loc 1 695 0 setp.ne.u64 %r1180,%r429,%r455; @ %r1180 bra $L503; .loc 1 698 0 mov.u16 %r1181,0; st.u16 [%frame+292],%r1181; .loc 1 3084 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call eiremain,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 3085 0 ld.u16 %r409,[%frame+76]; .loc 1 3086 0 setp.eq.u64 %r1187,%r409,0; @ ! %r1187 bra $L505; cvta.const.u64 %r1529,ezero; .loc 1 804 0 add.u64 %r1569,%frame,292; add.u64 %r1570,%frame,270; add.u64 %r1571,%r1539,24; add.u64 %r1572,%frame,240; add.u64 %r1573,%frame,218; bra $L504; $L592: .loc 1 805 0 mov.u32 %r416,0; .loc 1 804 0 mov.u64 %r417,%r1569; $L509: .loc 1 809 0 ld.u16 %r411,[%r417]; cvt.u16.u32 %r1188,%r411; setp.ge.s16 %r1189,%r1188,0; @ %r1189 bra $L506; .loc 1 810 0 cvt.u16.u32 %r1191,%r416; or.b16 %r1190,%r1191,1; cvt.u32.u16 %r416,%r1190; $L506: .loc 1 811 0 cvt.u16.u32 %r1192,%r411; add.u16 %r1193,%r1192,%r1192; .loc 1 812 0 cvt.u16.u32 %r1195,%r416; and.b16 %r1194,%r1195,2; setp.ne.u16 %r1196,%r1194,0; @ %r1196 bra $L507; .loc 1 811 0 st.u16 [%r417],%r1193; bra $L508; $L507: .loc 1 813 0 or.b16 %r1198,%r1193,1; st.u16 [%r417],%r1198; $L508: .loc 1 814 0 cvt.u16.u32 %r1200,%r416; add.u16 %r1201,%r1200,%r1200; cvt.u32.u16 %r416,%r1201; .loc 1 815 0 add.u64 %r417,%r417,-2; .loc 1 807 0 setp.ne.u64 %r1204,%r417,%r1570; @ %r1204 bra $L509; add.u64 %r475,%frame,216; mov.u64 %r533,%r1539; $L510: .loc 1 696 0 ld.u16 %r1205,[%r533]; st.u16 [%r475],%r1205; add.u64 %r533,%r533,2; add.u64 %r475,%r475,2; .loc 1 695 0 setp.ne.u64 %r1206,%r1571,%r533; @ %r1206 bra $L510; .loc 1 698 0 mov.u16 %r1207,0; st.u16 [%frame+240],%r1207; .loc 1 805 0 mov.u32 %r427,0; .loc 1 804 0 mov.u64 %r428,%r1572; $L514: .loc 1 809 0 ld.u16 %r422,[%r428]; cvt.u16.u32 %r1208,%r422; setp.ge.s16 %r1209,%r1208,0; @ %r1209 bra $L511; .loc 1 810 0 cvt.u16.u32 %r1211,%r427; or.b16 %r1210,%r1211,1; cvt.u32.u16 %r427,%r1210; $L511: .loc 1 811 0 cvt.u16.u32 %r1212,%r422; add.u16 %r1213,%r1212,%r1212; .loc 1 812 0 cvt.u16.u32 %r1215,%r427; and.b16 %r1214,%r1215,2; setp.ne.u16 %r1216,%r1214,0; @ %r1216 bra $L512; .loc 1 811 0 st.u16 [%r428],%r1213; bra $L513; $L512: .loc 1 813 0 or.b16 %r1218,%r1213,1; st.u16 [%r428],%r1218; $L513: .loc 1 814 0 cvt.u16.u32 %r1220,%r427; add.u16 %r1221,%r1220,%r1220; cvt.u32.u16 %r427,%r1221; .loc 1 815 0 add.u64 %r428,%r428,-2; .loc 1 807 0 setp.ne.u64 %r1224,%r428,%r1573; @ %r1224 bra $L514; .loc 1 805 0 mov.u32 %r435,0; .loc 1 804 0 mov.u64 %r436,%r1572; $L518: .loc 1 809 0 ld.u16 %r430,[%r436]; cvt.u16.u32 %r1225,%r430; setp.ge.s16 %r1226,%r1225,0; @ %r1226 bra $L515; .loc 1 810 0 cvt.u16.u32 %r1228,%r435; or.b16 %r1227,%r1228,1; cvt.u32.u16 %r435,%r1227; $L515: .loc 1 811 0 cvt.u16.u32 %r1229,%r430; add.u16 %r1230,%r1229,%r1229; .loc 1 812 0 cvt.u16.u32 %r1232,%r435; and.b16 %r1231,%r1232,2; setp.ne.u16 %r1233,%r1231,0; @ %r1233 bra $L516; .loc 1 811 0 st.u16 [%r436],%r1230; bra $L517; $L516: .loc 1 813 0 or.b16 %r1235,%r1230,1; st.u16 [%r436],%r1235; $L517: .loc 1 814 0 cvt.u16.u32 %r1237,%r435; add.u16 %r1238,%r1237,%r1237; cvt.u32.u16 %r435,%r1238; .loc 1 815 0 add.u64 %r436,%r436,-2; .loc 1 807 0 setp.ne.u64 %r1241,%r436,%r1573; @ %r1241 bra $L518; .loc 1 913 0 mov.u32 %r688,0; .loc 1 912 0 mov.u64 %r449,%r1569; .loc 1 911 0 mov.u64 %r448,%r1572; $L519: .loc 1 916 0 ld.u16 %r1242,[%r448]; ld.u16 %r1243,[%r449]; add.u64 %r1244,%r1242,%r1243; cvt.u64.u32 %r1245,%r688; add.u64 %r445,%r1244,%r1245; .loc 1 921 0 st.u16 [%r449],%r445; .loc 1 922 0 add.u64 %r448,%r448,-2; .loc 1 923 0 add.u64 %r449,%r449,-2; .loc 1 917 0 shr.u64 %r1246,%r445,16; cvt.u32.u64 %r1248,%r1246; and.b32 %r688,%r1248,1; .loc 1 914 0 setp.ne.u64 %r1251,%r448,%r1573; @ %r1251 bra $L519; .loc 1 3093 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call eiremain,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 3094 0 ld.u16 %r452,[%frame+76]; .loc 1 3095 0 add.u32 %r529,%r529,-1; .loc 1 3086 0 setp.ne.u64 %r1257,%r452,0; @ %r1257 bra $L591; $L504: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1529; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1261,[%value_in]; } setp.ne.u32 %r1262,%r1261,0; @ %r1262 bra $L592; bra $L505; $L591: mov.u64 %r409,%r452; $L505: .loc 1 3098 0 setp.eq.u32 %r1263,%r335,0; @ %r1263 bra $L520; .loc 1 3099 0 mov.u32 %r1264,45; st.u8 [%frame+80],%r1264; bra $L521; $L520: .loc 1 3101 0 mov.u32 %r1265,32; st.u8 [%frame+80],%r1265; $L521: .loc 1 3103 0 setp.ne.u32 %r1266,%r742,3; @ %r1266 bra $L593; .loc 1 3104 0 add.u32 %r305,%r304,%r529; .loc 1 3109 0 setp.le.s32 %r1267,%r305,42; @ %r1267 bra $L522; .loc 1 3111 0 setp.ne.u64 %r1268,%r409,10; @ %r1268 bra $L523; .loc 1 3113 0 mov.u32 %r1269,49; st.u8 [%frame+81],%r1269; .loc 1 3114 0 mov.u32 %r1270,46; st.u8 [%frame+82],%r1270; add.u32 %r529,%r529,1; .loc 1 3117 0 mov.u32 %r1271,48; st.u8 [%frame+83],%r1271; mov.u32 %r305,41; add.u64 %r310,%frame,84; bra $L524; $L593: .loc 1 3103 0 mov.u32 %r305,%r304; $L522: .loc 1 3111 0 setp.ne.u64 %r1272,%r409,10; @ %r1272 bra $L525; .loc 1 3113 0 mov.u32 %r1273,49; st.u8 [%frame+81],%r1273; .loc 1 3114 0 mov.u32 %r1274,46; st.u8 [%frame+82],%r1274; add.u32 %r529,%r529,1; .loc 1 3115 0 setp.le.s32 %r1275,%r305,0; @ %r1275 bra $L526; add.u32 %r305,%r305,-1; .loc 1 3117 0 mov.u32 %r1276,48; st.u8 [%frame+83],%r1276; add.u64 %r310,%frame,84; bra $L524; $L526: .loc 1 3121 0 setp.ne.u32 %r1277,%r305,0; @ %r1277 bra $L594; .loc 1 3114 0 add.u64 %r310,%frame,83; bra $L524; $L523: .loc 1 3129 0 cvt.u16.u64 %r1280,%r409; add.u16 %r1279,%r1280,48; cvt.u32.u16 %r1281,%r1279; st.u8 [%frame+81],%r1281; .loc 1 3130 0 mov.u32 %r1282,46; st.u8 [%frame+82],%r1282; .loc 1 3110 0 mov.u32 %r305,42; .loc 1 3130 0 add.u64 %r310,%frame,83; bra $L524; $L525: .loc 1 3129 0 cvt.u16.u64 %r1285,%r409; add.u16 %r1284,%r1285,48; cvt.u32.u16 %r1286,%r1284; st.u8 [%frame+81],%r1286; .loc 1 3130 0 mov.u32 %r1287,46; st.u8 [%frame+82],%r1287; .loc 1 3133 0 setp.lt.s32 %r1288,%r305,0; @ %r1288 bra $L528; .loc 1 3130 0 add.u64 %r310,%frame,83; $L524: mov.u64 %r550,%r310; mov.u32 %r507,0; add.u64 %r1534,%frame,216; add.u64 %r1536,%frame,240; add.u64 %r1541,%frame,292; add.u64 %r1540,%frame,270; add.u64 %r1552,%r1539,24; add.u64 %r1535,%frame,218; .loc 1 805 0 mov.u32 %r1568,%r507; $L543: mov.u32 %r467,%r1568; .loc 1 804 0 mov.u64 %r468,%r1541; $L532: .loc 1 809 0 ld.u16 %r462,[%r468]; cvt.u16.u32 %r1289,%r462; setp.ge.s16 %r1290,%r1289,0; @ %r1290 bra $L529; .loc 1 810 0 cvt.u16.u32 %r1292,%r467; or.b16 %r1291,%r1292,1; cvt.u32.u16 %r467,%r1291; $L529: .loc 1 811 0 cvt.u16.u32 %r1293,%r462; add.u16 %r1294,%r1293,%r1293; .loc 1 812 0 cvt.u16.u32 %r1296,%r467; and.b16 %r1295,%r1296,2; setp.ne.u16 %r1297,%r1295,0; @ %r1297 bra $L530; .loc 1 811 0 st.u16 [%r468],%r1294; bra $L531; $L530: .loc 1 813 0 or.b16 %r1299,%r1294,1; st.u16 [%r468],%r1299; $L531: .loc 1 814 0 cvt.u16.u32 %r1301,%r467; add.u16 %r1302,%r1301,%r1301; cvt.u32.u16 %r467,%r1302; .loc 1 815 0 add.u64 %r468,%r468,-2; .loc 1 807 0 setp.ne.u64 %r1305,%r468,%r1540; @ %r1305 bra $L532; mov.u64 %r579,%r1534; mov.u64 %r581,%r1539; $L533: .loc 1 696 0 ld.u16 %r1306,[%r581]; st.u16 [%r579],%r1306; add.u64 %r581,%r581,2; add.u64 %r579,%r579,2; .loc 1 695 0 setp.ne.u64 %r1307,%r1552,%r581; @ %r1307 bra $L533; .loc 1 698 0 mov.u16 %r1308,0; st.u16 [%frame+240],%r1308; .loc 1 805 0 mov.u32 %r479,%r1568; .loc 1 804 0 mov.u64 %r480,%r1536; $L537: .loc 1 809 0 ld.u16 %r473,[%r480]; cvt.u16.u32 %r1309,%r473; setp.ge.s16 %r1310,%r1309,0; @ %r1310 bra $L534; .loc 1 810 0 cvt.u16.u32 %r1312,%r479; or.b16 %r1311,%r1312,1; cvt.u32.u16 %r479,%r1311; $L534: .loc 1 811 0 cvt.u16.u32 %r1313,%r473; add.u16 %r1314,%r1313,%r1313; .loc 1 812 0 cvt.u16.u32 %r1316,%r479; and.b16 %r1315,%r1316,2; setp.ne.u16 %r1317,%r1315,0; @ %r1317 bra $L535; .loc 1 811 0 st.u16 [%r480],%r1314; bra $L536; $L535: .loc 1 813 0 or.b16 %r1319,%r1314,1; st.u16 [%r480],%r1319; $L536: .loc 1 814 0 cvt.u16.u32 %r1321,%r479; add.u16 %r1322,%r1321,%r1321; cvt.u32.u16 %r479,%r1322; .loc 1 815 0 add.u64 %r480,%r480,-2; .loc 1 807 0 setp.ne.u64 %r1325,%r480,%r1535; @ %r1325 bra $L537; .loc 1 805 0 mov.u32 %r488,%r1568; .loc 1 804 0 mov.u64 %r489,%r1536; $L541: .loc 1 809 0 ld.u16 %r482,[%r489]; cvt.u16.u32 %r1326,%r482; setp.ge.s16 %r1327,%r1326,0; @ %r1327 bra $L538; .loc 1 810 0 cvt.u16.u32 %r1329,%r488; or.b16 %r1328,%r1329,1; cvt.u32.u16 %r488,%r1328; $L538: .loc 1 811 0 cvt.u16.u32 %r1330,%r482; add.u16 %r1331,%r1330,%r1330; .loc 1 812 0 cvt.u16.u32 %r1333,%r488; and.b16 %r1332,%r1333,2; setp.ne.u16 %r1334,%r1332,0; @ %r1334 bra $L539; .loc 1 811 0 st.u16 [%r489],%r1331; bra $L540; $L539: .loc 1 813 0 or.b16 %r1336,%r1331,1; st.u16 [%r489],%r1336; $L540: .loc 1 814 0 cvt.u16.u32 %r1338,%r488; add.u16 %r1339,%r1338,%r1338; cvt.u32.u16 %r488,%r1339; .loc 1 815 0 add.u64 %r489,%r489,-2; .loc 1 807 0 setp.ne.u64 %r1342,%r489,%r1535; @ %r1342 bra $L541; .loc 1 913 0 mov.u32 %r591,%r1568; .loc 1 912 0 mov.u64 %r501,%r1541; .loc 1 911 0 mov.u64 %r500,%r1536; $L542: .loc 1 916 0 ld.u16 %r1343,[%r500]; ld.u16 %r1344,[%r501]; add.u64 %r1345,%r1343,%r1344; cvt.u64.u32 %r1346,%r591; add.u64 %r497,%r1345,%r1346; .loc 1 921 0 st.u16 [%r501],%r497; .loc 1 922 0 add.u64 %r500,%r500,-2; .loc 1 923 0 add.u64 %r501,%r501,-2; .loc 1 917 0 shr.u64 %r1347,%r497,16; cvt.u32.u64 %r1349,%r1347; and.b32 %r591,%r1349,1; .loc 1 914 0 setp.ne.u64 %r1352,%r500,%r1535; @ %r1352 bra $L542; .loc 1 3141 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1539; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call eiremain,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 3142 0 ld.u16 %r502,[%frame+76]; cvt.u16.u32 %r1360,%r502; add.u16 %r1359,%r1360,48; cvt.u32.u16 %r1361,%r1359; st.u8 [%r550],%r1361; .loc 1 3133 0 add.u32 %r507,%r507,1; add.u64 %r550,%r550,1; setp.ge.s32 %r1362,%r305,%r507; @ %r1362 bra $L543; cvt.s64.s32 %r1363,%r305; add.u64 %r1364,%r1363,1; add.u64 %r706,%r310,%r1364; bra $L544; $L528: ld.u16 %r502,[%frame+76]; .loc 1 3130 0 add.u64 %r706,%frame,83; $L544: .loc 1 3144 0 cvt.u16.u32 %r1365,%r502; cvt.u64.u16 %r508,%r1365; .loc 1 3145 0 add.u64 %r510,%r706,-1; .loc 1 3148 0 setp.le.s64 %r1366,%r508,4; @ %r1366 bra $L527; .loc 1 3151 0 setp.ne.u64 %r1367,%r508,5; @ %r1367 bra $L545; .loc 1 3153 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1539; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1537; call emovo$isra$7,(%out_arg1,%out_arg2); } .loc 1 3154 0 cvta.const.u64 %r1373,ezero; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1537; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1373; call (%value_in),ecmp,(%out_arg1,%out_arg2); ld.param.u32 %r1375,[%value_in]; } setp.ne.u32 %r1376,%r1375,0; @ %r1376 bra $L545; .loc 1 3156 0 setp.lt.s32 %r1377,%r305,0; @ %r1377 bra $L527; ld.s8 %r512,[%r706+-2]; cvt.u16.u32 %r1379,%r512; set.u32.eq.u16 %r1380,%r1379,46; cvt.s64.s32 %r1378,%r1380; add.u64 %r1383,%r510,%r1378; ld.u8 %r1596,[%r1383+-1]; mov.u16 %r1386,%r1596; and.b16 %r1385,%r1386,1; cvt.u32.u16 %r1387,%r1385; cvt.s32.s8 %r1389,%r1387; cvt.u16.u32 %r1388,%r1389; setp.eq.u16 %r1390,%r1388,0; @ %r1390 bra $L527; bra $L687; $L545: .loc 1 3161 0 add.u64 %r490,%r706,-2; ld.u8 %r1596,[%r706+-2]; mov.u16 %r1393,%r1596; and.b16 %r1392,%r1393,127; cvt.u32.u16 %r1394,%r1392; cvt.s32.s8 %r484,%r1394; .loc 1 3164 0 setp.lt.s32 %r1395,%r305,0; @ %r1395 bra $L547; $L581: .loc 1 3171 0 cvt.u16.u32 %r1396,%r484; setp.eq.u16 %r1397,%r1396,46; @ %r1397 bra $L548; .loc 1 3186 0 add.u32 %r713,%r484,1; .loc 1 3187 0 st.u8 [%r490],%r713; .loc 1 3188 0 setp.gt.s32 %r1398,%r713,57; @ ! %r1398 bra $L527; .loc 1 3190 0 mov.u32 %r1403,48; bra $L549; $L547: .loc 1 3167 0 mov.u32 %r1399,49; st.u8 [%r706+-2],%r1399; .loc 1 3168 0 add.u32 %r529,%r529,1; bra $L527; $L548: .loc 1 3174 0 ld.s8 %r524,[%r490+-1]; .loc 1 3175 0 add.u32 %r525,%r524,1; .loc 1 3178 0 setp.gt.s32 %r1400,%r525,57; @ %r1400 bra $L550; .loc 1 3176 0 st.u8 [%r490+-1],%r525; bra $L527; $L550: .loc 1 3180 0 add.u32 %r529,%r529,1; .loc 1 3181 0 mov.u32 %r1401,49; st.u8 [%r490+-1],%r1401; bra $L527; $L688: .loc 1 3186 0 add.u32 %r527,%r520,1; .loc 1 3187 0 st.u8 [%r490],%r527; .loc 1 3188 0 setp.le.s32 %r1402,%r527,57; @ %r1402 bra $L527; $L549: .loc 1 3190 0 st.u8 [%r490],%r1403; .loc 1 3161 0 add.u64 %r490,%r490,-1; ld.u8 %r1596,[%r490]; mov.u16 %r1406,%r1596; and.b16 %r1405,%r1406,127; cvt.u32.u16 %r1407,%r1405; cvt.s32.s8 %r520,%r1407; .loc 1 3171 0 cvt.u16.u32 %r1408,%r520; setp.eq.u16 %r1409,%r1408,46; @ ! %r1409 bra $L688; bra $L548; $L594: .loc 1 3114 0 add.u64 %r510,%frame,83; $L527: .loc 1 3201 0 st.u32 [%stack],%r529; cvta.const.u64 %r1411,$LC4; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r510; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1411; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),sprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1412,[%value_in]; } $L422: .loc 1 3204 0 st.u32 [%frame+4],%r323; .loc 1 3205 0 st.u32 [%frame+16],%r529; .loc 1 501 0 ld.u16 %r1415,[%frame+312]; and.b16 %r1414,%r1415,32767; setp.ne.u16 %r1416,%r1414,32767; @ %r1416 bra $L552; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisinf$part$1,(%out_arg1); ld.param.u32 %r1419,[%value_in]; } .loc 1 2768 0 setp.ne.u32 %r1420,%r1419,0; @ %r1420 bra $L553; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1542; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r1423,[%value_in]; } setp.eq.u32 %r1424,%r1423,0; @ %r1424 bra $L552; $L553: .loc 1 2770 0 mov.u32 %r1425,9999; st.u32 [%r744],%r1425; .loc 1 2771 0 bra $L554; $L552: .loc 1 2773 0 add.u32 %r1426,%r529,1; st.u32 [%r744],%r1426; .loc 1 2779 0 ld.s8 %r722,[%frame+80]; setp.eq.u32 %r1427,%r722,0; @ %r1427 bra $L595; .loc 1 2781 0 cvt.u16.u32 %r1428,%r722; setp.eq.u16 %r1429,%r1428,46; @ %r1429 bra $L596; .loc 1 2778 0 mov.u64 %r316,%r1550; bra $L557; $L558: .loc 1 2781 0 cvt.u16.u32 %r1430,%r278; setp.eq.u16 %r1431,%r1430,46; @ %r1431 bra $L556; $L557: .loc 1 2783 0 add.u64 %r316,%r316,1; .loc 1 2779 0 ld.s8 %r278,[%r316]; setp.ne.u32 %r1432,%r278,0; @ %r1432 bra $L558; bra $L559; $L560: .loc 1 2792 0 ld.s8 %r279,[%r604]; cvt.u32.u32 %r1433,%r279; st.u8 [%r316],%r1433; .loc 1 2793 0 mov.u64 %r316,%r1543; add.u64 %r604,%r604,1; .loc 1 2790 0 setp.ne.u32 %r1434,%r279,0; @ ! %r1434 bra $L559; add.u64 %r1543,%r1543,1; bra $L560; $L561: .loc 1 2800 0 add.u64 %r316,%r316,-1; .loc 1 2799 0 ld.s8 %r1437,[%r316]; cvt.u16.u32 %r1436,%r1437; set.u32.ne.u16 %r1438,%r1436,69; neg.s32 %r1439,%r1438; set.u32.gt.u64 %r1442,%r316,%r1550; neg.s32 %r1443,%r1442; cvt.u16.u32 %r1445,%r1439; cvt.u16.u32 %r1446,%r1443; and.b16 %r1444,%r1445,%r1446; cvt.u32.u16 %r1447,%r1444; cvt.u16.u8 %r1448,%r1447; setp.ne.u16 %r1449,%r1448,0; @ %r1449 bra $L561; bra $L555; $L559: setp.gt.u64 %r1451,%r316,%r1550; @ %r1451 bra $L561; bra $L555; $L595: .loc 1 2778 0 mov.u64 %r316,%r1550; $L555: .loc 1 2801 0 mov.u32 %r1452,0; st.u8 [%r316],%r1452; $L554: .loc 1 2807 0 ld.s8 %r664,[%frame+80]; cvt.u16.u32 %r1454,%r664; set.u32.eq.u16 %r1455,%r1454,32; neg.s32 %r1456,%r1455; set.u32.eq.u16 %r1459,%r1454,45; neg.s32 %r1460,%r1459; cvt.u16.u32 %r1462,%r1456; cvt.u16.u32 %r1463,%r1460; or.b16 %r1461,%r1462,%r1463; cvt.u32.u16 %r1464,%r1461; cvt.u16.u8 %r1465,%r1464; setp.eq.u16 %r1466,%r1465,0; @ %r1466 bra $L597; .loc 1 2806 0 mov.u64 %r320,%r1550; $L563: .loc 1 2808 0 add.u64 %r320,%r320,1; .loc 1 2807 0 ld.s8 %r664,[%r320]; cvt.u16.u32 %r1468,%r664; set.u32.eq.u16 %r1469,%r1468,32; neg.s32 %r1470,%r1469; set.u32.eq.u16 %r1473,%r1468,45; neg.s32 %r1474,%r1473; cvt.u16.u32 %r1476,%r1470; cvt.u16.u32 %r1477,%r1474; or.b16 %r1475,%r1476,%r1477; cvt.u32.u16 %r1478,%r1475; cvt.u16.u8 %r1479,%r1478; setp.ne.u16 %r1480,%r1479,0; @ %r1480 bra $L563; bra $L562; $L597: .loc 1 2806 0 mov.u64 %r320,%r1550; $L562: mov.u64 %r610,%r1550; $L565: mov.u64 %r317,%r610; .loc 1 2812 0 add.u64 %r320,%r320,1; cvt.u32.u32 %r1481,%r664; st.u8 [%r610],%r1481; add.u64 %r609,%r610,1; setp.eq.u32 %r1482,%r664,0; @ %r1482 bra $L564; ld.s8 %r664,[%r320]; mov.u64 %r610,%r609; bra $L565; $L564: ld.s8 %r663,[%r610+-1]; .loc 1 2817 0 setp.eq.u32 %r1483,%r742,2; @ %r1483 bra $L566; ld.u32 %r1484,[%frame+16]; max.s32 %r734,%r304,%r1484; .loc 1 2824 0 cvt.u16.u32 %r1485,%r663; setp.eq.u16 %r1486,%r1485,48; @ %r1486 bra $L567; bra $L568; $L599: mov.u64 %r656,1; $L570: add.u64 %r615,%r610,-2; .loc 1 2825 0 mov.u32 %r1487,0; $L571: add.u64 %r317,%r317,-1; st.u8 [%r317],%r1487; .loc 1 2824 0 ld.s8 %r1489,[%r615]; cvt.u16.u32 %r1488,%r1489; setp.eq.u16 %r1490,%r1488,48; @ %r1490 bra $L569; bra $L568; $L567: cvt.s64.s32 %r656,%r734; sub.u64 %r1491,%r610,%r1550; setp.lt.s64 %r1492,%r656,%r1491; @ %r1492 bra $L570; bra $L568; $L569: add.u64 %r615,%r615,-1; sub.u64 %r1493,%r317,%r1550; setp.gt.s64 %r1494,%r1493,%r656; @ %r1494 bra $L571; $L568: .loc 1 2829 0 setp.ne.u32 %r1495,%r742,3; @ %r1495 bra $L572; ld.u32 %r1497,[%frame+16]; add.u32 %r1496,%r304,%r1497; setp.ge.s32 %r1498,%r1496,0; @ %r1498 bra $L573; .loc 1 2832 0 mov.u32 %r1499,0; st.u8 [%frame+80],%r1499; .loc 1 2833 0 mov.u32 %r1500,0; st.u32 [%r744],%r1500; .loc 1 2831 0 mov.u64 %r317,%r1550; bra $L574; $L580: .loc 1 2845 0 mov.u32 %r1501,0; st.u32 [%r740+104],%r1501; cvt.s64.s32 %r645,%r308; setp.le.u64 %r1502,%r645,31; @ %r1502 bra $L598; mov.u32 %r620,1; .loc 1 2844 0 mov.u32 %r319,4; $L576: .loc 1 2846 0 mov.u32 %r294,%r620; .loc 1 2845 0 add.u32 %r319,%r319,%r319; add.u32 %r620,%r294,1; cvt.s64.s32 %r1504,%r319; add.u64 %r1505,%r1504,28; setp.le.u64 %r1506,%r1505,%r645; @ %r1506 bra $L576; st.u32 [%r740+104],%r294; bra $L575; $L598: mov.u32 %r294,%r1501; $L575: .loc 1 2847 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r740; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r294; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r1509,[%value_in]; } st.u64 [%r740+96],%r1509; .loc 1 2851 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1509; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1550; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r1513,[%value_in]; } .loc 1 2853 0 setp.eq.u64 %r1514,%r746,0; @ %r1514 bra $L415; .loc 1 2854 0 sub.u64 %r1516,%r317,%r1550; add.u64 %r1517,%r1509,%r1516; st.u64 [%r746],%r1517; .loc 1 2856 0 bra $L415; $L427: .loc 1 2947 0 cvt.u16.u32 %r1519,%r329; setp.eq.u16 %r1520,%r1519,32767; @ ! %r1520 bra $L689; bra $L578; $L573: ld.u32 %r1521,[%r744]; add.u32 %r743,%r743,%r1521; $L574: .loc 1 2840 0 add.u32 %r308,%r743,3; bra $L580; $L572: .loc 1 2842 0 add.u32 %r308,%r743,9; bra $L580; $L687: .loc 1 3161 0 add.u64 %r490,%r706,-2; and.b16 %r1522,%r1379,127; cvt.u32.u16 %r1524,%r1522; cvt.s32.s8 %r484,%r1524; bra $L581; $L596: .loc 1 2778 0 mov.u64 %r316,%r1550; $L556: add.u64 %r1543,%r316,1; mov.u64 %r604,%r1543; bra $L560; $L566: .loc 1 2824 0 cvt.u16.u32 %r1525,%r663; setp.ne.u16 %r1526,%r1525,48; @ %r1526 bra $L572; sub.u64 %r1527,%r610,%r1550; setp.gt.s64 %r1528,%r1527,1; @ %r1528 bra $L599; bra $L572; $L415: .loc 1 2857 0 mov.u64 %value,%r1509; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _ldcheck .visible .func (.param .u32 %value_out) _ldcheck (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,40; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r26; .reg .u64 %r27; .reg .f64 %r28; .reg .u64 %r31; .reg .u16 %r32; .reg .u16 %r33; .reg .pred %r34; .reg .u32 %r36; .reg .pred %r37; mov.u64 %r27,%ar0; .loc 1 2875 0 ld.f64 %r28,[%r27]; st.f64 [%frame+32],%r28; .loc 1 2879 0 add.u64 %r31,%frame,32; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call e53toe$isra$9,(%out_arg1,%out_arg2); } .loc 1 2886 0 ld.u16 %r33,[%frame+18]; and.b16 %r32,%r33,32767; setp.ne.u16 %r34,%r32,32767; @ %r34 bra $L692; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),eisnan$part$0,(%out_arg1); ld.param.u32 %r36,[%value_in]; } .loc 1 2889 0 setp.ne.u32 %r37,%r36,0; .loc 1 2892 0 selp.u32 %r26,1,2,%r37; bra $L690; $L692: .loc 1 2895 0 mov.u32 %r26,0; $L690: .loc 1 2896 0 mov.u32 %value,%r26; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _strtold .visible .func (.param .f64 %value_out) _strtold (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,360; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r156; .reg .u32 %r158; .reg .u64 %r160; .reg .u64 %r161; .reg .u32 %r162; .reg .u32 %r164; .reg .u64 %r165; .reg .u32 %r166; .reg .u64 %r167; .reg .u32 %r169; .reg .u32 %r171; .reg .u32 %r172; .reg .u32 %r175; .reg .u64 %r179; .reg .u32 %r180; .reg .u32 %r183; .reg .u64 %r184; .reg .u32 %r186; .reg .u32 %r187; .reg .u32 %r192; .reg .u64 %r193; .reg .u32 %r195; .reg .u32 %r200; .reg .u64 %r201; .reg .u32 %r203; .reg .u32 %r208; .reg .u64 %r209; .reg .u64 %r217; .reg .u64 %r219; .reg .u64 %r222; .reg .u64 %r223; .reg .u64 %r235; .reg .u64 %r238; .reg .u64 %r239; .reg .u32 %r240; .reg .u32 %r241; .reg .u32 %r244; .reg .u32 %r248; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .u32 %r257; .reg .u32 %r262; .reg .u64 %r263; .reg .u64 %r264; .reg .u32 %r265; .reg .u32 %r271; .reg .u64 %r272; .reg .u64 %r275; .reg .u64 %r280; .reg .u64 %r283; .reg .u64 %r284; .reg .u32 %r286; .reg .u32 %r291; .reg .u64 %r292; .reg .u32 %r296; .reg .u64 %r299; .reg .u64 %r306; .reg .u64 %r307; .reg .u64 %r310; .reg .u64 %r311; .reg .u32 %r312; .reg .u64 %r314; .reg .u32 %r315; .reg .u64 %r318; .reg .u64 %r321; .reg .u32 %r327; .reg .u32 %r330; .reg .u32 %r332; .reg .u32 %r333; .reg .u32 %r339; .reg .u64 %r340; .reg .u32 %r341; .reg .u64 %r355; .reg .u64 %r360; .reg .u64 %r362; .reg .u32 %r363; .reg .u32 %r364; .reg .u32 %r366; .reg .u32 %r367; .reg .u32 %r371; .reg .u32 %r372; .reg .u32 %r376; .reg .u64 %r378; .reg .u64 %r379; .reg .u64 %r380; .reg .u64 %r382; .reg .u64 %r385; .reg .u32 %r393; .reg .u32 %r394; .reg .u64 %r395; .reg .u64 %r399; .reg .f64 %r400; .reg .u64 %r401; .reg .u64 %r402; .reg .u32 %r415; .reg .u32 %r416; .reg .u64 %r418; .reg .pred %r419; .reg .u64 %r421; .reg .u64 %r422; .reg .u64 %r423; .reg .u16 %r424; .reg .u32 %r425; .reg .pred %r426; .reg .u16 %r427; .reg .u32 %r428; .reg .pred %r429; .reg .pred %r430; .reg .u32 %r431; .reg .pred %r432; .reg .u32 %r433; .reg .u64 %r434; .reg .u64 %r435; .reg .u32 %r436; .reg .pred %r437; .reg .pred %r438; .reg .u32 %r439; .reg .u32 %r440; .reg .u16 %r441; .reg .pred %r442; .reg .pred %r443; .reg .u32 %r444; .reg .u32 %r445; .reg .pred %r446; .reg .u32 %r448; .reg .u32 %r449; .reg .u16 %r452; .reg .u16 %r454; .reg .u16 %r455; .reg .u32 %r457; .reg .u16 %r458; .reg .pred %r459; .reg .u16 %r461; .reg .u16 %r462; .reg .u16 %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u16 %r467; .reg .u16 %r468; .reg .u16 %r469; .reg .u32 %r470; .reg .pred %r471; .reg .u16 %r472; .reg .u16 %r473; .reg .u16 %r474; .reg .u32 %r475; .reg .u32 %r476; .reg .pred %r477; .reg .u16 %r478; .reg .u32 %r480; .reg .u16 %r482; .reg .pred %r483; .reg .u64 %r484; .reg .u64 %r485; .reg .u64 %r486; .reg .u16 %r488; .reg .u16 %r489; .reg .u32 %r490; .reg .u16 %r491; .reg .pred %r492; .reg .u16 %r493; .reg .u32 %r494; .reg .pred %r495; .reg .u32 %r496; .reg .u16 %r497; .reg .u32 %r498; .reg .pred %r499; .reg .u16 %r500; .reg .pred %r501; .reg .pred %r502; .reg .pred %r503; .reg .u16 %r504; .reg .pred %r505; .reg .u16 %r506; .reg .u16 %r507; .reg .u16 %r508; .reg .u16 %r509; .reg .u16 %r510; .reg .u16 %r511; .reg .pred %r512; .reg .u16 %r514; .reg .u16 %r516; .reg .u16 %r517; .reg .pred %r520; .reg .u16 %r521; .reg .pred %r522; .reg .u16 %r523; .reg .u16 %r524; .reg .pred %r525; .reg .u16 %r526; .reg .u16 %r527; .reg .u16 %r528; .reg .u16 %r529; .reg .u16 %r530; .reg .u16 %r531; .reg .pred %r532; .reg .u16 %r534; .reg .u16 %r536; .reg .u16 %r537; .reg .pred %r540; .reg .u16 %r541; .reg .pred %r542; .reg .u16 %r543; .reg .u16 %r544; .reg .u16 %r545; .reg .u16 %r546; .reg .u16 %r547; .reg .u16 %r548; .reg .pred %r549; .reg .u16 %r551; .reg .u16 %r553; .reg .u16 %r554; .reg .pred %r557; .reg .u64 %r558; .reg .u64 %r559; .reg .u64 %r560; .reg .u64 %r561; .reg .u64 %r562; .reg .u32 %r564; .reg .pred %r567; .reg .u16 %r568; .reg .pred %r569; .reg .u64 %r570; .reg .u64 %r571; .reg .u64 %r572; .reg .u64 %r573; .reg .u64 %r574; .reg .u32 %r576; .reg .pred %r579; .reg .pred %r580; .reg .u16 %r581; .reg .pred %r582; .reg .pred %r584; .reg .pred %r586; .reg .pred %r588; .reg .pred %r590; .reg .pred %r592; .reg .pred %r594; .reg .pred %r596; .reg .pred %r598; .reg .pred %r600; .reg .pred %r602; .reg .pred %r604; .reg .pred %r606; .reg .pred %r608; .reg .pred %r610; .reg .pred %r612; .reg .pred %r613; .reg .pred %r614; .reg .pred %r615; .reg .u16 %r616; .reg .u16 %r617; .reg .u16 %r618; .reg .u16 %r628; .reg .u16 %r629; .reg .pred %r630; .reg .u16 %r631; .reg .pred %r632; .reg .u32 %r634; .reg .u32 %r635; .reg .u32 %r636; .reg .u32 %r637; .reg .pred %r638; .reg .pred %r639; .reg .u16 %r641; .reg .u16 %r642; .reg .u16 %r643; .reg .u32 %r644; .reg .pred %r645; .reg .pred %r646; .reg .pred %r647; .reg .u16 %r648; .reg .pred %r649; .reg .u16 %r650; .reg .u16 %r651; .reg .u16 %r652; .reg .pred %r653; .reg .u16 %r654; .reg .u16 %r655; .reg .pred %r656; .reg .pred %r657; .reg .u16 %r658; .reg .pred %r659; .reg .u16 %r660; .reg .u16 %r661; .reg .pred %r662; .reg .u16 %r663; .reg .u16 %r664; .reg .u16 %r665; .reg .u16 %r666; .reg .u16 %r667; .reg .u16 %r668; .reg .pred %r669; .reg .u16 %r671; .reg .u16 %r673; .reg .u16 %r674; .reg .pred %r677; .reg .u16 %r678; .reg .pred %r679; .reg .u16 %r680; .reg .u16 %r681; .reg .u16 %r682; .reg .u16 %r683; .reg .u16 %r684; .reg .u16 %r685; .reg .pred %r686; .reg .u16 %r688; .reg .u16 %r690; .reg .u16 %r691; .reg .pred %r694; .reg .u64 %r695; .reg .u64 %r696; .reg .u64 %r697; .reg .u64 %r698; .reg .u64 %r699; .reg .u32 %r701; .reg .pred %r704; .reg .u16 %r705; .reg .pred %r706; .reg .u16 %r707; .reg .u16 %r708; .reg .u16 %r709; .reg .u16 %r710; .reg .u16 %r711; .reg .u16 %r712; .reg .pred %r713; .reg .u16 %r715; .reg .u16 %r717; .reg .u16 %r718; .reg .pred %r721; .reg .u16 %r722; .reg .pred %r723; .reg .u16 %r724; .reg .pred %r725; .reg .pred %r727; .reg .u16 %r728; .reg .pred %r729; .reg .u32 %r732; .reg .pred %r733; .reg .u16 %r734; .reg .pred %r735; .reg .u16 %r736; .reg .u16 %r737; .reg .u32 %r740; .reg .u32 %r742; .reg .u32 %r745; .reg .u32 %r746; .reg .u64 %r747; .reg .pred %r749; .reg .pred %r750; .reg .pred %r751; .reg .u64 %r752; .reg .u64 %r755; .reg .u32 %r762; .reg .u32 %r763; .reg .u16 %r764; .reg .pred %r765; .reg .u32 %r766; .reg .pred %r767; .reg .pred %r777; .reg .pred %r782; .reg .u64 %r783; .reg .u32 %r790; .reg .u64 %r791; .reg .u32 %r798; .reg .u32 %r799; .reg .u32 %r802; .reg .u32 %r804; .reg .u64 %r807; .reg .u16 %r809; .reg .u16 %r810; .reg .u16 %r811; .reg .u16 %r812; .reg .pred %r813; .reg .u16 %r815; .reg .pred %r816; .reg .pred %r817; .reg .pred %r818; .reg .u16 %r822; .reg .pred %r823; .reg .u16 %r824; .reg .u16 %r825; .reg .u64 %r826; .reg .pred %r832; .reg .u32 %r834; .reg .u32 %r836; .reg .u32 %r838; .reg .u32 %r840; .reg .u32 %r841; .reg .u16 %r842; .reg .u16 %r843; .reg .u16 %r844; .reg .u16 %r845; .reg .u16 %r846; .reg .u16 %r847; .reg .u16 %r848; .reg .u64 %r849; .reg .u64 %r850; .reg .u64 %r851; .reg .u64 %r853; .reg .u64 %r854; .reg .u64 %r855; .reg .u64 %r857; .reg .u64 %r858; .reg .u64 %r859; .reg .u64 %r861; .reg .u64 %r862; .reg .pred %r864; .reg .pred %r866; .reg .u64 %r867; .reg .u32 %r868; .reg .u32 %r869; .reg .u64 %r870; .reg .u64 %r871; .reg .pred %r873; .reg .u32 %r878; .reg .u32 %r881; .reg .u32 %r882; .reg .u64 %r883; .reg .u32 %r887; .reg .pred %r888; .reg .u32 %r891; .reg .u32 %r893; .reg .u32 %r896; .reg .u32 %r897; .reg .u64 %r898; .reg .u32 %r902; .reg .pred %r903; .reg .u32 %r906; .reg .u32 %r908; .reg .u32 %r911; .reg .u32 %r912; .reg .u64 %r913; .reg .u32 %r917; .reg .pred %r918; .reg .u64 %r919; .reg .u64 %r920; .reg .u64 %r921; .reg .u64 %r922; .reg .u64 %r923; .reg .u64 %r924; .reg .u64 %r925; .reg .u64 %r926; .reg .u64 %r927; .reg .u64 %r928; .reg .u32 %r937; .reg .u64 %r938; .reg .u64 %r939; .reg .u64 %r940; .reg .u64 %r941; .reg .u64 %r942; .reg .u64 %r943; .reg .u64 %r944; .reg .u64 %r945; mov.u64 %r401,%ar0; mov.u64 %r402,%ar1; .loc 1 3237 0 mov.u32 %r415,-1; st.u32 [%frame+200],%r415; .loc 1 3238 0 mov.u32 %r416,144; st.u32 [%frame+204],%r416; .loc 1 3263 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r401; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r418,[%value_in]; } cvt.u32.u64 %r156,%r418; add.u32 %r158,%r156,2; .loc 1 3264 0 setp.le.s32 %r419,%r158,200; @ %r419 bra $L797; .loc 1 3268 0 cvt.s64.s32 %r422,%r158; mov.u64 %r421,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r422; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r421; call (%value_in),calloc,(%out_arg1,%out_arg2); ld.param.u64 %r423,[%value_in]; } mov.u64 %r160,%r423; .loc 1 3269 0 cvt.u32.u64 %r330,%r421; bra $L695; $L797: .loc 1 3259 0 mov.u32 %r330,0; .loc 1 3265 0 mov.u64 %r160,%frame; $L695: .loc 1 3273 0 ld.s8 %r425,[%r401]; cvt.u16.u32 %r424,%r425; setp.ne.u16 %r426,%r424,32; @ %r426 bra $L798; mov.u64 %r161,%r401; .loc 1 3272 0 mov.u32 %r162,0; $L697: .loc 1 3275 0 add.u64 %r161,%r161,1; .loc 1 3276 0 add.u32 %r162,%r162,1; .loc 1 3273 0 ld.s8 %r428,[%r161]; cvt.u16.u32 %r427,%r428; setp.eq.u16 %r429,%r427,32; @ %r429 bra $L697; mov.u32 %r341,%r162; bra $L696; $L798: mov.u64 %r161,%r401; mov.u32 %r341,0; $L696: .loc 1 3279 0 setp.le.s32 %r430,%r158,0; @ %r430 bra $L799; .loc 1 3281 0 add.u64 %r395,%r161,1; add.u64 %r165,%r160,1; ld.s8 %r393,[%r161]; cvt.u32.u32 %r431,%r393; st.u8 [%r160],%r431; setp.eq.u32 %r432,%r393,0; @ %r432 bra $L698; mov.u64 %r252,%r165; mov.u64 %r251,%r395; add.u32 %r433,%r156,1; cvt.u64.u32 %r434,%r433; add.u64 %r435,%r434,1; add.u64 %r217,%r160,%r435; bra $L699; $L700: add.u64 %r252,%r165,1; ld.s8 %r164,[%r251]; cvt.u32.u32 %r436,%r164; st.u8 [%r165],%r436; add.u64 %r251,%r251,1; setp.eq.u32 %r437,%r164,0; @ %r437 bra $L800; $L699: mov.u64 %r165,%r252; .loc 1 3279 0 setp.ne.u64 %r438,%r217,%r165; @ %r438 bra $L700; bra $L698; $L799: mov.u64 %r165,%r160; bra $L698; $L800: .loc 1 3281 0 mov.u64 %r165,%r252; $L698: .loc 1 3284 0 mov.u32 %r439,0; st.u8 [%r165],%r439; .loc 1 3287 0 ld.u32 %r166,[%frame+204]; .loc 1 3288 0 mov.u32 %r440,144; st.u32 [%frame+204],%r440; add.u64 %r920,%frame,332; mov.u64 %r355,%r920; add.u64 %r253,%frame,358; mov.u64 %r264,%r920; .loc 1 672 0 mov.u16 %r441,0; $L701: st.u16 [%r264],%r441; add.u64 %r264,%r264,2; .loc 1 671 0 setp.ne.u64 %r442,%r253,%r264; @ %r442 bra $L701; mov.u64 %r167,%r160; .loc 1 3290 0 mov.u32 %r332,0; .loc 1 3297 0 mov.u32 %r175,%r332; .loc 1 3289 0 mov.u32 %r240,%r332; .loc 1 3295 0 mov.u32 %r172,%r332; .loc 1 3293 0 mov.u32 %r186,%r332; .loc 1 3292 0 mov.u32 %r241,%r332; .loc 1 3291 0 mov.u32 %r171,%r332; .loc 1 804 0 add.u64 %r939,%frame,356; add.u64 %r940,%frame,334; add.u64 %r941,%frame,306; add.u64 %r942,%r920,24; add.u64 %r943,%frame,330; add.u64 %r944,%frame,308; add.u64 %r945,%frame,332; $L702: .loc 1 3300 0 ld.s8 %r366,[%r167]; add.u32 %r169,%r366,-48; .loc 1 3301 0 setp.gt.u32 %r443,%r169,9; @ %r443 bra $L703; .loc 1 3304 0 or.b32 %r444,%r171,%r172; or.b32 %r445,%r444,%r169; setp.eq.u32 %r446,%r445,0; @ %r446 bra $L704; .loc 1 3307 0 set.u32.eq.u32 %r448,%r175,0; neg.s32 %r449,%r448; cvt.u16.u32 %r452,%r171; cvt.u16.u32 %r455,%r449; and.b16 %r454,%r455,%r452; cvt.u32.u16 %r457,%r454; cvt.u16.u8 %r458,%r457; setp.eq.u16 %r459,%r458,0; @ %r459 bra $L705; .loc 1 3310 0 cvt.u16.u32 %r462,%r366; add.u16 %r461,%r462,-48; cvt.u32.u16 %r464,%r461; cvt.u16.u8 %r463,%r464; setp.gt.u16 %r465,%r463,9; @ %r465 bra $L801; mov.u64 %r179,%r167; $L707: .loc 1 3311 0 add.u64 %r179,%r179,1; .loc 1 3310 0 ld.s8 %r180,[%r179]; cvt.u16.u32 %r468,%r180; add.u16 %r467,%r468,-48; cvt.u32.u16 %r470,%r467; cvt.u16.u8 %r469,%r470; setp.le.u16 %r471,%r469,9; @ %r471 bra $L707; bra $L706; $L801: mov.u32 %r180,%r366; mov.u64 %r179,%r167; $L706: .loc 1 3314 0 cvt.u16.u32 %r473,%r180; and.b16 %r472,%r473,95; cvt.u32.u16 %r476,%r472; cvt.s32.s8 %r475,%r476; cvt.u16.u32 %r474,%r475; setp.eq.u16 %r477,%r474,69; @ %r477 bra $L708; and.b16 %r478,%r473,127; cvt.u32.u16 %r480,%r478; cvt.s32.s8 %r183,%r480; cvt.u32.u8 %r394,%r480; cvt.u16.u32 %r482,%r183; setp.gt.s16 %r483,%r482,44; @ %r483 bra $L709; mov.u64 %r485,17596481020929; shr.u64 %r484,%r485,%r394; not.b64 %r486,%r484; cvt.u16.u64 %r489,%r486; and.b16 %r488,%r489,1; .loc 1 3315 0 cvt.u32.u16 %r490,%r488; cvt.u16.u8 %r491,%r490; setp.ne.u16 %r492,%r491,0; @ %r492 bra $L709; $L708: .loc 1 3318 0 add.u64 %r184,%r179,-1; .loc 1 3319 0 ld.s8 %r494,[%r179+-1]; cvt.u16.u32 %r493,%r494; setp.ne.u16 %r495,%r493,48; @ %r495 bra $L710; mov.u64 %r275,%r184; .loc 1 3320 0 mov.u32 %r496,122; $L711: add.u64 %r184,%r184,-1; st.u8 [%r275],%r496; add.u64 %r275,%r275,-1; .loc 1 3319 0 ld.s8 %r498,[%r184]; cvt.u16.u32 %r497,%r498; setp.eq.u16 %r499,%r497,48; @ %r499 bra $L711; ld.s8 %r366,[%r167]; $L710: .loc 1 3322 0 cvt.u16.u32 %r500,%r366; setp.eq.u16 %r501,%r500,122; @ %r501 bra $L802; .loc 1 3321 0 mov.u32 %r175,1; $L705: .loc 1 3330 0 ld.u16 %r208,[%frame+336]; setp.ne.u32 %r502,%r208,0; @ %r502 bra $L712; .loc 1 3332 0 setp.eq.u32 %r503,%r171,0; @ %r503 bra $L713; .loc 1 3333 0 add.u32 %r186,%r186,1; $L713: .loc 1 805 0 mov.u32 %r192,%r208; .loc 1 804 0 mov.u64 %r193,%r939; $L717: .loc 1 809 0 ld.u16 %r187,[%r193]; cvt.u16.u32 %r504,%r187; setp.ge.s16 %r505,%r504,0; @ %r505 bra $L714; .loc 1 810 0 cvt.u16.u32 %r507,%r192; or.b16 %r506,%r507,1; cvt.u32.u16 %r192,%r506; $L714: .loc 1 811 0 cvt.u16.u32 %r508,%r187; add.u16 %r509,%r508,%r508; .loc 1 812 0 cvt.u16.u32 %r511,%r192; and.b16 %r510,%r511,2; setp.ne.u16 %r512,%r510,0; @ %r512 bra $L715; .loc 1 811 0 st.u16 [%r193],%r509; bra $L716; $L715: .loc 1 813 0 or.b16 %r514,%r509,1; st.u16 [%r193],%r514; $L716: .loc 1 814 0 cvt.u16.u32 %r516,%r192; add.u16 %r517,%r516,%r516; cvt.u32.u16 %r192,%r517; .loc 1 815 0 add.u64 %r193,%r193,-2; .loc 1 807 0 setp.ne.u64 %r520,%r193,%r940; @ %r520 bra $L717; mov.u64 %r340,%r941; mov.u64 %r299,%r941; mov.u64 %r307,%r920; $L718: .loc 1 696 0 ld.u16 %r521,[%r307]; st.u16 [%r299],%r521; add.u64 %r307,%r307,2; add.u64 %r299,%r299,2; .loc 1 695 0 setp.ne.u64 %r522,%r942,%r307; @ %r522 bra $L718; .loc 1 698 0 mov.u16 %r523,0; st.u16 [%frame+330],%r523; .loc 1 805 0 mov.u32 %r200,%r208; .loc 1 804 0 mov.u64 %r201,%r943; $L722: .loc 1 809 0 ld.u16 %r195,[%r201]; cvt.u16.u32 %r524,%r195; setp.ge.s16 %r525,%r524,0; @ %r525 bra $L719; .loc 1 810 0 cvt.u16.u32 %r527,%r200; or.b16 %r526,%r527,1; cvt.u32.u16 %r200,%r526; $L719: .loc 1 811 0 cvt.u16.u32 %r528,%r195; add.u16 %r529,%r528,%r528; .loc 1 812 0 cvt.u16.u32 %r531,%r200; and.b16 %r530,%r531,2; setp.ne.u16 %r532,%r530,0; @ %r532 bra $L720; .loc 1 811 0 st.u16 [%r201],%r529; bra $L721; $L720: .loc 1 813 0 or.b16 %r534,%r529,1; st.u16 [%r201],%r534; $L721: .loc 1 814 0 cvt.u16.u32 %r536,%r200; add.u16 %r537,%r536,%r536; cvt.u32.u16 %r200,%r537; .loc 1 815 0 add.u64 %r201,%r201,-2; .loc 1 807 0 setp.ne.u64 %r540,%r201,%r944; @ %r540 bra $L722; .loc 1 804 0 mov.u64 %r209,%r943; $L726: .loc 1 809 0 ld.u16 %r203,[%r209]; cvt.u16.u32 %r541,%r203; setp.ge.s16 %r542,%r541,0; @ %r542 bra $L723; .loc 1 810 0 cvt.u16.u32 %r544,%r208; or.b16 %r543,%r544,1; cvt.u32.u16 %r208,%r543; $L723: .loc 1 811 0 cvt.u16.u32 %r545,%r203; add.u16 %r546,%r545,%r545; .loc 1 812 0 cvt.u16.u32 %r548,%r208; and.b16 %r547,%r548,2; setp.ne.u16 %r549,%r547,0; @ %r549 bra $L724; .loc 1 811 0 st.u16 [%r209],%r546; bra $L725; $L724: .loc 1 813 0 or.b16 %r551,%r546,1; st.u16 [%r209],%r551; $L725: .loc 1 814 0 cvt.u16.u32 %r553,%r208; add.u16 %r554,%r553,%r553; cvt.u32.u16 %r208,%r554; .loc 1 815 0 add.u64 %r209,%r209,-2; .loc 1 807 0 setp.ne.u64 %r557,%r209,%r944; @ %r557 bra $L726; .loc 1 913 0 mov.u32 %r327,0; .loc 1 912 0 mov.u64 %r223,%r939; .loc 1 911 0 mov.u64 %r222,%r943; $L727: .loc 1 916 0 ld.u16 %r558,[%r222]; ld.u16 %r559,[%r223]; add.u64 %r560,%r558,%r559; cvt.u64.u32 %r561,%r327; add.u64 %r219,%r560,%r561; .loc 1 921 0 st.u16 [%r223],%r219; .loc 1 922 0 add.u64 %r222,%r222,-2; .loc 1 923 0 add.u64 %r223,%r223,-2; .loc 1 917 0 shr.u64 %r562,%r219,16; cvt.u32.u64 %r564,%r562; and.b32 %r327,%r564,1; .loc 1 914 0 setp.ne.u64 %r567,%r222,%r944; @ %r567 bra $L727; .loc 1 672 0 mov.u16 %r568,0; $L728: st.u16 [%r340],%r568; add.u64 %r340,%r340,2; .loc 1 671 0 setp.ne.u64 %r569,%r945,%r340; @ %r569 bra $L728; .loc 1 3340 0 st.u16 [%frame+328],%r169; .loc 1 913 0 mov.u32 %r367,0; .loc 1 912 0 mov.u64 %r239,%r939; .loc 1 911 0 mov.u64 %r238,%r943; $L729: .loc 1 916 0 ld.u16 %r570,[%r238]; ld.u16 %r571,[%r239]; add.u64 %r572,%r570,%r571; cvt.u64.u32 %r573,%r367; add.u64 %r235,%r572,%r573; .loc 1 921 0 st.u16 [%r239],%r235; .loc 1 922 0 add.u64 %r238,%r238,-2; .loc 1 923 0 add.u64 %r239,%r239,-2; .loc 1 917 0 shr.u64 %r574,%r235,16; cvt.u32.u64 %r576,%r574; and.b32 %r367,%r576,1; .loc 1 914 0 setp.ne.u64 %r579,%r238,%r944; @ %r579 bra $L729; bra $L730; $L712: .loc 1 3346 0 or.b32 %r240,%r240,%r169; .loc 1 3348 0 setp.ne.u32 %r580,%r171,0; @ %r580 bra $L730; .loc 1 3349 0 add.u32 %r186,%r186,-1; $L730: .loc 1 3351 0 add.u32 %r172,%r172,1; bra $L704; $L703: .loc 1 3355 0 cvt.u16.u32 %r581,%r366; setp.eq.u16 %r582,%r581,45; @ %r582 bra $L731; setp.gt.s16 %r584,%r581,45; @ %r584 bra $L732; setp.eq.u16 %r586,%r581,13; @ %r586 bra $L803; setp.gt.s16 %r588,%r581,13; @ %r588 bra $L734; setp.eq.u16 %r590,%r581,0; @ %r590 bra $L803; setp.eq.u16 %r592,%r581,10; @ ! %r592 bra $L709; bra $L803; $L734: setp.eq.u16 %r594,%r581,43; @ %r594 bra $L735; setp.gt.s16 %r596,%r581,43; @ %r596 bra $L803; setp.eq.u16 %r598,%r581,32; @ ! %r598 bra $L709; bra $L803; $L732: setp.eq.u16 %r600,%r581,73; @ %r600 bra $L736; setp.gt.s16 %r602,%r581,73; @ %r602 bra $L737; setp.eq.u16 %r604,%r581,46; @ %r604 bra $L738; setp.eq.u16 %r606,%r581,69; @ %r606 bra $L739; bra $L709; $L737: setp.eq.u16 %r608,%r581,105; @ %r608 bra $L736; setp.eq.u16 %r610,%r581,122; @ %r610 bra $L704; setp.eq.u16 %r612,%r581,101; @ ! %r612 bra $L709; bra $L739; $L738: .loc 1 3363 0 setp.ne.u32 %r613,%r171,0; @ %r613 bra $L709; .loc 1 3365 0 mov.u32 %r171,1; bra $L704; $L731: .loc 1 3369 0 setp.ne.u32 %r614,%r241,0; @ %r614 bra $L804; .loc 1 3368 0 mov.u32 %r332,65535; .loc 1 3371 0 mov.u32 %r241,1; bra $L704; $L735: .loc 1 3374 0 setp.eq.u32 %r615,%r241,0; @ %r615 bra $L805; bra $L709; $L804: .loc 1 3368 0 mov.u32 %r332,65535; $L709: .loc 1 3762 0 mov.u16 %r616,32767; st.u16 [%frame+334],%r616; .loc 1 3763 0 mov.u16 %r617,0; st.u16 [%frame+336],%r617; .loc 1 3765 0 mov.u16 %r618,-16384; st.u16 [%frame+338],%r618; .loc 1 3767 0 st.u16 [%frame+340],%r617; st.u16 [%frame+342],%r617; st.u16 [%frame+344],%r617; st.u16 [%frame+346],%r617; st.u16 [%frame+348],%r617; st.u16 [%frame+350],%r617; st.u16 [%frame+352],%r617; st.u16 [%frame+354],%r617; .loc 1 3773 0 st.u16 [%frame+356],%r617; .loc 1 3536 0 st.u32 [%frame+204],%r166; .loc 1 3537 0 cvt.u16.u32 %r628,%r332; st.u16 [%frame+332],%r628; mov.u32 %r371,32767; bra $L740; $L802: .loc 1 3321 0 mov.u32 %r171,1; .loc 1 3322 0 mov.u32 %r175,%r171; bra $L704; $L805: .loc 1 3376 0 mov.u32 %r241,1; $L704: .loc 1 3398 0 add.u64 %r167,%r167,1; bra $L702; $L739: .loc 1 3408 0 ld.s8 %r339,[%r167+1]; cvt.u16.u32 %r629,%r339; setp.eq.u16 %r630,%r629,45; @ %r630 bra $L741; .loc 1 3406 0 add.u64 %r167,%r167,1; .loc 1 3404 0 mov.u32 %r248,1; bra $L742; $L741: ld.s8 %r339,[%r167+2]; .loc 1 3411 0 add.u64 %r167,%r167,2; .loc 1 3410 0 mov.u32 %r248,-1; $L742: .loc 1 3413 0 cvt.u16.u32 %r631,%r339; setp.ne.u16 %r632,%r631,43; @ %r632 bra $L743; ld.s8 %r339,[%r167+1]; .loc 1 3414 0 add.u64 %r167,%r167,1; bra $L743; $L747: .loc 1 3417 0 shl.b32 %r634,%r244,2; add.u32 %r635,%r634,%r244; add.u32 %r636,%r635,%r635; .loc 1 3418 0 add.u64 %r167,%r167,1; add.u32 %r637,%r339,-48; add.u32 %r244,%r637,%r636; .loc 1 3419 0 setp.gt.s32 %r638,%r244,4977; @ %r638 bra $L744; ld.s8 %r339,[%r167]; bra $L745; $L744: .loc 1 3421 0 setp.eq.u32 %r639,%r248,-1; @ ! %r639 bra $L736; bra $L746; $L743: .loc 1 3414 0 mov.u32 %r244,0; $L745: .loc 1 3415 0 cvt.u16.u32 %r642,%r339; add.u16 %r641,%r642,-48; cvt.u32.u16 %r644,%r641; cvt.u16.u8 %r643,%r644; setp.le.u16 %r645,%r643,9; @ %r645 bra $L747; .loc 1 3427 0 setp.ne.u32 %r646,%r248,-1; @ %r646 bra $L748; .loc 1 3436 0 setp.gt.s32 %r647,%r244,4977; @ %r647 bra $L746; .loc 1 3428 0 neg.s32 %r244,%r244; bra $L733; $L736: .loc 1 672 0 mov.u16 %r648,0; $L749: st.u16 [%r355],%r648; add.u64 %r355,%r355,2; .loc 1 671 0 setp.ne.u64 %r649,%r264,%r355; @ %r649 bra $L749; .loc 1 3433 0 mov.u16 %r650,32767; st.u16 [%frame+334],%r650; .loc 1 3536 0 st.u32 [%frame+204],%r166; .loc 1 3537 0 cvt.u16.u32 %r651,%r332; st.u16 [%frame+332],%r651; mov.u32 %r371,32767; bra $L740; $L746: .loc 1 672 0 mov.u16 %r652,0; $L750: st.u16 [%r355],%r652; add.u64 %r355,%r355,2; .loc 1 671 0 setp.ne.u64 %r653,%r264,%r355; @ %r653 bra $L750; ld.u16 %r371,[%frame+334]; cvt.u16.u32 %r655,%r371; and.b16 %r654,%r655,32767; cvt.u32.u16 %r372,%r654; bra $L751; $L803: .loc 1 3294 0 mov.u32 %r244,0; $L733: .loc 1 3444 0 sub.u32 %r296,%r244,%r186; .loc 1 3446 0 setp.le.s32 %r656,%r296,0; @ %r656 bra $L752; ld.u16 %r333,[%frame+336]; setp.ne.u32 %r657,%r333,0; @ %r657 bra $L753; add.u64 %r922,%frame,356; add.u64 %r921,%frame,334; add.u64 %r927,%frame,306; add.u64 %r923,%r920,24; add.u64 %r919,%frame,330; add.u64 %r928,%frame,308; .loc 1 698 0 cvt.u16.u32 %r660,%r333; .loc 1 913 0 mov.u32 %r937,%r333; add.u64 %r938,%frame,330; $L771: mov.u64 %r379,%r927; .loc 1 3294 0 mov.u64 %r360,%r927; mov.u64 %r362,%r920; $L754: .loc 1 696 0 ld.u16 %r658,[%r362]; st.u16 [%r360],%r658; add.u64 %r362,%r362,2; add.u64 %r360,%r360,2; .loc 1 695 0 setp.ne.u64 %r659,%r923,%r362; @ %r659 bra $L754; .loc 1 698 0 st.u16 [%frame+330],%r660; .loc 1 805 0 mov.u32 %r262,%r333; .loc 1 804 0 mov.u64 %r263,%r919; $L758: .loc 1 809 0 ld.u16 %r257,[%r263]; cvt.u16.u32 %r661,%r257; setp.ge.s16 %r662,%r661,0; @ %r662 bra $L755; .loc 1 810 0 cvt.u16.u32 %r664,%r262; or.b16 %r663,%r664,1; cvt.u32.u16 %r262,%r663; $L755: .loc 1 811 0 cvt.u16.u32 %r665,%r257; add.u16 %r666,%r665,%r665; .loc 1 812 0 cvt.u16.u32 %r668,%r262; and.b16 %r667,%r668,2; setp.ne.u16 %r669,%r667,0; @ %r669 bra $L756; .loc 1 811 0 st.u16 [%r263],%r666; bra $L757; $L756: .loc 1 813 0 or.b16 %r671,%r666,1; st.u16 [%r263],%r671; $L757: .loc 1 814 0 cvt.u16.u32 %r673,%r262; add.u16 %r674,%r673,%r673; cvt.u32.u16 %r262,%r674; .loc 1 815 0 add.u64 %r263,%r263,-2; .loc 1 807 0 setp.ne.u64 %r677,%r263,%r928; @ %r677 bra $L758; .loc 1 805 0 mov.u32 %r271,%r333; .loc 1 804 0 mov.u64 %r272,%r919; $L762: .loc 1 809 0 ld.u16 %r265,[%r272]; cvt.u16.u32 %r678,%r265; setp.ge.s16 %r679,%r678,0; @ %r679 bra $L759; .loc 1 810 0 cvt.u16.u32 %r681,%r271; or.b16 %r680,%r681,1; cvt.u32.u16 %r271,%r680; $L759: .loc 1 811 0 cvt.u16.u32 %r682,%r265; add.u16 %r683,%r682,%r682; .loc 1 812 0 cvt.u16.u32 %r685,%r271; and.b16 %r684,%r685,2; setp.ne.u16 %r686,%r684,0; @ %r686 bra $L760; .loc 1 811 0 st.u16 [%r272],%r683; bra $L761; $L760: .loc 1 813 0 or.b16 %r688,%r683,1; st.u16 [%r272],%r688; $L761: .loc 1 814 0 cvt.u16.u32 %r690,%r271; add.u16 %r691,%r690,%r690; cvt.u32.u16 %r271,%r691; .loc 1 815 0 add.u64 %r272,%r272,-2; .loc 1 807 0 setp.ne.u64 %r694,%r272,%r928; @ %r694 bra $L762; .loc 1 913 0 mov.u32 %r364,%r937; .loc 1 912 0 mov.u64 %r284,%r919; .loc 1 911 0 mov.u64 %r283,%r922; $L763: .loc 1 916 0 ld.u16 %r695,[%r283]; ld.u16 %r696,[%r284]; add.u64 %r697,%r695,%r696; cvt.u64.u32 %r698,%r364; add.u64 %r280,%r697,%r698; .loc 1 921 0 st.u16 [%r284],%r280; .loc 1 922 0 add.u64 %r283,%r283,-2; .loc 1 923 0 add.u64 %r284,%r284,-2; .loc 1 917 0 shr.u64 %r699,%r280,16; cvt.u32.u64 %r701,%r699; and.b32 %r364,%r701,1; .loc 1 914 0 setp.ne.u64 %r704,%r283,%r921; @ %r704 bra $L763; .loc 1 805 0 mov.u32 %r291,%r333; .loc 1 804 0 mov.u64 %r292,%r919; $L767: .loc 1 809 0 ld.u16 %r286,[%r292]; cvt.u16.u32 %r705,%r286; setp.ge.s16 %r706,%r705,0; @ %r706 bra $L764; .loc 1 810 0 cvt.u16.u32 %r708,%r291; or.b16 %r707,%r708,1; cvt.u32.u16 %r291,%r707; $L764: .loc 1 811 0 cvt.u16.u32 %r709,%r286; add.u16 %r710,%r709,%r709; .loc 1 812 0 cvt.u16.u32 %r712,%r291; and.b16 %r711,%r712,2; setp.ne.u16 %r713,%r711,0; @ %r713 bra $L765; .loc 1 811 0 st.u16 [%r292],%r710; bra $L766; $L765: .loc 1 813 0 or.b16 %r715,%r710,1; st.u16 [%r292],%r715; $L766: .loc 1 814 0 cvt.u16.u32 %r717,%r291; add.u16 %r718,%r717,%r717; cvt.u32.u16 %r291,%r718; .loc 1 815 0 add.u64 %r292,%r292,-2; .loc 1 807 0 setp.ne.u64 %r721,%r292,%r928; @ %r721 bra $L767; .loc 1 3453 0 ld.u16 %r722,[%frame+310]; setp.ne.u16 %r723,%r722,0; @ %r723 bra $L768; .loc 1 3455 0 add.u32 %r296,%r296,-1; mov.u64 %r378,%r920; $L769: .loc 1 696 0 ld.u16 %r724,[%r379]; st.u16 [%r378],%r724; add.u64 %r379,%r379,2; add.u64 %r378,%r378,2; .loc 1 695 0 setp.ne.u64 %r725,%r938,%r379; @ %r725 bra $L769; .loc 1 698 0 st.u16 [%frame+356],%r660; .loc 1 3446 0 setp.eq.u32 %r727,%r296,0; @ %r727 bra $L770; ld.u16 %r728,[%frame+336]; setp.eq.u16 %r729,%r728,0; @ %r729 bra $L771; bra $L753; $L752: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r732,[%value_in]; } setp.le.s32 %r733,%r732,144; @ %r733 bra $L772; $L792: .loc 1 672 0 mov.u16 %r734,0; $L773: st.u16 [%r355],%r734; add.u64 %r355,%r355,2; .loc 1 671 0 setp.ne.u64 %r735,%r264,%r355; @ %r735 bra $L773; ld.u16 %r371,[%frame+334]; cvt.u16.u32 %r737,%r371; and.b16 %r736,%r737,32767; cvt.u32.u16 %r372,%r736; bra $L751; $L772: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r746,16526; sub.u32 %r745,%r746,%r732; cvt.s64.s32 %r747,%r745; .loc 1 3464 0 mov.u32 %r742,64; mov.u32 %r740,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r740; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r747; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r742; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; .loc 1 3475 0 setp.eq.u32 %r749,%r296,0; @ %r749 bra $L774; add.u64 %r927,%frame,306; $L795: .loc 1 3481 0 setp.ge.s32 %r750,%r296,0; @ %r750 bra $L806; .loc 1 3485 0 setp.lt.s32 %r751,%r296,-4096; @ %r751 bra $L776; .loc 1 3483 0 neg.s32 %r296,%r296; .loc 1 3484 0 mov.u32 %r315,-1; add.u64 %r926,%frame,280; bra $L775; $L776: .loc 1 3487 0 add.u64 %r926,%frame,280; cvta.const.u64 %r752,etens; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r752; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r926; call emovi,(%out_arg1,%out_arg2); } .loc 1 3488 0 ld.u16 %r755,[%frame+282]; sub.u64 %r310,%r306,%r755; .loc 1 3489 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r926; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r920; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r925; call (%value_in),edivm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r762,[%value_in]; } .loc 1 3490 0 add.u64 %r306,%r310,16383; mov.u32 %r763,-4096; sub.u32 %r296,%r763,%r296; .loc 1 3484 0 mov.u32 %r315,-1; bra $L775; $L806: .loc 1 3480 0 mov.u32 %r315,1; add.u64 %r926,%frame,280; $L775: mov.u64 %r382,%r927; add.u64 %r380,%frame,326; mov.u32 %r363,0; cvta.const.u64 %r311,eone; $L778: .loc 1 455 0 add.u64 %r311,%r311,2; cvt.u16.u32 %r764,%r363; st.u16 [%r382],%r764; add.u64 %r382,%r382,2; .loc 1 454 0 setp.eq.u64 %r765,%r380,%r382; @ %r765 bra $L807; ld.u16 %r363,[%r311]; bra $L778; $L807: .loc 1 3494 0 cvta.const.u64 %r314,etens+240; .loc 1 3496 0 mov.u32 %r312,1; add.u64 %r924,%r314,-260; $L777: .loc 1 3499 0 and.b32 %r766,%r296,%r312; setp.eq.u32 %r767,%r766,0; @ %r767 bra $L779; .loc 1 3500 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r314; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r927; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r927; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r925; call emul,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); } $L779: .loc 1 3501 0 add.u64 %r314,%r314,-20; .loc 1 3502 0 add.u32 %r312,%r312,%r312; .loc 1 3504 0 setp.ne.u64 %r777,%r314,%r924; @ %r777 bra $L777; .loc 1 3506 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r927; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r926; call emovi,(%out_arg1,%out_arg2); } .loc 1 3507 0 setp.ne.u32 %r782,%r315,-1; @ %r782 bra $L780; .loc 1 3509 0 ld.u16 %r783,[%frame+282]; sub.u64 %r318,%r306,%r783; .loc 1 3510 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r926; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r920; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r925; call (%value_in),edivm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r790,[%value_in]; } mov.u32 %r296,%r790; .loc 1 3511 0 add.u64 %r306,%r318,16383; bra $L774; $L780: .loc 1 3515 0 ld.u16 %r791,[%frame+282]; add.u64 %r321,%r791,%r306; .loc 1 3516 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r926; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r920; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r925; call (%value_in),emulm,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r798,[%value_in]; } mov.u32 %r296,%r798; .loc 1 3517 0 add.u64 %r306,%r321,-16382; $L774: .loc 1 3531 0 mov.u32 %r799,53; st.u32 [%frame+204],%r799; .loc 1 3524 0 add.u64 %r807,%r306,-15360; .loc 1 3532 0 mov.u32 %r804,64; mov.u32 %r802,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r296; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r802; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r807; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r804; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } ld.u16 %r371,[%frame+334]; cvt.u16.u32 %r810,%r371; and.b16 %r809,%r810,32767; cvt.u32.u16 %r372,%r809; $L751: .loc 1 3536 0 st.u32 [%frame+204],%r166; .loc 1 3537 0 cvt.u16.u32 %r811,%r332; st.u16 [%frame+332],%r811; .loc 1 708 0 cvt.u16.u32 %r812,%r372; setp.ne.u16 %r813,%r812,32767; @ %r813 bra $L781; $L740: add.u64 %r385,%frame,338; $L783: .loc 1 712 0 ld.u16 %r815,[%r385]; setp.ne.u16 %r816,%r815,0; @ %r816 bra $L782; add.u64 %r385,%r385,2; .loc 1 710 0 setp.ne.u64 %r817,%r264,%r385; @ %r817 bra $L783; $L781: .loc 1 2116 0 setp.ne.u32 %r818,%r332,0; .loc 1 2115 0 selp.u64 %r399,-9223372036854775808,0,%r818; selp.u32 %r332,32768,%r332,%r818; .loc 1 2120 0 cvt.u16.u32 %r822,%r371; setp.le.u16 %r823,%r822,2046; @ %r823 bra $L786; .loc 1 2123 0 cvt.u16.u32 %r825,%r332; or.b16 %r824,%r825,32752; cvt.u64.u16 %r826,%r824; .loc 1 2126 0 shl.b64 %r399,%r826,48; bra $L787; $L786: .loc 1 2149 0 setp.ne.u32 %r832,%r371,0; @ %r832 bra $L788; mov.u32 %r834,4; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r834; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r836,[%value_in]; } mov.u32 %r376,%r371; bra $L789; $L788: mov.u32 %r838,5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r838; call (%value_in),eshift$part$4,(%out_arg1,%out_arg2); ld.param.u32 %r840,[%value_in]; } .loc 1 2155 0 shl.b32 %r841,%r371,4; cvt.u16.u32 %r842,%r841; cvt.s32.s16 %r376,%r842; $L789: .loc 1 2158 0 ld.u16 %r844,[%frame+336]; and.b16 %r843,%r844,15; cvt.u16.u32 %r846,%r376; or.b16 %r845,%r843,%r846; .loc 1 2159 0 cvt.u16.u32 %r848,%r332; or.b16 %r847,%r845,%r848; cvt.u64.u16 %r849,%r847; shl.b64 %r850,%r849,48; and.b64 %r851,%r399,281474976710655; or.b64 %r399,%r851,%r850; .loc 1 2161 0 ld.u16 %r853,[%frame+338]; shl.b64 %r854,%r853,32; and.b64 %r855,%r399,-281470681743361; or.b64 %r399,%r855,%r854; .loc 1 2162 0 ld.u16 %r857,[%frame+340]; shl.b64 %r858,%r857,16; and.b64 %r859,%r399,-4294901761; or.b64 %r399,%r859,%r858; .loc 1 2163 0 ld.u16 %r861,[%frame+342]; and.b64 %r862,%r399,-65536; or.b64 %r399,%r862,%r861; $L787: .loc 1 3568 0 setp.eq.u32 %r864,%r330,0; @ %r864 bra $L790; .loc 1 3569 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r160; call __nvptx_free,(%out_arg1); } $L790: .loc 1 3241 0 setp.eq.u64 %r866,%r402,0; @ %r866 bra $L791; .loc 1 3567 0 sub.u64 %r867,%r167,%r160; cvt.u32.u64 %r869,%r867; add.u32 %r868,%r341,%r869; .loc 1 3242 0 cvt.s64.s32 %r870,%r868; add.u64 %r871,%r401,%r870; st.u64 [%r402],%r871; $L791: .loc 1 3243 0 mov.b64 %r400,%r399; bra $L891; $L748: .loc 1 3429 0 setp.gt.s32 %r873,%r244,4932; @ %r873 bra $L736; bra $L733; $L782: .loc 1 3781 0 mov.u64 %r399,9221120237041090560; bra $L787; $L892: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r882,16526; sub.u32 %r881,%r882,%r887; cvt.s64.s32 %r883,%r881; .loc 1 3464 0 mov.u32 %r878,64; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r296; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r883; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r878; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; bra $L774; $L770: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r887,[%value_in]; } setp.gt.s32 %r888,%r887,144; @ %r888 bra $L792; bra $L892; $L893: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r897,16526; sub.u32 %r896,%r897,%r902; cvt.s64.s32 %r898,%r896; .loc 1 3464 0 mov.u32 %r893,64; mov.u32 %r891,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r891; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r898; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r893; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; .loc 1 3480 0 mov.u32 %r315,1; add.u64 %r927,%frame,306; add.u64 %r926,%frame,280; bra $L775; $L753: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r902,[%value_in]; } setp.gt.s32 %r903,%r902,144; @ %r903 bra $L792; bra $L893; $L894: .loc 1 3464 0 add.u64 %r925,%frame,200; .loc 1 3463 0 mov.u32 %r912,16526; sub.u32 %r911,%r912,%r917; cvt.s64.s32 %r913,%r911; .loc 1 3464 0 mov.u32 %r908,64; mov.u32 %r906,0; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r240; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r906; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r913; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r908; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r925; call emdnorm,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); } .loc 1 3474 0 ld.u16 %r306,[%frame+334]; bra $L795; $L768: .loc 1 3458 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r920; call (%value_in),enormlz,(%out_arg1); ld.param.u32 %r917,[%value_in]; } setp.gt.s32 %r918,%r917,144; @ %r918 bra $L792; bra $L894; $L891: .loc 1 3244 0 mov.f64 %value,%r400; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } lib_a-llabs.o/ 0 0 0 644 529 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: llabs .visible .func (.param .u64 %value_out) llabs (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/llabs.c" // BEGIN GLOBAL FUNCTION DEF: llabs .visible .func (.param .u64 %value_out) llabs (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r23; mov.u64 %r23,%ar0; .loc 1 65 0 abs.s64 %value,%r23; .loc 1 66 0 st.param.u64 [%value_out],%value; ret; } lib_a-lldiv.o/ 0 0 0 644 1253 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: lldiv .visible .func lldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/stdlib/lldiv.c" // BEGIN GLOBAL FUNCTION DEF: lldiv .visible .func lldiv (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r31; .reg .u64 %r33; .reg .u64 %r34; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u32 %r40; .reg .u16 %r41; .reg .pred %r42; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; mov.u64 %r29,%ar2; .loc 1 107 0 div.s64 %r22,%r28,%r29; .loc 1 108 0 rem.s64 %r23,%r28,%r29; .loc 1 109 0 shr.u64 %r31,%r23,63; not.b64 %r33,%r28; shr.u64 %r34,%r33,63; cvt.u16.u64 %r38,%r31; cvt.u16.u64 %r39,%r34; and.b16 %r37,%r38,%r39; cvt.u32.u16 %r40,%r37; cvt.u16.u8 %r41,%r40; setp.eq.u16 %r42,%r41,0; @ %r42 bra $L2; .loc 1 110 0 add.u64 %r22,%r22,1; .loc 1 111 0 sub.u64 %r23,%r23,%r29; $L2: .loc 1 113 0 st.u64 [%r27],%r22; st.u64 [%r27+8],%r23; .loc 1 114 0 ret; } /102 0 0 0 644 3310 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __messages_load_locale .visible .func (.param .u32 %value_out) __messages_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/locale/lmessages.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_messages_locale .visible .func (.param .u64 %value_out) __get_current_messages_locale; // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN VAR DEF: empty .global .align 1 .u8 empty[1]; // BEGIN VAR DEF: _messages_using_locale .global .align 4 .u32 _messages_using_locale[1]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[12] = {76,67,95,77,69,83,83,65,71,69,83,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {94,91,121,89,93,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[6] = {94,91,110,78,93,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {121,101,115,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[3] = {110,111,0 }; // BEGIN VAR DEF: _C_messages_locale .const .align 8 .u64 _C_messages_locale[4] = {generic($LC1),generic($LC2),generic($LC3),generic($LC4) }; // BEGIN VAR DEF: _messages_locale .global .align 8 .u64 _messages_locale[4]; // BEGIN GLOBAL FUNCTION DEF: __messages_load_locale .visible .func (.param .u32 %value_out) __messages_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r37; mov.u64 %r23,%ar0; .loc 1 91 0 cvta.global.u64 %r26,_messages_locale; cvta.global.u64 %r27,empty; st.u64 [%r26+16],%r27; .loc 1 92 0 st.u64 [%r26+24],%r27; .loc 1 94 0 mov.u32 %r35,2; mov.u32 %r34,4; cvta.const.u64 %r33,$LC0; mov.u64 %r32,0; cvta.global.u64 %r31,_messages_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r33; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r34; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r35; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r26; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r37,[%value_in]; } .loc 1 99 0 mov.u32 %value,%r37; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_messages_locale .visible .func (.param .u64 %value_out) __get_current_messages_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 106 0 ld.global.u32 %r24,[_messages_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L4; cvta.const.u64 %r23,_C_messages_locale; bra $L2; $L4: cvta.global.u64 %r23,_messages_locale; $L2: .loc 1 107 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } /121 0 0 0 644 8417 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __monetary_load_locale .visible .func (.param .u32 %value_out) __monetary_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/locale/lmonetary.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_monetary_locale .visible .func (.param .u64 %value_out) __get_current_monetary_locale; // BEGIN GLOBAL VAR DECL: __mlocale_changed .extern .global .align 4 .u32 __mlocale_changed[1]; // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: __fix_locale_grouping_str .extern .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strtol .extern .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN VAR DEF: empty .global .align 1 .u8 empty[1]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[12] = {76,67,95,77,79,78,69,84,65,82,89,0 }; // BEGIN VAR DEF: numempty .global .align 1 .u8 numempty[2] = {127,0 }; // BEGIN VAR DEF: _C_monetary_locale .const .align 8 .u64 _C_monetary_locale[15] = {generic(empty),generic(empty),generic(empty),generic(empty),generic(numempty),generic(empty),generic(empty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty),generic(numempty) }; // BEGIN VAR DEF: _monetary_locale .global .align 8 .u64 _monetary_locale[15]; // BEGIN VAR DEF: _monetary_using_locale .global .align 4 .u32 _monetary_using_locale[1]; // BEGIN GLOBAL FUNCTION DEF: __monetary_load_locale .visible .func (.param .u32 %value_out) __monetary_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r35; .reg .u64 %r37; .reg .u64 %r39; .reg .u64 %r41; .reg .u64 %r43; .reg .u64 %r45; .reg .u64 %r47; .reg .u64 %r58; .reg .u32 %r61; .reg .u64 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u32 %r67; .reg .u32 %r69; .reg .pred %r70; .reg .u32 %r71; .reg .pred %r72; .reg .u64 %r75; .reg .u64 %r76; .reg .u32 %r81; .reg .u64 %r82; .reg .u32 %r83; .reg .pred %r84; .reg .u64 %r89; .reg .u32 %r90; .reg .pred %r91; .reg .u64 %r96; .reg .u32 %r97; .reg .pred %r98; .reg .u64 %r103; .reg .u32 %r104; .reg .pred %r105; .reg .u64 %r110; .reg .u32 %r111; .reg .pred %r112; .reg .u64 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .u64 %r124; .reg .u32 %r125; .reg .pred %r126; .reg .u64 %r131; .reg .u32 %r132; .reg .pred %r133; .reg .u64 %r135; mov.u64 %r58,%ar0; .loc 1 118 0 mov.u32 %r61,1; st.global.u32 [__mlocale_changed],%r61; .loc 1 119 0 cvta.global.u64 %r135,_monetary_locale; mov.u32 %r67,15; cvta.const.u64 %r65,$LC0; mov.u64 %r64,0; cvta.global.u64 %r63,_monetary_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r58; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r63; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r64; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r65; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r67; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r67; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r135; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r69,[%value_in]; } .loc 1 123 0 setp.ne.u32 %r70,%r69,0; @ %r70 bra $L1; ld.global.u32 %r71,[_monetary_using_locale]; setp.eq.u32 %r72,%r71,0; @ %r72 bra $L1; .loc 1 125 0 ld.u64 %r75,[%r135+32]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r75; call (%value_in),__fix_locale_grouping_str,(%out_arg1); ld.param.u64 %r76,[%value_in]; } .loc 1 124 0 st.u64 [%r135+32],%r76; .loc 1 130 0 ld.u64 %r25,[%r135+56]; .loc 1 85 0 mov.u32 %r81,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r82,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r83,%r82; setp.ne.u32 %r84,%r83,-1; selp.u64 %r47,%r82,127,%r84; .loc 1 130 0 st.u8 [%r25],%r47; .loc 1 131 0 ld.u64 %r26,[%r135+64]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r89,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r90,%r89; setp.ne.u32 %r91,%r90,-1; selp.u64 %r45,%r89,127,%r91; .loc 1 131 0 st.u8 [%r26],%r45; .loc 1 132 0 ld.u64 %r27,[%r135+72]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r96,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r97,%r96; setp.ne.u32 %r98,%r97,-1; selp.u64 %r43,%r96,127,%r98; .loc 1 132 0 st.u8 [%r27],%r43; .loc 1 133 0 ld.u64 %r28,[%r135+80]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r103,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r104,%r103; setp.ne.u32 %r105,%r104,-1; selp.u64 %r41,%r103,127,%r105; .loc 1 133 0 st.u8 [%r28],%r41; .loc 1 134 0 ld.u64 %r29,[%r135+88]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r110,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r111,%r110; setp.ne.u32 %r112,%r111,-1; selp.u64 %r39,%r110,127,%r112; .loc 1 134 0 st.u8 [%r29],%r39; .loc 1 135 0 ld.u64 %r30,[%r135+96]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r30; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r117,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r118,%r117; setp.ne.u32 %r119,%r118,-1; selp.u64 %r37,%r117,127,%r119; .loc 1 135 0 st.u8 [%r30],%r37; .loc 1 136 0 ld.u64 %r31,[%r135+104]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r124,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r125,%r124; setp.ne.u32 %r126,%r125,-1; selp.u64 %r35,%r124,127,%r126; .loc 1 136 0 st.u8 [%r31],%r35; .loc 1 137 0 ld.u64 %r32,[%r135+112]; .loc 1 85 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r32; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r64; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r81; call (%value_in),strtol,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r131,[%value_in]; } .loc 1 86 0 cvt.u32.u64 %r132,%r131; setp.ne.u32 %r133,%r132,-1; selp.u64 %r33,%r131,127,%r133; .loc 1 137 0 st.u8 [%r32],%r33; $L1: .loc 1 141 0 mov.u32 %value,%r69; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_monetary_locale .visible .func (.param .u64 %value_out) __get_current_monetary_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 148 0 ld.global.u32 %r24,[_monetary_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L16; cvta.const.u64 %r23,_C_monetary_locale; bra $L14; $L16: cvta.global.u64 %r23,_monetary_locale; $L14: .loc 1 149 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } /140 0 0 0 644 3767 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: __numeric_load_locale .visible .func (.param .u32 %value_out) __numeric_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/locale/lnumeric.c" // BEGIN GLOBAL FUNCTION DECL: __get_current_numeric_locale .visible .func (.param .u64 %value_out) __get_current_numeric_locale; // BEGIN GLOBAL VAR DECL: __nlocale_changed .extern .global .align 4 .u32 __nlocale_changed[1]; // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: __fix_locale_grouping_str .extern .func (.param .u64 %value_out) __fix_locale_grouping_str (.param .u64 %in_ar0); // BEGIN VAR DEF: _numeric_locale .global .align 8 .u64 _numeric_locale[3]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[11] = {76,67,95,78,85,77,69,82,73,67,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[2] = {46,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[1] = {0 }; // BEGIN VAR DEF: _numeric_using_locale .global .align 4 .u32 _numeric_using_locale[1]; // BEGIN VAR DEF: numempty .global .align 1 .u8 numempty[2] = {127,0 }; // BEGIN VAR DEF: _C_numeric_locale .const .align 8 .u64 _C_numeric_locale[3] = {generic($LC1),generic($LC2),generic(numempty) }; // BEGIN GLOBAL FUNCTION DEF: __numeric_load_locale .visible .func (.param .u32 %value_out) __numeric_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r26; .reg .u32 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u64 %r43; .reg .u64 %r44; mov.u64 %r26,%ar0; .loc 1 78 0 mov.u32 %r29,1; st.global.u32 [__nlocale_changed],%r29; .loc 1 79 0 cvta.global.u64 %r36,_numeric_locale; mov.u32 %r35,3; cvta.const.u64 %r33,$LC0; mov.u64 %r32,0; cvta.global.u64 %r31,_numeric_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r33; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r35; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r35; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r36; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r37,[%value_in]; } .loc 1 83 0 setp.ne.u32 %r38,%r37,0; @ %r38 bra $L1; ld.global.u32 %r39,[_numeric_using_locale]; setp.eq.u32 %r40,%r39,0; @ %r40 bra $L1; .loc 1 85 0 ld.u64 %r43,[%r36+16]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r43; call (%value_in),__fix_locale_grouping_str,(%out_arg1); ld.param.u64 %r44,[%value_in]; } .loc 1 84 0 st.u64 [%r36+16],%r44; $L1: .loc 1 88 0 mov.u32 %value,%r37; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __get_current_numeric_locale .visible .func (.param .u64 %value_out) __get_current_numeric_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 95 0 ld.global.u32 %r24,[_numeric_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L8; cvta.const.u64 %r23,_C_numeric_locale; bra $L6; $L8: cvta.global.u64 %r23,_numeric_locale; $L6: .loc 1 96 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-locale.o/ 0 0 0 644 6146 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _setlocale_r .visible .func (.param .u64 %value_out) _setlocale_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/locale/locale.c" // BEGIN GLOBAL FUNCTION DECL: __locale_charset .visible .func (.param .u64 %value_out) __locale_charset; // BEGIN GLOBAL FUNCTION DECL: __locale_mb_cur_max .visible .func (.param .u32 %value_out) __locale_mb_cur_max; // BEGIN GLOBAL FUNCTION DECL: __locale_msgcharset .visible .func (.param .u64 %value_out) __locale_msgcharset; // BEGIN GLOBAL FUNCTION DECL: __locale_cjk_lang .visible .func (.param .u32 %value_out) __locale_cjk_lang; // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .visible .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: setlocale .visible .func (.param .u64 %value_out) setlocale (.param .u32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: localeconv .visible .func (.param .u64 %value_out) localeconv; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[2] = {67,0 }; // BEGIN GLOBAL VAR DEF: _PathLocale .visible .global .align 8 .u64 _PathLocale[1]; // BEGIN GLOBAL VAR DEF: __mb_cur_max .visible .global .align 4 .u32 __mb_cur_max[1] = {1 }; // BEGIN VAR DEF: lc_ctype_charset .global .align 1 .u8 lc_ctype_charset[32] = {65,83,67,73,73,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[2] = {46,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[1] = {0 }; // BEGIN VAR DEF: lconv .global .align 8 .u64 lconv[12] = {generic($LC3),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),generic($LC2),9187201950435737471,140185576636287 }; // BEGIN GLOBAL VAR DEF: __nlocale_changed .visible .global .align 4 .u32 __nlocale_changed[1]; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {80,79,83,73,88,0 }; // BEGIN VAR DEF: lc_message_charset .global .align 1 .u8 lc_message_charset[32] = {65,83,67,73,73,0 }; // BEGIN GLOBAL VAR DEF: __mlocale_changed .visible .global .align 4 .u32 __mlocale_changed[1]; // BEGIN GLOBAL FUNCTION DEF: _setlocale_r .visible .func (.param .u64 %value_out) _setlocale_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r25; .reg .u64 %r28; .reg .pred %r29; .reg .u64 %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u32 %r36; .reg .pred %r37; .reg .u64 %r39; .reg .u32 %r40; .reg .pred %r41; .reg .u64 %r43; mov.u64 %r28,%ar2; .loc 1 282 0 setp.eq.u64 %r29,%r28,0; @ %r29 bra $L2; .loc 1 284 0 cvta.const.u64 %r31,$LC1; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r32,[%value_in]; } setp.eq.u32 %r33,%r32,0; @ %r33 bra $L2; cvta.const.u64 %r43,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r36,[%value_in]; } setp.eq.u32 %r37,%r36,0; @ %r37 bra $L2; .loc 1 285 0 cvta.const.u64 %r39,$LC2; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r39; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r40,[%value_in]; } setp.ne.u32 %r41,%r40,0; @ %r41 bra $L4; $L2: .loc 1 288 0 cvta.const.u64 %r25,$LC0; bra $L1; $L4: .loc 1 286 0 mov.u64 %r25,0; $L1: .loc 1 417 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_charset .visible .func (.param .u64 %value_out) __locale_charset { .reg .u64 %value; .loc 1 940 0 cvta.global.u64 %value,lc_ctype_charset; .loc 1 942 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_mb_cur_max .visible .func (.param .u32 %value_out) __locale_mb_cur_max { .reg .u32 %value; .loc 1 950 0 ld.global.u32 %value,[__mb_cur_max]; .loc 1 952 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_msgcharset .visible .func (.param .u64 %value_out) __locale_msgcharset { .reg .u64 %value; .loc 1 961 0 cvta.global.u64 %value,lc_message_charset; .loc 1 963 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __locale_cjk_lang .visible .func (.param .u32 %value_out) __locale_cjk_lang { .reg .u32 %value; .loc 1 968 0 mov.u32 %value,0; .loc 1 969 0 st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _localeconv_r .visible .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 1020 0 cvta.global.u64 %value,lconv; .loc 1 1021 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: setlocale .visible .func (.param .u64 %value_out) setlocale (.param .u32 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r29; .reg .u64 %r30; mov.u32 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 1033 0 ld.global.u64 %r29,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),_setlocale_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r30,[%value_in]; } .loc 1 1034 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: localeconv .visible .func (.param .u64 %value_out) localeconv { .reg .u64 %value; .loc 1 1040 0 cvta.global.u64 %value,lconv; .loc 1 1041 0 st.param.u64 [%value_out],%value; ret; } lib_a-lrand48.o/0 0 0 644 2016 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _lrand48_r .visible .func (.param .u64 %value_out) _lrand48_r (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/lrand48.c" // BEGIN GLOBAL FUNCTION DECL: lrand48 .visible .func (.param .u64 %value_out) lrand48; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _lrand48_r .visible .func (.param .u64 %value_out) _lrand48_r (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r31; .reg .u64 %r34; .reg .u64 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u16 %r41; mov.u64 %r31,%ar0; .loc 1 21 0 add.u64 %r34,%r31,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r36,[%r31+244]; shl.b64 %r37,%r36,15; .loc 1 23 0 ld.u16 %r38,[%r31+242]; shr.u32 %r39,%r38,1; cvt.u16.u32 %r41,%r39; cvt.u64.u16 %r40,%r41; .loc 1 22 0 add.u64 %value,%r37,%r40; .loc 1 24 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: lrand48 .visible .func (.param .u64 %value_out) lrand48 { .reg .u64 %value; .reg .u64 %r22; .reg .u64 %r34; .reg .u64 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u16 %r41; .loc 1 30 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 21 0 add.u64 %r34,%r22,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r22; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r36,[%r22+244]; shl.b64 %r37,%r36,15; .loc 1 23 0 ld.u16 %r38,[%r22+242]; shr.u32 %r39,%r38,1; cvt.u16.u32 %r41,%r39; cvt.u64.u16 %r40,%r41; .loc 1 22 0 add.u64 %value,%r37,%r40; .loc 1 31 0 st.param.u64 [%value_out],%value; ret; } lib_a-malloc.o/ 0 0 0 644 1603 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .visible .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); .file 1 "../../../../../../../newlib/libc/machine/nvptx/malloc.c" // BEGIN GLOBAL FUNCTION DECL: malloc .extern .func (.param .u64 %value_out) malloc (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_uni .extern .shared .u32 __nvptx_uni[32]; // BEGIN GLOBAL FUNCTION DEF: __nvptx_malloc .visible .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r27; .reg .u64 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; .reg .pred %r34; .reg .u64 %r35; { .reg .u32 %ustmp0; .reg .u64 %ustmp1; mov.u32 %ustmp0,%tid.y; mul.wide.u32 %ustmp1,%ustmp0,4; mov.u64 %r35,__nvptx_uni; add.u64 %r35,%r35,%ustmp1; ld.shared.u32 %r31,[%r35]; mov.u32 %ustmp0,%laneid; and.b32 %r31,%r31,%ustmp0; setp.eq.u32 %r34,%r31,%ustmp0; } mov.u64 %r25,%ar0; .loc 1 33 0 add.u64 %r27,%r25,8; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; @ %r34 call (%value_in),malloc,(%out_arg1); ld.param.u64 %r28,[%value_in]; } mov.b64 {%r32,%r33},%r28; shfl.idx.b32 %r32,%r32,%r31,31; shfl.idx.b32 %r33,%r33,%r31,31; mov.b64 %r28,{%r32,%r33}; .loc 1 34 0 setp.eq.u64 %r29,%r28,0; @ %r29 bra $L3; .loc 1 35 0 add.u64 %r24,%r28,8; st.u64 [%r28],%r25; bra $L1; $L3: mov.u64 %r24,%r28; $L1: .loc 1 38 0 mov.u64 %value,%r24; st.param.u64 [%value_out],%value; ret; } lib_a-mallocr.o/0 0 0 644 1491 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _malloc_r .visible .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../../newlib/libc/machine/nvptx/mallocr.c" // BEGIN GLOBAL FUNCTION DECL: _free_r .visible .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: _malloc_r .visible .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r26; mov.u64 %r24,%ar1; .loc 1 20 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r26,[%value_in]; } .loc 1 21 0 mov.u64 %value,%r26; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _free_r .visible .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; mov.u64 %r23,%ar1; .loc 1 25 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; call __nvptx_free,(%out_arg1); } .loc 1 26 0 ret; } lib_a-memccpy.o/0 0 0 644 2745 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memccpy .visible .func (.param .u64 %value_out) memccpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/string/memccpy.c" // BEGIN GLOBAL FUNCTION DEF: memccpy .visible .func (.param .u64 %value_out) memccpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r81; .reg .u64 %r82; .reg .u32 %r87; .reg .u32 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u32 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .pred %r110; .reg .pred %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u16 %r120; .reg .pred %r122; .reg .pred %r123; .reg .u16 %r125; mov.u64 %r103,%ar0; mov.u64 %r104,%ar1; mov.u32 %r105,%ar2; mov.u64 %r106,%ar3; .loc 1 95 0 cvt.u32.u32 %r107,%r105; cvt.s32.s8 %r88,%r107; .loc 1 99 0 setp.le.u64 %r108,%r106,7; @ %r108 bra $L2; mov.u64 %r93,%r103; or.b64 %r109,%r104,%r93; and.b64 %r91,%r109,7; setp.ne.u64 %r110,%r91,0; @ %r110 bra $L2; cvt.s64.s8 %r101,%r107; mov.u32 %r100,8; $L3: .loc 1 114 0 shl.b64 %r81,%r91,8; add.u64 %r91,%r81,%r101; add.u32 %r100,%r100,-1; .loc 1 113 0 setp.ne.u32 %r112,%r100,0; @ %r112 bra $L3; $L4: mov.u64 %r98,%r93; .loc 1 120 0 ld.u64 %r82,[%r104]; .loc 1 121 0 xor.b64 %r90,%r82,%r91; .loc 1 122 0 add.u64 %r113,%r90,-72340172838076673; not.b64 %r114,%r90; and.b64 %r115,%r113,%r114; and.b64 %r116,%r115,-9187201950435737472; setp.ne.u64 %r117,%r116,0; @ %r117 bra $L8; .loc 1 124 0 add.u64 %r104,%r104,8; add.u64 %r93,%r93,8; mov.u64 %r103,%r93; st.u64 [%r98],%r82; .loc 1 125 0 add.u64 %r106,%r106,-8; .loc 1 118 0 setp.gt.u64 %r118,%r106,7; @ %r118 bra $L4; bra $L2; $L7: add.u64 %r102,%r92,1; .loc 1 135 0 ld.s8 %r87,[%r99]; cvt.u32.u32 %r119,%r87; st.u8 [%r92],%r119; add.u64 %r99,%r99,1; mov.u64 %r92,%r102; cvt.u16.u32 %r120,%r87; setp.eq.u16 %r122,%r120,%r125; @ ! %r122 bra $L6; bra $L1; $L8: mov.u64 %r103,%r93; $L2: mov.u64 %r92,%r103; mov.u64 %r99,%r104; add.u64 %r97,%r92,%r106; cvt.u16.u32 %r125,%r88; $L6: .loc 1 133 0 setp.ne.u64 %r123,%r97,%r92; @ %r123 bra $L7; .loc 1 90 0 mov.u64 %r102,0; $L1: .loc 1 144 0 mov.u64 %value,%r102; st.param.u64 [%value_out],%value; ret; } lib_a-memchr.o/ 0 0 0 644 3631 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memchr .visible .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/memchr.c" // BEGIN GLOBAL FUNCTION DEF: memchr .visible .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r81; .reg .u64 %r83; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r92; .reg .u32 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r98; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u64 %r105; .reg .u32 %r106; .reg .u64 %r107; .reg .pred %r108; .reg .pred %r109; .reg .u16 %r110; .reg .u16 %r111; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r114; .reg .pred %r116; .reg .u64 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .pred %r131; .reg .u16 %r132; .reg .u16 %r133; .reg .pred %r134; .reg .u16 %r135; .reg .pred %r137; .reg .pred %r138; .reg .u16 %r140; .reg .u16 %r141; mov.u64 %r103,%ar0; mov.u32 %r104,%ar1; mov.u64 %r105,%ar2; .loc 1 78 0 cvt.u32.u32 %r106,%r104; cvt.u32.u8 %r94,%r106; .loc 1 85 0 and.b64 %r107,%r103,7; setp.eq.u64 %r108,%r107,0; @ %r108 bra $L11; .loc 1 87 0 add.u64 %r98,%r105,-1; setp.eq.u64 %r109,%r105,0; @ %r109 bra $L12; .loc 1 89 0 ld.u8 %r110,[%r103]; cvt.u16.u32 %r111,%r94; setp.eq.u16 %r112,%r110,%r111; @ %r112 bra $L13; cvt.u16.u32 %r141,%r94; bra $L4; $L5: .loc 1 87 0 add.u64 %r98,%r98,-1; setp.eq.u64 %r113,%r98,-1; @ %r113 bra $L14; .loc 1 89 0 ld.u8 %r114,[%r103]; setp.eq.u16 %r116,%r114,%r141; @ %r116 bra $L15; $L4: .loc 1 91 0 add.u64 %r103,%r103,1; .loc 1 85 0 and.b64 %r117,%r103,7; setp.ne.u64 %r118,%r117,0; @ %r118 bra $L5; bra $L2; $L11: mov.u64 %r98,%r105; $L2: .loc 1 94 0 setp.le.u64 %r119,%r98,7; @ %r119 bra $L6; .loc 1 105 0 shl.b32 %r120,%r104,8; and.b32 %r121,%r120,65535; and.b32 %r122,%r104,255; or.b32 %r123,%r121,%r122; cvt.s64.s32 %r95,%r123; .loc 1 106 0 shl.b64 %r81,%r95,16; or.b64 %r96,%r81,%r95; .loc 1 108 0 shl.b64 %r90,%r96,32; or.b64 %r89,%r90,%r96; $L8: .loc 1 112 0 ld.u64 %r124,[%r103]; xor.b64 %r83,%r89,%r124; add.u64 %r125,%r83,-72340172838076673; not.b64 %r126,%r83; and.b64 %r127,%r125,%r126; and.b64 %r128,%r127,-9187201950435737472; setp.ne.u64 %r129,%r128,0; @ %r129 bra $L7; .loc 1 114 0 add.u64 %r98,%r98,-8; .loc 1 115 0 add.u64 %r103,%r103,8; .loc 1 110 0 setp.gt.u64 %r130,%r98,7; @ %r130 bra $L8; $L6: .loc 1 126 0 setp.eq.u64 %r131,%r98,0; @ %r131 bra $L16; $L7: .loc 1 128 0 ld.u8 %r132,[%r103]; cvt.u16.u32 %r133,%r94; setp.eq.u16 %r134,%r132,%r133; @ %r134 bra $L17; add.u64 %r92,%r103,%r98; cvt.u16.u32 %r140,%r94; bra $L9; $L10: ld.u8 %r135,[%r103]; setp.eq.u16 %r137,%r135,%r140; @ %r137 bra $L18; $L9: .loc 1 130 0 add.u64 %r103,%r103,1; .loc 1 126 0 setp.ne.u64 %r138,%r92,%r103; @ %r138 bra $L10; .loc 1 88 0 mov.u64 %r102,0; bra $L1; $L12: mov.u64 %r102,%r105; bra $L1; $L13: .loc 1 89 0 mov.u64 %r102,%r103; bra $L1; $L14: .loc 1 88 0 mov.u64 %r102,0; bra $L1; $L15: .loc 1 91 0 mov.u64 %r102,%r103; bra $L1; $L16: .loc 1 88 0 mov.u64 %r102,%r98; bra $L1; $L17: .loc 1 128 0 mov.u64 %r102,%r103; bra $L1; $L18: .loc 1 130 0 mov.u64 %r102,%r103; $L1: .loc 1 134 0 mov.u64 %value,%r102; st.param.u64 [%value_out],%value; ret; } lib_a-memcmp.o/ 0 0 0 644 2176 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memcmp .visible .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/memcmp.c" // BEGIN GLOBAL FUNCTION DEF: memcmp .visible .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r82; .reg .u32 %r83; .reg .u64 %r86; .reg .u32 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .pred %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .pred %r94; .reg .pred %r95; .reg .u16 %r96; .reg .u16 %r97; .reg .pred %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .pred %r101; .reg .pred %r102; .reg .u16 %r103; .reg .u16 %r104; .reg .pred %r105; .reg .pred %r106; mov.u64 %r88,%ar0; mov.u64 %r89,%ar1; mov.u64 %r90,%ar2; .loc 1 81 0 setp.le.u64 %r91,%r90,7; @ %r91 bra $L2; or.b64 %r92,%r88,%r89; and.b64 %r93,%r92,7; setp.eq.u64 %r94,%r93,0; @ %r94 bra $L3; bra $L10; $L2: .loc 1 102 0 setp.eq.u64 %r95,%r90,0; @ %r95 bra $L11; $L10: .loc 1 104 0 ld.u8 %r82,[%r88]; ld.u8 %r83,[%r89]; cvt.u16.u32 %r96,%r82; cvt.u16.u32 %r97,%r83; setp.ne.u16 %r98,%r96,%r97; @ ! %r98 bra $L16; bra $L6; $L3: .loc 1 89 0 ld.u64 %r99,[%r88]; ld.u64 %r100,[%r89]; setp.ne.u64 %r101,%r99,%r100; @ %r101 bra $L10; .loc 1 91 0 add.u64 %r88,%r88,8; .loc 1 92 0 add.u64 %r89,%r89,8; .loc 1 93 0 add.u64 %r90,%r90,-8; .loc 1 87 0 setp.gt.u64 %r102,%r90,7; @ %r102 bra $L3; bra $L2; $L9: .loc 1 104 0 ld.u8 %r82,[%r88]; ld.u8 %r83,[%r89]; cvt.u16.u32 %r103,%r82; cvt.u16.u32 %r104,%r83; setp.eq.u16 %r105,%r103,%r104; @ %r105 bra $L8; $L6: .loc 1 105 0 sub.u32 %r87,%r82,%r83; bra $L1; $L16: add.u64 %r86,%r88,%r90; $L8: .loc 1 106 0 add.u64 %r88,%r88,1; .loc 1 107 0 add.u64 %r89,%r89,1; .loc 1 102 0 setp.ne.u64 %r106,%r88,%r86; @ %r106 bra $L9; .loc 1 110 0 mov.u32 %r87,0; bra $L1; $L11: cvt.u32.u64 %r87,%r90; $L1: .loc 1 112 0 mov.u32 %value,%r87; st.param.u32 [%value_out],%value; ret; } lib_a-memcpy.o/ 0 0 0 644 2975 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memcpy .visible .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/memcpy.c" // BEGIN GLOBAL FUNCTION DEF: memcpy .visible .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r103; .reg .u64 %r105; .reg .u64 %r109; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .pred %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .pred %r121; .reg .pred %r122; .reg .u64 %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .pred %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .pred %r136; .reg .u64 %r137; .reg .u32 %r138; .reg .pred %r139; mov.u64 %r115,%ar0; mov.u64 %r116,%ar1; mov.u64 %r117,%ar2; .loc 1 79 0 setp.le.u64 %r118,%r117,31; @ %r118 bra $L9; or.b64 %r119,%r116,%r115; and.b64 %r120,%r119,7; setp.eq.u64 %r121,%r120,0; @ %r121 bra $L3; .loc 1 72 0 mov.u64 %r89,%r115; bra $L4; $L9: mov.u64 %r89,%r115; bra $L2; $L10: .loc 1 95 0 mov.u64 %r117,%r86; $L2: .loc 1 106 0 setp.ne.u64 %r122,%r117,0; @ %r122 bra $L4; bra $L5; $L3: add.u64 %r123,%r117,-32; and.b64 %r125,%r123,-32; add.u64 %r109,%r125,32; add.u64 %r89,%r115,%r109; .loc 1 82 0 mov.u64 %r90,%r116; .loc 1 81 0 mov.u64 %r93,%r115; $L6: .loc 1 87 0 ld.u64 %r126,[%r90]; st.u64 [%r93],%r126; .loc 1 88 0 ld.u64 %r127,[%r90+8]; st.u64 [%r93+8],%r127; .loc 1 89 0 ld.u64 %r128,[%r90+16]; st.u64 [%r93+16],%r128; add.u64 %r90,%r90,32; add.u64 %r93,%r93,32; .loc 1 90 0 ld.u64 %r129,[%r90+-8]; st.u64 [%r93+-8],%r129; .loc 1 85 0 setp.ne.u64 %r130,%r89,%r93; @ %r130 bra $L6; add.u64 %r116,%r116,%r109; and.b64 %r86,%r117,31; .loc 1 95 0 setp.le.u64 %r131,%r86,7; @ %r131 bra $L10; mov.u64 %r98,%r116; mov.u64 %r99,%r89; add.u64 %r132,%r86,-8; shr.u64 %r103,%r132,3; shl.b64 %r133,%r103,3; add.u64 %r134,%r133,8; add.u64 %r105,%r134,%r116; $L7: .loc 1 97 0 ld.u64 %r135,[%r98]; st.u64 [%r99],%r135; add.u64 %r98,%r98,8; add.u64 %r99,%r99,8; .loc 1 95 0 setp.ne.u64 %r136,%r98,%r105; @ %r136 bra $L7; and.b64 %r117,%r117,7; add.u64 %r137,%r103,1; shl.b64 %r87,%r137,3; add.u64 %r89,%r89,%r87; add.u64 %r116,%r116,%r87; bra $L2; $L4: mov.u64 %r91,%r89; mov.u64 %r94,%r116; add.u64 %r97,%r91,%r117; $L8: .loc 1 107 0 ld.u8 %r138,[%r94]; st.u8 [%r91],%r138; add.u64 %r91,%r91,1; add.u64 %r94,%r94,1; .loc 1 106 0 setp.ne.u64 %r139,%r91,%r97; @ %r139 bra $L8; $L5: .loc 1 111 0 mov.u64 %value,%r115; st.param.u64 [%value_out],%value; ret; } lib_a-memmem.o/ 0 0 0 644 23114 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/str-two-way.h" // BEGIN FUNCTION DECL: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: memmem .visible .func (.param .u64 %value_out) memmem (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 2 "../../../../../../newlib/libc/string/memmem.c" // BEGIN GLOBAL FUNCTION DECL: memcmp .extern .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN FUNCTION DEF: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .pred %r54; .reg .pred %r57; .reg .pred %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .u16 %r63; .reg .u16 %r64; .reg .pred %r65; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .u64 %r73; .reg .u64 %r74; mov.u64 %r46,%ar0; mov.u64 %r47,%ar1; mov.u64 %r48,%ar2; .loc 1 113 0 mov.u64 %r37,1; mov.u64 %r35,%r37; .loc 1 112 0 mov.u64 %r28,0; .loc 1 111 0 mov.u64 %r32,-1; .loc 1 140 0 mov.u64 %r74,%r37; .loc 1 114 0 bra $L2; $L7: .loc 1 116 0 add.u64 %r49,%r46,%r27; .loc 1 117 0 add.u64 %r50,%r46,%r32; add.u64 %r51,%r50,%r35; .loc 1 118 0 ld.u8 %r52,[%r49]; ld.u8 %r53,[%r51]; setp.ge.u16 %r54,%r52,%r53; @ %r54 bra $L3; .loc 1 123 0 sub.u64 %r37,%r27,%r32; mov.u64 %r28,%r27; .loc 1 122 0 mov.u64 %r35,1; bra $L2; $L3: .loc 1 125 0 setp.ne.u16 %r57,%r52,%r53; @ %r57 bra $L5; .loc 1 128 0 setp.eq.u64 %r58,%r35,%r37; @ %r58 bra $L6; .loc 1 129 0 add.u64 %r35,%r35,1; bra $L2; $L6: .loc 1 132 0 mov.u64 %r28,%r27; .loc 1 133 0 mov.u64 %r35,1; bra $L2; $L5: .loc 1 139 0 mov.u64 %r32,%r28; add.u64 %r28,%r28,1; .loc 1 140 0 mov.u64 %r37,%r74; mov.u64 %r35,1; $L2: .loc 1 114 0 add.u64 %r27,%r28,%r35; setp.lt.u64 %r59,%r27,%r47; @ %r59 bra $L7; .loc 1 143 0 st.u64 [%r48],%r37; .loc 1 148 0 mov.u64 %r38,1; mov.u64 %r36,%r38; .loc 1 147 0 mov.u64 %r22,0; .loc 1 146 0 mov.u64 %r26,-1; .loc 1 175 0 mov.u64 %r73,%r38; .loc 1 149 0 bra $L8; $L13: .loc 1 151 0 add.u64 %r60,%r46,%r33; .loc 1 152 0 add.u64 %r61,%r46,%r26; add.u64 %r62,%r61,%r36; .loc 1 153 0 ld.u8 %r63,[%r60]; ld.u8 %r64,[%r62]; setp.le.u16 %r65,%r63,%r64; @ %r65 bra $L9; .loc 1 158 0 sub.u64 %r38,%r33,%r26; mov.u64 %r22,%r33; .loc 1 157 0 mov.u64 %r36,1; bra $L8; $L9: .loc 1 160 0 setp.ne.u16 %r68,%r63,%r64; @ %r68 bra $L11; .loc 1 163 0 setp.eq.u64 %r69,%r36,%r38; @ %r69 bra $L12; .loc 1 164 0 add.u64 %r36,%r36,1; bra $L8; $L12: .loc 1 167 0 mov.u64 %r22,%r33; .loc 1 168 0 mov.u64 %r36,1; bra $L8; $L11: .loc 1 174 0 mov.u64 %r26,%r22; add.u64 %r22,%r22,1; .loc 1 175 0 mov.u64 %r38,%r73; mov.u64 %r36,1; $L8: .loc 1 149 0 add.u64 %r33,%r22,%r36; setp.lt.u64 %r70,%r33,%r47; @ %r70 bra $L13; .loc 1 181 0 add.u64 %r34,%r26,1; add.u64 %r45,%r32,1; setp.lt.u64 %r71,%r34,%r45; @ %r71 bra $L1; .loc 1 183 0 st.u64 [%r48],%r38; .loc 1 184 0 mov.u64 %r45,%r34; $L1: .loc 1 185 0 mov.u64 %value,%r45; st.param.u64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,2056; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r100; .reg .u32 %r105; .reg .u32 %r106; .reg .u64 %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .u64 %r110; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r124; .reg .u64 %r126; .reg .u64 %r128; .reg .u64 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r153; .reg .u64 %r154; .reg .u64 %r159; .reg .u64 %r162; .reg .u64 %r169; .reg .u64 %r172; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r180; .reg .u64 %r183; .reg .u64 %r184; .reg .u64 %r185; .reg .u64 %r186; .reg .u64 %r187; .reg .u64 %r191; .reg .u64 %r192; .reg .pred %r193; .reg .pred %r194; .reg .u64 %r196; .reg .u64 %r197; .reg .u64 %r198; .reg .pred %r199; .reg .u64 %r203; .reg .u64 %r204; .reg .u32 %r205; .reg .pred %r206; .reg .u64 %r208; .reg .u64 %r210; .reg .u64 %r211; .reg .u64 %r212; .reg .pred %r213; .reg .pred %r214; .reg .pred %r215; .reg .pred %r216; .reg .u64 %r218; .reg .u64 %r219; .reg .u16 %r220; .reg .u16 %r221; .reg .pred %r222; .reg .u64 %r224; .reg .u64 %r225; .reg .pred %r226; .reg .u16 %r227; .reg .u16 %r228; .reg .pred %r229; .reg .pred %r230; .reg .u64 %r232; .reg .u16 %r234; .reg .u16 %r235; .reg .pred %r236; .reg .u64 %r237; .reg .pred %r238; .reg .u16 %r239; .reg .u16 %r240; .reg .pred %r241; .reg .u64 %r242; .reg .pred %r243; .reg .pred %r245; .reg .u64 %r246; .reg .u64 %r247; .reg .u64 %r249; .reg .u64 %r251; .reg .u64 %r252; .reg .u64 %r253; .reg .pred %r254; .reg .pred %r255; .reg .u64 %r256; .reg .u64 %r258; .reg .u16 %r259; .reg .u16 %r260; .reg .pred %r261; .reg .u64 %r262; .reg .pred %r263; .reg .u16 %r264; .reg .u16 %r265; .reg .pred %r266; .reg .u64 %r268; .reg .u64 %r270; .reg .u16 %r271; .reg .u16 %r272; .reg .pred %r273; .reg .u64 %r274; .reg .pred %r275; .reg .u16 %r276; .reg .u16 %r277; .reg .pred %r278; .reg .u64 %r279; .reg .pred %r280; .reg .u64 %r286; .reg .u64 %r287; .reg .u64 %r288; .reg .u64 %r289; .reg .u64 %r290; .reg .u64 %r291; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u64 %r295; .reg .u64 %r296; .reg .pred %r297; .reg .u64 %r298; .reg .u64 %r299; .reg .u64 %r300; .reg .u64 %r301; .reg .u64 %r302; mov.u64 %r184,%ar0; mov.u64 %r185,%ar1; mov.u64 %r186,%ar2; mov.u64 %r187,%ar3; .loc 1 304 0 add.u64 %r191,%frame,2048; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r186; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r187; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r191; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r192,[%value_in]; } mov.u64 %r180,%frame; $L16: .loc 1 311 0 st.u64 [%r180],%r187; add.u64 %r180,%r180,8; .loc 1 310 0 setp.ne.u64 %r193,%r191,%r180; @ %r193 bra $L16; add.u64 %r154,%r187,-1; .loc 1 312 0 setp.eq.u64 %r194,%r187,0; @ %r194 bra $L17; mov.u64 %r177,%r186; mov.u64 %r178,%r154; $L18: .loc 1 313 0 ld.u8 %r196,[%r177]; shl.b64 %r197,%r196,3; add.u64 %r198,%frame,%r197; st.u64 [%r198],%r178; add.u64 %r177,%r177,1; add.u64 %r178,%r178,-1; .loc 1 312 0 setp.ne.u64 %r199,%r178,-1; @ %r199 bra $L18; $L17: .loc 1 317 0 ld.u64 %r204,[%frame+2048]; add.u64 %r203,%r186,%r204; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r186; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r203; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r192; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r205,[%value_in]; } setp.ne.u32 %r206,%r205,0; @ %r206 bra $L19; .loc 1 360 0 ld.u64 %r95,[%frame+2048]; .loc 1 361 0 sub.u64 %r133,%r187,%r95; .loc 1 322 0 mov.u64 %r110,0; .loc 1 324 0 mov.u64 %r124,%r110; .loc 1 352 0 add.u64 %r289,%r192,-1; .loc 1 353 0 add.u64 %r290,%r186,%r289; add.u64 %r291,%r192,-2; mov.u64 %r292,1; sub.u64 %r293,%r292,%r192; .loc 1 339 0 mov.u64 %r294,%r110; .loc 1 325 0 sub.u64 %r295,%r185,%r187; $L30: .loc 1 329 0 add.u64 %r286,%r184,%r124; add.u64 %r208,%r286,%r154; ld.u8 %r210,[%r208]; shl.b64 %r211,%r210,3; add.u64 %r212,%frame,%r211; ld.u64 %r118,[%r212]; .loc 1 330 0 setp.eq.u64 %r213,%r118,0; @ %r213 bra $L20; .loc 1 332 0 setp.eq.u64 %r214,%r110,0; @ %r214 bra $L21; setp.le.u64 %r215,%r95,%r118; .loc 1 337 0 selp.u64 %r118,%r118,%r133,%r215; $L21: .loc 1 340 0 add.u64 %r124,%r124,%r118; .loc 1 339 0 mov.u64 %r110,%r294; .loc 1 341 0 bra $L22; $L20: .loc 1 345 0 max.u64 %r131,%r192,%r110; .loc 1 346 0 setp.ge.u64 %r216,%r131,%r154; @ %r216 bra $L23; .loc 1 347 0 add.u64 %r218,%r286,%r131; .loc 1 346 0 add.u64 %r219,%r186,%r131; ld.u8 %r220,[%r218]; ld.u8 %r221,[%r219]; setp.ne.u16 %r222,%r220,%r221; @ %r222 bra $L24; add.u64 %r287,%r131,1; add.u64 %r117,%r186,%r287; add.u64 %r224,%r124,1; add.u64 %r225,%r224,%r131; add.u64 %r130,%r184,%r225; $L25: .loc 1 348 0 mov.u64 %r131,%r287; .loc 1 346 0 setp.ge.u64 %r226,%r287,%r154; @ %r226 bra $L23; ld.u8 %r89,[%r117]; .loc 1 347 0 ld.u8 %r90,[%r130]; add.u64 %r117,%r117,1; add.u64 %r130,%r130,1; .loc 1 346 0 cvt.u16.u32 %r227,%r89; cvt.u16.u32 %r228,%r90; setp.eq.u16 %r229,%r227,%r228; @ ! %r229 bra $L24; add.u64 %r287,%r287,1; bra $L25; $L23: .loc 1 352 0 mov.u64 %r136,%r289; .loc 1 353 0 setp.le.u64 %r230,%r192,%r110; @ %r230 bra $L41; .loc 1 354 0 add.u64 %r232,%r286,%r289; .loc 1 353 0 ld.u8 %r234,[%r232]; ld.u8 %r235,[%r290]; setp.ne.u16 %r236,%r234,%r235; @ %r236 bra $L42; add.u64 %r96,%r186,%r291; add.u64 %r237,%r291,%r124; add.u64 %r153,%r184,%r237; add.u64 %r137,%r110,-1; bra $L27; $L43: mov.u64 %r136,%r132; $L27: .loc 1 355 0 add.u64 %r132,%r136,-1; .loc 1 353 0 setp.eq.u64 %r238,%r132,%r137; @ %r238 bra $L26; ld.u8 %r91,[%r96]; .loc 1 354 0 ld.u8 %r92,[%r153]; add.u64 %r96,%r96,-1; add.u64 %r153,%r153,-1; .loc 1 353 0 cvt.u16.u32 %r239,%r91; cvt.u16.u32 %r240,%r92; setp.eq.u16 %r241,%r239,%r240; @ %r241 bra $L43; bra $L26; $L41: mov.u64 %r136,%r192; bra $L26; $L42: mov.u64 %r136,%r192; $L26: .loc 1 356 0 add.u64 %r242,%r110,1; setp.le.u64 %r243,%r242,%r136; @ %r243 bra $L28; .loc 1 357 0 mov.u64 %r183,%r286; bra $L15; $L28: .loc 1 360 0 add.u64 %r124,%r124,%r95; .loc 1 361 0 mov.u64 %r110,%r133; $L22: .loc 1 325 0 setp.ge.u64 %r245,%r295,%r124; @ %r245 bra $L30; .loc 1 408 0 mov.u64 %r183,0; bra $L15; $L19: .loc 1 375 0 sub.u64 %r247,%r187,%r192; max.u64 %r246,%r247,%r192; add.u64 %r100,%r246,1; .loc 1 376 0 mov.u64 %r107,0; .loc 1 396 0 add.u64 %r296,%r192,-1; .loc 1 397 0 setp.eq.u64 %r297,%r296,-1; add.u64 %r298,%r192,-2; add.u64 %r299,%r186,-1; mov.u64 %r300,1; sub.u64 %r301,%r300,%r192; add.u64 %r302,%r192,1; $L40: .loc 1 381 0 add.u64 %r288,%r184,%r107; add.u64 %r249,%r288,%r154; ld.u8 %r251,[%r249]; shl.b64 %r252,%r251,3; add.u64 %r253,%frame,%r252; ld.u64 %r126,[%r253]; .loc 1 382 0 setp.ne.u64 %r254,%r126,0; @ %r254 bra $L31; .loc 1 390 0 setp.ge.u64 %r255,%r192,%r154; @ %r255 bra $L32; add.u64 %r256,%r186,%r192; .loc 1 391 0 add.u64 %r258,%r288,%r192; .loc 1 390 0 ld.u8 %r259,[%r256]; ld.u8 %r260,[%r258]; setp.eq.u16 %r261,%r259,%r260; @ %r261 bra $L33; mov.u64 %r128,%r192; bra $L34; $L31: .loc 1 384 0 add.u64 %r107,%r107,%r126; .loc 1 385 0 bra $L35; $L33: add.u64 %r169,%r186,%r302; add.u64 %r262,%r107,%r302; add.u64 %r172,%r184,%r262; .loc 1 390 0 mov.u64 %r128,%r192; $L36: .loc 1 392 0 add.u64 %r128,%r128,1; .loc 1 390 0 setp.ge.u64 %r263,%r128,%r154; @ %r263 bra $L32; ld.u8 %r105,[%r169]; .loc 1 391 0 ld.u8 %r106,[%r172]; add.u64 %r169,%r169,1; add.u64 %r172,%r172,1; .loc 1 390 0 cvt.u16.u32 %r264,%r105; cvt.u16.u32 %r265,%r106; setp.eq.u16 %r266,%r264,%r265; @ %r266 bra $L36; bra $L34; $L32: .loc 1 397 0 @ %r297 bra $L37; add.u64 %r268,%r186,%r296; .loc 1 398 0 add.u64 %r270,%r288,%r296; .loc 1 397 0 ld.u8 %r271,[%r268]; ld.u8 %r272,[%r270]; setp.ne.u16 %r273,%r271,%r272; @ %r273 bra $L38; add.u64 %r159,%r186,%r298; add.u64 %r274,%r107,%r298; add.u64 %r162,%r184,%r274; $L39: setp.eq.u64 %r275,%r159,%r299; @ %r275 bra $L37; ld.u8 %r108,[%r159]; .loc 1 398 0 ld.u8 %r109,[%r162]; add.u64 %r159,%r159,-1; add.u64 %r162,%r162,-1; .loc 1 397 0 cvt.u16.u32 %r276,%r108; cvt.u16.u32 %r277,%r109; setp.eq.u16 %r278,%r276,%r277; @ %r278 bra $L39; bra $L38; $L35: .loc 1 377 0 sub.u64 %r279,%r185,%r187; setp.le.u64 %r280,%r107,%r279; @ %r280 bra $L40; .loc 1 408 0 mov.u64 %r183,0; bra $L15; $L37: .loc 1 401 0 mov.u64 %r183,%r288; bra $L15; $L38: .loc 1 402 0 add.u64 %r107,%r107,%r100; bra $L35; $L24: add.u64 %r114,%r293,%r124; .loc 1 365 0 add.u64 %r124,%r114,%r131; .loc 1 366 0 mov.u64 %r110,%r118; bra $L22; $L34: add.u64 %r115,%r301,%r107; .loc 1 405 0 add.u64 %r107,%r128,%r115; bra $L35; $L15: .loc 1 409 0 mov.u64 %value,%r183; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: memmem .visible .func (.param .u64 %value_out) memmem (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u64 %r41; .reg .u32 %r42; .reg .u64 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u64 %r50; .reg .u64 %r51; .reg .u64 %r55; .reg .u64 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r61; .reg .u32 %r63; .reg .u64 %r67; .reg .u64 %r68; .reg .u64 %r69; .reg .u64 %r78; .reg .u64 %r91; .reg .u64 %r94; .reg .u64 %r97; .reg .u64 %r102; .reg .u64 %r105; .reg .u64 %r112; .reg .u64 %r115; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .pred %r125; .reg .pred %r126; .reg .pred %r127; .reg .u32 %r131; .reg .u64 %r132; .reg .u32 %r134; .reg .u32 %r135; .reg .u32 %r137; .reg .u32 %r138; .reg .u16 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .u32 %r142; .reg .u16 %r143; .reg .pred %r144; .reg .u64 %r145; .reg .pred %r146; .reg .u64 %r150; .reg .u64 %r154; .reg .u64 %r155; .reg .u32 %r156; .reg .pred %r157; .reg .pred %r158; .reg .u64 %r159; .reg .u64 %r160; .reg .u64 %r161; .reg .u16 %r162; .reg .u16 %r163; .reg .pred %r164; .reg .u64 %r166; .reg .u64 %r167; .reg .pred %r168; .reg .u16 %r169; .reg .u16 %r170; .reg .pred %r171; .reg .pred %r172; .reg .u64 %r174; .reg .u64 %r175; .reg .u16 %r176; .reg .u16 %r177; .reg .pred %r178; .reg .u64 %r179; .reg .pred %r180; .reg .u16 %r181; .reg .u16 %r182; .reg .pred %r183; .reg .u64 %r184; .reg .pred %r185; .reg .pred %r187; .reg .u64 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .pred %r191; .reg .u16 %r192; .reg .u16 %r193; .reg .pred %r194; .reg .u64 %r195; .reg .u64 %r197; .reg .u16 %r198; .reg .u16 %r199; .reg .pred %r200; .reg .u64 %r201; .reg .pred %r202; .reg .u16 %r203; .reg .u16 %r204; .reg .pred %r205; .reg .u64 %r206; .reg .pred %r207; .reg .u64 %r210; .reg .u64 %r211; .reg .u16 %r212; .reg .u16 %r213; .reg .pred %r214; .reg .u64 %r219; .reg .pred %r226; .reg .u64 %r227; .reg .u64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .pred %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; mov.u64 %r121,%ar0; mov.u64 %r122,%ar1; mov.u64 %r123,%ar2; mov.u64 %r124,%ar3; .loc 2 60 0 setp.eq.u64 %r125,%r124,0; @ %r125 bra $L84; .loc 2 83 0 setp.le.u64 %r126,%r124,%r122; @ %r126 bra $L61; $L63: .loc 2 84 0 mov.u64 %r120,0; bra $L59; $L61: .loc 2 90 0 setp.gt.u64 %r127,%r124,31; @ %r127 bra $L62; .loc 2 92 0 ld.u8 %r131,[%r123]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r121; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r131; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r122; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r132,[%value_in]; } mov.u64 %r120,%r132; .loc 2 93 0 set.u32.eq.u64 %r134,%r132,0; neg.s32 %r135,%r134; set.u32.eq.u64 %r137,%r124,1; neg.s32 %r138,%r137; cvt.u16.u32 %r140,%r135; cvt.u16.u32 %r141,%r138; or.b16 %r139,%r140,%r141; cvt.u32.u16 %r142,%r139; cvt.u16.u8 %r143,%r142; setp.ne.u16 %r144,%r143,0; @ %r144 bra $L59; .loc 2 95 0 sub.u64 %r145,%r132,%r121; sub.u64 %r31,%r122,%r145; .loc 2 96 0 setp.gt.u64 %r146,%r124,%r31; @ %r146 bra $L63; .loc 1 209 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r123; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r124; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r150,[%value_in]; } .loc 1 213 0 ld.u64 %r155,[%frame]; add.u64 %r154,%r123,%r155; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r123; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r154; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r150; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r156,[%value_in]; } setp.ne.u32 %r157,%r156,0; @ %r157 bra $L64; .loc 1 238 0 ld.u64 %r50,[%frame]; .loc 1 239 0 sub.u64 %r51,%r124,%r50; .loc 1 219 0 mov.u64 %r67,0; .loc 1 218 0 mov.u64 %r68,%r67; .loc 1 230 0 add.u64 %r229,%r150,-1; .loc 1 231 0 add.u64 %r230,%r123,%r229; add.u64 %r231,%r150,-2; mov.u64 %r232,1; sub.u64 %r233,%r232,%r150; .loc 1 244 0 mov.u64 %r234,%r67; .loc 1 220 0 sub.u64 %r235,%r31,%r124; $L72: .loc 1 223 0 max.u64 %r39,%r150,%r68; .loc 1 224 0 setp.le.u64 %r158,%r124,%r39; @ %r158 bra $L65; add.u64 %r159,%r123,%r39; .loc 1 225 0 add.u64 %r160,%r132,%r39; add.u64 %r161,%r160,%r67; .loc 1 224 0 ld.u8 %r162,[%r159]; ld.u8 %r163,[%r161]; setp.ne.u16 %r164,%r162,%r163; @ %r164 bra $L66; add.u64 %r227,%r39,1; add.u64 %r94,%r123,%r227; add.u64 %r166,%r67,1; add.u64 %r167,%r166,%r39; add.u64 %r97,%r132,%r167; $L67: .loc 1 226 0 mov.u64 %r39,%r227; .loc 1 224 0 setp.eq.u64 %r168,%r124,%r227; @ %r168 bra $L65; ld.u8 %r40,[%r94]; .loc 1 225 0 ld.u8 %r42,[%r97]; add.u64 %r94,%r94,1; add.u64 %r97,%r97,1; .loc 1 224 0 cvt.u16.u32 %r169,%r40; cvt.u16.u32 %r170,%r42; setp.eq.u16 %r171,%r169,%r170; @ ! %r171 bra $L66; add.u64 %r227,%r227,1; bra $L67; $L65: .loc 1 230 0 mov.u64 %r69,%r229; .loc 1 231 0 setp.le.u64 %r172,%r150,%r68; @ %r172 bra $L85; .loc 1 232 0 add.u64 %r174,%r132,%r67; add.u64 %r175,%r174,%r229; .loc 1 231 0 ld.u8 %r176,[%r230]; ld.u8 %r177,[%r175]; setp.ne.u16 %r178,%r176,%r177; @ %r178 bra $L86; add.u64 %r41,%r123,%r231; add.u64 %r179,%r231,%r67; add.u64 %r33,%r132,%r179; add.u64 %r91,%r68,-1; bra $L69; $L87: mov.u64 %r69,%r45; $L69: .loc 1 233 0 add.u64 %r45,%r69,-1; .loc 1 231 0 setp.eq.u64 %r180,%r45,%r91; @ %r180 bra $L68; ld.u8 %r46,[%r41]; .loc 1 232 0 ld.u8 %r47,[%r33]; add.u64 %r41,%r41,-1; add.u64 %r33,%r33,-1; .loc 1 231 0 cvt.u16.u32 %r181,%r46; cvt.u16.u32 %r182,%r47; setp.eq.u16 %r183,%r181,%r182; @ %r183 bra $L87; bra $L68; $L85: mov.u64 %r69,%r150; bra $L68; $L86: mov.u64 %r69,%r150; $L68: .loc 1 234 0 add.u64 %r184,%r68,1; setp.le.u64 %r185,%r184,%r69; @ %r185 bra $L70; .loc 1 235 0 add.u64 %r120,%r132,%r67; bra $L59; $L70: .loc 1 238 0 add.u64 %r67,%r67,%r50; .loc 1 239 0 mov.u64 %r68,%r51; $L82: .loc 1 220 0 setp.ge.u64 %r187,%r235,%r67; @ %r187 bra $L72; .loc 1 276 0 mov.u64 %r120,0; bra $L59; $L64: .loc 1 252 0 sub.u64 %r189,%r124,%r150; max.u64 %r188,%r189,%r150; add.u64 %r55,%r188,1; .loc 1 253 0 mov.u64 %r32,0; setp.le.u64 %r226,%r124,%r150; .loc 1 264 0 add.u64 %r236,%r150,-1; .loc 1 265 0 setp.ne.u64 %r237,%r236,-1; add.u64 %r238,%r150,-2; add.u64 %r239,%r123,-1; mov.u64 %r240,1; sub.u64 %r241,%r240,%r150; add.u64 %r242,%r150,1; bra $L73; $L80: add.u64 %r112,%r123,%r242; add.u64 %r190,%r32,%r242; add.u64 %r115,%r132,%r190; .loc 1 258 0 mov.u64 %r57,%r150; $L75: .loc 1 260 0 add.u64 %r57,%r57,1; .loc 1 258 0 setp.eq.u64 %r191,%r124,%r57; @ %r191 bra $L74; ld.u8 %r58,[%r112]; .loc 1 259 0 ld.u8 %r59,[%r115]; add.u64 %r112,%r112,1; add.u64 %r115,%r115,1; .loc 1 258 0 cvt.u16.u32 %r192,%r58; cvt.u16.u32 %r193,%r59; setp.eq.u16 %r194,%r192,%r193; @ %r194 bra $L75; bra $L76; $L83: .loc 1 265 0 add.u64 %r195,%r123,%r236; .loc 1 266 0 add.u64 %r197,%r228,%r236; .loc 1 265 0 ld.u8 %r198,[%r195]; ld.u8 %r199,[%r197]; setp.ne.u16 %r200,%r198,%r199; @ %r200 bra $L77; add.u64 %r102,%r123,%r238; add.u64 %r201,%r32,%r238; add.u64 %r105,%r132,%r201; $L79: setp.eq.u64 %r202,%r102,%r239; @ %r202 bra $L78; ld.u8 %r61,[%r102]; .loc 1 266 0 ld.u8 %r63,[%r105]; add.u64 %r102,%r102,-1; add.u64 %r105,%r105,-1; .loc 1 265 0 cvt.u16.u32 %r203,%r61; cvt.u16.u32 %r204,%r63; setp.eq.u16 %r205,%r203,%r204; @ %r205 bra $L79; bra $L77; $L81: .loc 1 254 0 sub.u64 %r206,%r31,%r124; setp.lt.u64 %r207,%r206,%r32; @ %r207 bra $L88; $L73: .loc 1 258 0 @ ! %r226 bra $L94; add.u64 %r228,%r132,%r32; bra $L74; $L94: .loc 1 259 0 add.u64 %r228,%r132,%r32; add.u64 %r210,%r228,%r150; .loc 1 258 0 add.u64 %r211,%r123,%r150; ld.u8 %r212,[%r210]; ld.u8 %r213,[%r211]; setp.eq.u16 %r214,%r212,%r213; @ %r214 bra $L80; mov.u64 %r57,%r150; bra $L76; $L88: .loc 1 276 0 mov.u64 %r120,0; .loc 2 98 0 bra $L59; $L62: .loc 2 100 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r121; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r122; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r123; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r124; call (%value_in),two_way_long_needle,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r219,[%value_in]; } mov.u64 %r120,%r219; bra $L59; $L84: .loc 2 63 0 mov.u64 %r120,%r121; bra $L59; $L78: .loc 1 269 0 mov.u64 %r120,%r228; bra $L59; $L77: .loc 1 270 0 add.u64 %r32,%r32,%r55; bra $L81; $L66: add.u64 %r38,%r233,%r67; .loc 1 243 0 add.u64 %r67,%r38,%r39; .loc 1 244 0 mov.u64 %r68,%r234; bra $L82; $L76: add.u64 %r78,%r241,%r32; .loc 1 273 0 add.u64 %r32,%r78,%r57; bra $L81; $L74: .loc 1 265 0 @ %r237 bra $L83; bra $L78; $L59: .loc 2 102 0 mov.u64 %value,%r120; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } lib_a-memmove.o/0 0 0 644 3493 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memmove .visible .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/memmove.c" // BEGIN GLOBAL FUNCTION DEF: memmove .visible .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r77; .reg .u64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u64 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r106; .reg .u64 %r108; .reg .u64 %r112; .reg .u64 %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .pred %r121; .reg .pred %r122; .reg .pred %r123; .reg .u32 %r124; .reg .pred %r125; .reg .pred %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .pred %r139; .reg .u64 %r140; .reg .u32 %r141; .reg .pred %r142; mov.u64 %r118,%ar0; mov.u64 %r119,%ar1; mov.u64 %r120,%ar2; .loc 1 94 0 setp.le.u64 %r121,%r118,%r119; @ %r121 bra $L2; add.u64 %r93,%r119,%r120; setp.le.u64 %r122,%r93,%r118; @ %r122 bra $L2; .loc 1 98 0 add.u64 %r94,%r118,%r120; .loc 1 99 0 setp.eq.u64 %r123,%r120,0; @ %r123 bra $L3; $L4: .loc 1 101 0 add.u64 %r93,%r93,-1; add.u64 %r94,%r94,-1; ld.u8 %r124,[%r93]; st.u8 [%r94],%r124; .loc 1 99 0 setp.ne.u64 %r125,%r119,%r93; @ %r125 bra $L4; bra $L3; $L2: .loc 1 109 0 setp.le.u64 %r126,%r120,31; @ %r126 bra $L11; or.b64 %r127,%r119,%r118; and.b64 %r128,%r127,7; setp.eq.u64 %r129,%r128,0; @ %r129 bra $L6; mov.u64 %r77,%r118; bra $L7; $L11: mov.u64 %r77,%r118; bra $L5; $L12: .loc 1 125 0 mov.u64 %r120,%r95; $L5: .loc 1 136 0 setp.ne.u64 %r130,%r120,0; @ %r130 bra $L7; bra $L3; $L6: add.u64 %r131,%r120,-32; and.b64 %r133,%r131,-32; add.u64 %r112,%r133,32; add.u64 %r77,%r118,%r112; .loc 1 109 0 mov.u64 %r88,%r119; mov.u64 %r90,%r118; $L8: .loc 1 117 0 ld.u64 %r82,[%r88]; st.u64 [%r90],%r82; .loc 1 118 0 ld.u64 %r83,[%r88+8]; st.u64 [%r90+8],%r83; .loc 1 119 0 ld.u64 %r84,[%r88+16]; st.u64 [%r90+16],%r84; add.u64 %r88,%r88,32; add.u64 %r90,%r90,32; .loc 1 120 0 ld.u64 %r85,[%r88+-8]; st.u64 [%r90+-8],%r85; .loc 1 115 0 setp.ne.u64 %r134,%r77,%r90; @ %r134 bra $L8; add.u64 %r119,%r119,%r112; and.b64 %r95,%r120,31; .loc 1 125 0 setp.le.u64 %r135,%r95,7; @ %r135 bra $L12; mov.u64 %r101,%r119; mov.u64 %r102,%r77; add.u64 %r136,%r95,-8; shr.u64 %r106,%r136,3; shl.b64 %r137,%r106,3; add.u64 %r138,%r137,8; add.u64 %r108,%r138,%r119; $L9: .loc 1 127 0 ld.u64 %r86,[%r101]; st.u64 [%r102],%r86; add.u64 %r101,%r101,8; add.u64 %r102,%r102,8; .loc 1 125 0 setp.ne.u64 %r139,%r101,%r108; @ %r139 bra $L9; and.b64 %r120,%r120,7; add.u64 %r140,%r106,1; shl.b64 %r91,%r140,3; add.u64 %r77,%r77,%r91; add.u64 %r119,%r119,%r91; bra $L5; $L7: mov.u64 %r92,%r77; mov.u64 %r96,%r119; add.u64 %r100,%r92,%r120; $L10: .loc 1 138 0 ld.u8 %r141,[%r96]; st.u8 [%r92],%r141; add.u64 %r92,%r92,1; add.u64 %r96,%r96,1; .loc 1 136 0 setp.ne.u64 %r142,%r92,%r100; @ %r142 bra $L10; $L3: .loc 1 144 0 mov.u64 %value,%r118; st.param.u64 [%value_out],%value; ret; } lib_a-mempcpy.o/0 0 0 644 2928 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: mempcpy .visible .func (.param .u64 %value_out) mempcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/mempcpy.c" // BEGIN GLOBAL FUNCTION DEF: mempcpy .visible .func (.param .u64 %value_out) mempcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r80; .reg .u64 %r81; .reg .u64 %r82; .reg .u64 %r83; .reg .u64 %r84; .reg .u64 %r86; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r101; .reg .u64 %r103; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .pred %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .pred %r120; .reg .pred %r121; .reg .u64 %r122; .reg .u64 %r124; .reg .pred %r125; .reg .pred %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .pred %r130; .reg .u64 %r131; .reg .u32 %r132; .reg .pred %r133; mov.u64 %r114,%ar0; mov.u64 %r115,%ar1; mov.u64 %r116,%ar2; .loc 1 75 0 setp.le.u64 %r117,%r116,31; @ %r117 bra $L2; or.b64 %r118,%r115,%r114; and.b64 %r119,%r118,7; setp.eq.u64 %r120,%r119,0; @ %r120 bra $L3; bra $L4; $L9: .loc 1 91 0 mov.u64 %r116,%r89; $L2: .loc 1 102 0 setp.ne.u64 %r121,%r116,0; @ %r121 bra $L4; mov.u64 %r113,%r114; bra $L1; $L3: add.u64 %r122,%r116,-32; and.b64 %r124,%r122,-32; add.u64 %r107,%r124,32; add.u64 %r108,%r114,%r107; .loc 1 78 0 mov.u64 %r88,%r115; $L6: .loc 1 83 0 ld.u64 %r80,[%r88]; st.u64 [%r114],%r80; .loc 1 84 0 ld.u64 %r81,[%r88+8]; st.u64 [%r114+8],%r81; .loc 1 85 0 ld.u64 %r82,[%r88+16]; st.u64 [%r114+16],%r82; add.u64 %r88,%r88,32; add.u64 %r114,%r114,32; .loc 1 86 0 ld.u64 %r83,[%r88+-8]; st.u64 [%r114+-8],%r83; .loc 1 81 0 setp.ne.u64 %r125,%r108,%r114; @ %r125 bra $L6; add.u64 %r115,%r115,%r107; and.b64 %r89,%r116,31; .loc 1 91 0 setp.le.u64 %r126,%r89,7; @ %r126 bra $L9; mov.u64 %r96,%r115; mov.u64 %r97,%r108; add.u64 %r127,%r89,-8; shr.u64 %r101,%r127,3; shl.b64 %r128,%r101,3; add.u64 %r129,%r128,8; add.u64 %r103,%r129,%r115; $L7: .loc 1 93 0 ld.u64 %r84,[%r96]; st.u64 [%r97],%r84; add.u64 %r96,%r96,8; add.u64 %r97,%r97,8; .loc 1 91 0 setp.ne.u64 %r130,%r96,%r103; @ %r130 bra $L7; add.u64 %r131,%r101,1; shl.b64 %r86,%r131,3; add.u64 %r115,%r115,%r86; add.u64 %r114,%r108,%r86; and.b64 %r116,%r116,7; bra $L2; $L4: mov.u64 %r91,%r115; mov.u64 %r92,%r114; add.u64 %r95,%r91,%r116; $L8: .loc 1 103 0 ld.u8 %r132,[%r91]; st.u8 [%r92],%r132; add.u64 %r91,%r91,1; add.u64 %r92,%r92,1; .loc 1 102 0 setp.ne.u64 %r133,%r91,%r95; @ %r133 bra $L8; add.u64 %r113,%r114,%r116; $L1: .loc 1 107 0 mov.u64 %value,%r113; st.param.u64 [%value_out],%value; ret; } lib_a-memrchr.o/0 0 0 644 3617 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memrchr .visible .func (.param .u64 %value_out) memrchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/memrchr.c" // BEGIN GLOBAL FUNCTION DEF: memrchr .visible .func (.param .u64 %value_out) memrchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r81; .reg .u64 %r84; .reg .u64 %r86; .reg .u64 %r91; .reg .u64 %r92; .reg .u32 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r99; .reg .u64 %r101; .reg .u64 %r106; .reg .u64 %r107; .reg .u32 %r108; .reg .u64 %r109; .reg .u32 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .pred %r113; .reg .pred %r114; .reg .u16 %r115; .reg .u16 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u16 %r119; .reg .pred %r121; .reg .u64 %r123; .reg .pred %r124; .reg .pred %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u64 %r130; .reg .u64 %r131; .reg .u64 %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .pred %r135; .reg .pred %r136; .reg .pred %r137; .reg .u16 %r138; .reg .u16 %r139; .reg .pred %r140; .reg .u16 %r141; .reg .pred %r143; .reg .pred %r144; .reg .u16 %r146; .reg .u16 %r147; mov.u64 %r107,%ar0; mov.u32 %r108,%ar1; mov.u64 %r109,%ar2; .loc 1 77 0 add.u64 %r101,%r109,-1; add.u64 %r106,%r107,%r101; .loc 1 78 0 cvt.u32.u32 %r110,%r108; cvt.u32.u8 %r95,%r110; .loc 1 85 0 add.u64 %r111,%r107,%r109; and.b64 %r112,%r111,7; setp.eq.u64 %r113,%r112,0; @ %r113 bra $L11; .loc 1 87 0 setp.eq.u64 %r114,%r109,0; @ %r114 bra $L12; .loc 1 89 0 ld.u8 %r115,[%r106]; cvt.u16.u32 %r116,%r95; setp.eq.u16 %r117,%r115,%r116; @ %r117 bra $L1; cvt.u16.u32 %r147,%r95; bra $L4; $L5: .loc 1 87 0 add.u64 %r101,%r101,-1; setp.eq.u64 %r118,%r101,-1; @ %r118 bra $L13; .loc 1 89 0 ld.u8 %r119,[%r106]; setp.eq.u16 %r121,%r119,%r147; @ %r121 bra $L1; $L4: .loc 1 91 0 add.u64 %r106,%r106,-1; .loc 1 85 0 shl.b64 %r123,%r106,61; setp.ne.u64 %r124,%r123,-2305843009213693952; @ %r124 bra $L5; bra $L2; $L11: mov.u64 %r101,%r109; $L2: .loc 1 94 0 setp.le.u64 %r125,%r101,7; @ %r125 bra $L6; .loc 1 104 0 add.u64 %r99,%r106,-7; .loc 1 105 0 shl.b32 %r126,%r108,8; and.b32 %r127,%r126,65535; and.b32 %r128,%r108,255; or.b32 %r129,%r127,%r128; cvt.s64.s32 %r96,%r129; .loc 1 106 0 shl.b64 %r81,%r96,16; or.b64 %r97,%r81,%r96; .loc 1 108 0 shl.b64 %r92,%r97,32; or.b64 %r91,%r92,%r97; $L8: .loc 1 112 0 ld.u64 %r130,[%r99]; xor.b64 %r84,%r91,%r130; add.u64 %r131,%r84,-72340172838076673; not.b64 %r132,%r84; and.b64 %r133,%r131,%r132; and.b64 %r134,%r133,-9187201950435737472; setp.ne.u64 %r135,%r134,0; @ %r135 bra $L7; .loc 1 114 0 add.u64 %r101,%r101,-8; .loc 1 115 0 add.u64 %r99,%r99,-8; .loc 1 110 0 setp.gt.u64 %r136,%r101,7; @ %r136 bra $L8; $L7: .loc 1 121 0 add.u64 %r106,%r99,7; $L6: .loc 1 126 0 setp.eq.u64 %r137,%r101,0; @ %r137 bra $L14; .loc 1 128 0 ld.u8 %r138,[%r106]; cvt.u16.u32 %r139,%r95; setp.eq.u16 %r140,%r138,%r139; @ %r140 bra $L1; sub.u64 %r86,%r106,%r101; cvt.u16.u32 %r146,%r95; bra $L9; $L10: ld.u8 %r141,[%r106]; setp.eq.u16 %r143,%r141,%r146; @ %r143 bra $L1; $L9: .loc 1 130 0 add.u64 %r106,%r106,-1; .loc 1 126 0 setp.ne.u64 %r144,%r86,%r106; @ %r144 bra $L10; .loc 1 88 0 mov.u64 %r106,0; bra $L1; $L12: mov.u64 %r106,%r109; bra $L1; $L13: mov.u64 %r106,0; bra $L1; $L14: mov.u64 %r106,%r101; $L1: .loc 1 134 0 mov.u64 %value,%r106; st.param.u64 [%value_out],%value; ret; } lib_a-memset.o/ 0 0 0 644 3548 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: memset .visible .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/memset.c" // BEGIN GLOBAL FUNCTION DEF: memset .visible .func (.param .u64 %value_out) memset (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r82; .reg .u64 %r84; .reg .u64 %r85; .reg .u64 %r89; .reg .u64 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r98; .reg .u64 %r100; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r111; .reg .u64 %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r120; .reg .pred %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .pred %r124; .reg .pred %r125; .reg .pred %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .pred %r129; .reg .u64 %r130; .reg .u64 %r132; .reg .u64 %r133; .reg .pred %r134; .reg .pred %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .u64 %r138; .reg .pred %r139; .reg .u64 %r140; .reg .u64 %r141; .reg .u32 %r142; .reg .u32 %r143; .reg .pred %r144; mov.u64 %r114,%ar0; mov.u32 %r115,%ar1; mov.u64 %r116,%ar2; .loc 1 59 0 mov.u64 %r111,%r114; and.b64 %r117,%r114,7; setp.eq.u64 %r118,%r117,0; @ %r118 bra $L13; .loc 1 61 0 add.u64 %r94,%r116,-1; setp.eq.u64 %r119,%r116,0; @ %r119 bra $L3; cvt.u32.u32 %r120,%r115; .loc 1 50 0 mov.u64 %r95,%r114; .loc 1 62 0 mov.u32 %r122,%r120; bra $L4; $L5: .loc 1 61 0 add.u64 %r94,%r94,-1; add.u64 %r111,%r111,1; setp.eq.u64 %r121,%r94,-1; @ %r121 bra $L3; $L4: .loc 1 62 0 add.u64 %r95,%r95,1; st.u8 [%r111],%r122; .loc 1 59 0 and.b64 %r123,%r95,7; setp.ne.u64 %r124,%r123,0; @ %r124 bra $L5; bra $L2; $L13: .loc 1 50 0 mov.u64 %r95,%r114; .loc 1 59 0 mov.u64 %r94,%r116; $L2: .loc 1 67 0 setp.gt.u64 %r125,%r94,7; @ %r125 bra $L6; $L10: .loc 1 100 0 setp.ne.u64 %r126,%r94,0; @ %r126 bra $L7; bra $L3; $L6: .loc 1 56 0 and.b32 %r91,%r115,255; .loc 1 74 0 shl.b32 %r127,%r91,8; or.b32 %r128,%r127,%r91; cvt.u64.u32 %r92,%r128; .loc 1 75 0 shl.b64 %r82,%r92,16; or.b64 %r93,%r82,%r92; .loc 1 77 0 shl.b64 %r98,%r93,32; or.b64 %r103,%r93,%r98; .loc 1 80 0 setp.le.u64 %r129,%r94,31; @ %r129 bra $L14; add.u64 %r130,%r94,-32; and.b64 %r132,%r130,-32; add.u64 %r133,%r132,32; add.u64 %r90,%r95,%r133; $L9: .loc 1 82 0 st.u64 [%r95],%r103; .loc 1 83 0 st.u64 [%r95+8],%r103; .loc 1 84 0 st.u64 [%r95+16],%r103; add.u64 %r95,%r95,32; .loc 1 85 0 st.u64 [%r95+-8],%r103; .loc 1 80 0 setp.ne.u64 %r134,%r90,%r95; @ %r134 bra $L9; and.b64 %r94,%r94,31; .loc 1 89 0 setp.le.u64 %r135,%r94,7; @ ! %r135 bra $L8; bra $L10; $L14: .loc 1 80 0 mov.u64 %r90,%r95; $L8: mov.u64 %r84,%r90; add.u64 %r136,%r94,-8; shr.u64 %r100,%r136,3; shl.b64 %r137,%r100,3; add.u64 %r138,%r90,8; add.u64 %r102,%r137,%r138; $L11: .loc 1 91 0 st.u64 [%r84],%r103; add.u64 %r84,%r84,8; .loc 1 89 0 setp.ne.u64 %r139,%r84,%r102; @ %r139 bra $L11; add.u64 %r140,%r100,1; shl.b64 %r141,%r140,3; add.u64 %r95,%r90,%r141; and.b64 %r94,%r94,7; bra $L10; $L7: cvt.u32.u32 %r142,%r115; mov.u64 %r85,%r95; add.u64 %r89,%r85,%r94; .loc 1 101 0 mov.u32 %r143,%r142; $L12: st.u8 [%r85],%r143; add.u64 %r85,%r85,1; .loc 1 100 0 setp.ne.u64 %r144,%r85,%r89; @ %r144 bra $L12; $L3: .loc 1 104 0 mov.u64 %value,%r114; st.param.u64 [%value_out],%value; ret; } lib_a-mprec.o/ 0 0 0 644 52452 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _Balloc .visible .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/mprec.c" // BEGIN GLOBAL FUNCTION DECL: _Bfree .visible .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __multadd .visible .func (.param .u64 %value_out) __multadd (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __s2b .visible .func (.param .u64 %value_out) __s2b (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: __hi0bits .visible .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __lo0bits .visible .func (.param .u32 %value_out) __lo0bits (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __i2b .visible .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __multiply .visible .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __pow5mult .visible .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __lshift .visible .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mcmp .visible .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __mdiff .visible .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __ulp .visible .func (.param .f64 %value_out) __ulp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __b2d .visible .func (.param .f64 %value_out) __b2d (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __d2b .visible .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ratio .visible .func (.param .f64 %value_out) __ratio (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _mprec_log10 .visible .func (.param .f64 %value_out) _mprec_log10 (.param .u32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __copybits .visible .func __copybits (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __any_on .visible .func (.param .u32 %value_out) __any_on (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _calloc_r .extern .func (.param .u64 %value_out) _calloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL VAR DEF: __mprec_tens .visible .const .align 8 .u64 __mprec_tens[25] = {4607182418800017408,4621819117588971520,4636737291354636288,4652007308841189376,4666723172467343360,4681608360884174848,4696837146684686336,4711630319722168320,4726483295884279808,4741671816366391296,4756540486875873280,4771362005757984768,4786511204640096256,4801453603149578240,4816244402031689728,4831355200913801216,4846369599423283200,4861130398305394688,4876203697187506176,4891288408196988160,4906019910204099648,4921056587992461136,4936209963552724370,4950912855330343670,4965913770331839924 }; // BEGIN GLOBAL VAR DEF: __mprec_tinytens .visible .const .align 8 .u64 __mprec_tinytens[5] = {4367597403136100796,4128101167230658355,3649340653511681853,2691949749288605597,776877706278891331 }; // BEGIN VAR DEF: p05$2582 .const .align 4 .u32 p05$2582[3] = {5,25,125 }; // BEGIN GLOBAL VAR DEF: __mprec_bigtens .visible .const .align 8 .u64 __mprec_bigtens[5] = {4846369599423283200,5085611494797045271,5564284217833028085,6521906365687930162,8436737289693151036 }; // BEGIN GLOBAL FUNCTION DEF: _Balloc .visible .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r22; .reg .u64 %r25; .reg .u64 %r26; .reg .u32 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u32 %r34; .reg .pred %r35; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .pred %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u64 %r46; .reg .u32 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .pred %r53; .reg .u64 %r54; mov.u64 %r33,%ar0; mov.u32 %r34,%ar1; .loc 1 103 0 ld.u64 %r22,[%r33+120]; setp.ne.u64 %r35,%r22,0; @ %r35 bra $L2; .loc 1 106 0 mov.u64 %r38,65; mov.u64 %r37,8; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r37; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r38; call (%value_in),_calloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r39,[%value_in]; } mov.u64 %r22,%r39; st.u64 [%r33+120],%r22; .loc 1 109 0 setp.ne.u64 %r40,%r22,0; @ %r40 bra $L2; $L6: .loc 1 111 0 mov.u64 %r32,0; bra $L1; $L2: .loc 1 115 0 cvt.s64.s32 %r41,%r34; shl.b64 %r42,%r41,3; add.u64 %r25,%r22,%r42; ld.u64 %r32,[%r25]; setp.eq.u64 %r43,%r32,0; @ %r43 bra $L4; .loc 1 117 0 ld.u64 %r26,[%r32]; st.u64 [%r25],%r26; bra $L5; $L4: .loc 1 121 0 mov.u32 %r44,1; shl.b32 %r31,%r44,%r34; .loc 1 126 0 add.u32 %r48,%r31,-1; cvt.s64.s32 %r49,%r48; .loc 1 123 0 add.u64 %r50,%r49,8; shl.b64 %r51,%r50,2; mov.u64 %r46,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r46; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r51; call (%value_in),_calloc_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r52,[%value_in]; } mov.u64 %r32,%r52; .loc 1 127 0 setp.eq.u64 %r53,%r32,0; @ %r53 bra $L6; .loc 1 128 0 st.u32 [%r32+8],%r34; .loc 1 129 0 st.u32 [%r32+12],%r31; $L5: .loc 1 131 0 mov.u64 %r54,0; st.u64 [%r32+16],%r54; $L1: .loc 1 133 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _Bfree .visible .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .pred %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; mov.u64 %r28,%ar0; mov.u64 %r29,%ar1; .loc 1 139 0 setp.eq.u64 %r30,%r29,0; @ %r30 bra $L10; .loc 1 141 0 ld.s32 %r31,[%r29+8]; shl.b64 %r32,%r31,3; ld.u64 %r33,[%r28+120]; add.u64 %r26,%r33,%r32; ld.u64 %r27,[%r26]; st.u64 [%r29],%r27; .loc 1 142 0 st.u64 [%r26],%r29; $L10: .loc 1 144 0 ret; } // BEGIN GLOBAL FUNCTION DEF: __multadd .visible .func (.param .u64 %value_out) __multadd (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u64 %r80; .reg .u64 %r81; .reg .u64 %r83; .reg .u64 %r86; .reg .u64 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .pred %r98; .reg .pred %r99; .reg .u32 %r100; .reg .pred %r101; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r106; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u32 %r123; mov.u64 %r86,%ar0; mov.u64 %r87,%ar1; mov.u32 %r88,%ar2; mov.u32 %r89,%ar3; .loc 1 160 0 ld.u32 %r69,[%r87+20]; .loc 1 161 0 add.u64 %r83,%r87,24; .loc 1 162 0 mov.u32 %r68,0; $L16: .loc 1 166 0 ld.u32 %r71,[%r83]; .loc 1 167 0 and.b32 %r90,%r71,65535; mad.lo.u32 %r72,%r90,%r88,%r89; .loc 1 168 0 shr.u32 %r92,%r71,16; shr.u32 %r94,%r72,16; mad.lo.u32 %r73,%r92,%r88,%r94; .loc 1 169 0 shr.u32 %r89,%r73,16; .loc 1 170 0 shl.b32 %r95,%r73,16; and.b32 %r96,%r72,65535; add.u32 %r97,%r95,%r96; st.u32 [%r83],%r97; .loc 1 177 0 add.u32 %r68,%r68,1; add.u64 %r83,%r83,4; setp.gt.s32 %r98,%r69,%r68; @ %r98 bra $L16; .loc 1 178 0 setp.eq.u32 %r99,%r89,0; @ %r99 bra $L15; .loc 1 180 0 ld.u32 %r100,[%r87+12]; setp.gt.s32 %r101,%r100,%r69; @ %r101 bra $L18; .loc 1 182 0 ld.u32 %r105,[%r87+8]; add.u32 %r104,%r105,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r86; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r104; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r106,[%value_in]; } .loc 1 183 0 ld.s32 %r110,[%r87+20]; add.u64 %r111,%r110,2; shl.b64 %r112,%r111,2; add.u64 %r113,%r87,16; add.u64 %r114,%r106,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r114; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r113; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r112; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r115,[%value_in]; } .loc 1 141 0 ld.s32 %r116,[%r87+8]; shl.b64 %r117,%r116,3; ld.u64 %r118,[%r86+120]; add.u64 %r80,%r118,%r117; ld.u64 %r81,[%r80]; st.u64 [%r87],%r81; .loc 1 142 0 st.u64 [%r80],%r87; .loc 1 185 0 mov.u64 %r87,%r106; $L18: .loc 1 187 0 cvt.s64.s32 %r119,%r69; add.u64 %r120,%r119,6; shl.b64 %r121,%r120,2; add.u64 %r122,%r87,%r121; st.u32 [%r122],%r89; add.u32 %r123,%r69,1; .loc 1 188 0 st.u32 [%r87+20],%r123; $L15: .loc 1 191 0 mov.u64 %value,%r87; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __s2b .visible .func (.param .u64 %value_out) __s2b (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %ar4; ld.param.u32 %ar4,[%in_ar4]; .reg .u32 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r104; .reg .u32 %r105; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r114; .reg .u64 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .pred %r124; .reg .pred %r126; .reg .u64 %r129; .reg .u32 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .u64 %r133; .reg .u32 %r136; .reg .u32 %r138; .reg .u32 %r139; .reg .u64 %r140; .reg .pred %r141; .reg .pred %r142; .reg .u32 %r143; .reg .u32 %r144; .reg .u64 %r145; .reg .u64 %r146; .reg .u32 %r149; .reg .u32 %r151; .reg .u32 %r152; .reg .u64 %r153; .reg .pred %r154; mov.u64 %r118,%ar0; mov.u64 %r119,%ar1; mov.u32 %r120,%ar2; mov.u32 %r121,%ar3; mov.u32 %r122,%ar4; .loc 1 205 0 add.u32 %r123,%r121,8; div.s32 %r97,%r123,9; .loc 1 206 0 setp.le.s32 %r124,%r97,1; @ %r124 bra $L30; mov.u32 %r104,1; mov.u32 %r105,0; $L24: add.u32 %r104,%r104,%r104; add.u32 %r105,%r105,1; setp.gt.s32 %r126,%r97,%r104; @ %r126 bra $L24; bra $L23; $L30: mov.u32 %r105,0; $L23: .loc 1 208 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r105; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r129,[%value_in]; } mov.u64 %r117,%r129; .loc 1 209 0 st.u32 [%r117+24],%r122; .loc 1 210 0 mov.u32 %r130,1; st.u32 [%r117+20],%r130; .loc 1 218 0 setp.le.s32 %r131,%r120,9; @ %r131 bra $L25; .loc 1 220 0 add.u64 %r99,%r119,9; mov.u64 %r110,%r99; add.u32 %r132,%r120,-10; cvt.u64.u32 %r114,%r132; add.u64 %r133,%r119,10; add.u64 %r116,%r133,%r114; $L26: .loc 1 222 0 ld.s8 %r138,[%r110]; add.u32 %r139,%r138,-48; mov.u32 %r136,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r117; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r136; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r139; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r140,[%value_in]; } mov.u64 %r117,%r140; add.u64 %r110,%r110,1; .loc 1 223 0 setp.ne.u64 %r141,%r110,%r116; @ %r141 bra $L26; add.u64 %r103,%r99,%r114; .loc 1 224 0 add.u64 %r102,%r103,2; bra $L27; $L25: .loc 1 227 0 add.u64 %r102,%r119,10; .loc 1 217 0 mov.u32 %r120,9; $L27: .loc 1 228 0 setp.le.s32 %r142,%r121,%r120; @ %r142 bra $L22; mov.u64 %r98,%r102; add.u32 %r143,%r121,-1; sub.u32 %r144,%r143,%r120; cvt.u64.u32 %r145,%r144; add.u64 %r146,%r98,1; add.u64 %r109,%r145,%r146; $L29: .loc 1 229 0 ld.s8 %r151,[%r98]; add.u32 %r152,%r151,-48; mov.u32 %r149,10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r117; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r149; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r152; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r153,[%value_in]; } mov.u64 %r117,%r153; add.u64 %r98,%r98,1; .loc 1 228 0 setp.ne.u64 %r154,%r98,%r109; @ %r154 bra $L29; $L22: .loc 1 231 0 mov.u64 %value,%r117; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __hi0bits .visible .func (.param .u32 %value_out) __hi0bits (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r28; .reg .u32 %r29; .reg .u32 %r30; .reg .pred %r31; .reg .u32 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .pred %r35; .reg .u32 %r36; .reg .pred %r37; .reg .pred %r38; .reg .u32 %r39; .reg .pred %r40; mov.u32 %r29,%ar0; .loc 1 239 0 and.b32 %r30,%r29,-65536; setp.ne.u32 %r31,%r30,0; @ %r31 bra $L40; .loc 1 242 0 shl.b32 %r29,%r29,16; .loc 1 241 0 mov.u32 %r28,16; bra $L35; $L40: .loc 1 237 0 mov.u32 %r28,0; $L35: .loc 1 244 0 and.b32 %r32,%r29,-16777216; setp.ne.u32 %r33,%r32,0; @ %r33 bra $L36; .loc 1 246 0 add.u32 %r28,%r28,8; .loc 1 247 0 shl.b32 %r29,%r29,8; $L36: .loc 1 249 0 and.b32 %r34,%r29,-268435456; setp.ne.u32 %r35,%r34,0; @ %r35 bra $L37; .loc 1 251 0 add.u32 %r28,%r28,4; .loc 1 252 0 shl.b32 %r29,%r29,4; $L37: .loc 1 254 0 and.b32 %r36,%r29,-1073741824; setp.ne.u32 %r37,%r36,0; @ %r37 bra $L38; .loc 1 256 0 add.u32 %r28,%r28,2; .loc 1 257 0 shl.b32 %r29,%r29,2; $L38: .loc 1 259 0 setp.lt.s32 %r38,%r29,0; @ %r38 bra $L34; .loc 1 262 0 and.b32 %r39,%r29,1073741824; setp.eq.u32 %r40,%r39,0; @ %r40 bra $L41; .loc 1 261 0 add.u32 %r28,%r28,1; bra $L34; $L41: .loc 1 263 0 mov.u32 %r28,32; $L34: .loc 1 266 0 mov.u32 %value,%r28; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __lo0bits .visible .func (.param .u32 %value_out) __lo0bits (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r32; .reg .u32 %r33; .reg .u64 %r34; .reg .u32 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .pred %r44; .reg .u32 %r45; .reg .pred %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .pred %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; mov.u64 %r34,%ar0; .loc 1 272 0 ld.u32 %r32,[%r34]; .loc 1 274 0 and.b32 %r35,%r32,7; setp.eq.u32 %r36,%r35,0; @ %r36 bra $L43; .loc 1 276 0 and.b32 %r37,%r32,1; setp.ne.u32 %r38,%r37,0; @ %r38 bra $L51; .loc 1 278 0 and.b32 %r39,%r32,2; setp.eq.u32 %r40,%r39,0; @ %r40 bra $L45; .loc 1 280 0 shr.u32 %r41,%r32,1; st.u32 [%r34],%r41; .loc 1 281 0 mov.u32 %r33,1; bra $L42; $L45: .loc 1 283 0 shr.u32 %r42,%r32,2; st.u32 [%r34],%r42; .loc 1 284 0 mov.u32 %r33,2; bra $L42; $L43: .loc 1 287 0 and.b32 %r43,%r32,65535; setp.ne.u32 %r44,%r43,0; @ %r44 bra $L52; .loc 1 290 0 shr.u32 %r32,%r32,16; .loc 1 289 0 mov.u32 %r33,16; bra $L46; $L52: .loc 1 286 0 mov.u32 %r33,%r35; $L46: .loc 1 292 0 and.b32 %r45,%r32,255; setp.ne.u32 %r46,%r45,0; @ %r46 bra $L47; .loc 1 294 0 add.u32 %r33,%r33,8; .loc 1 295 0 shr.u32 %r32,%r32,8; $L47: .loc 1 297 0 and.b32 %r47,%r32,15; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L48; .loc 1 299 0 add.u32 %r33,%r33,4; .loc 1 300 0 shr.u32 %r32,%r32,4; $L48: .loc 1 302 0 and.b32 %r49,%r32,3; setp.ne.u32 %r50,%r49,0; @ %r50 bra $L49; .loc 1 304 0 add.u32 %r33,%r33,2; .loc 1 305 0 shr.u32 %r32,%r32,2; $L49: .loc 1 307 0 and.b32 %r51,%r32,1; setp.ne.u32 %r52,%r51,0; @ %r52 bra $L50; .loc 1 310 0 shr.u32 %r32,%r32,1; .loc 1 311 0 setp.eq.u32 %r53,%r32,0; @ %r53 bra $L53; .loc 1 309 0 add.u32 %r33,%r33,1; $L50: .loc 1 314 0 st.u32 [%r34],%r32; .loc 1 315 0 bra $L42; $L51: .loc 1 277 0 mov.u32 %r33,0; bra $L42; $L53: .loc 1 312 0 mov.u32 %r33,32; $L42: .loc 1 316 0 mov.u32 %value,%r33; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __i2b .visible .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r27; .reg .u64 %r28; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; .loc 1 323 0 mov.u32 %r27,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r27; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } .loc 1 324 0 st.u32 [%r28+24],%r25; .loc 1 325 0 st.u32 [%r28+20],%r27; .loc 1 327 0 mov.u64 %value,%r28; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __multiply .visible .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r28; .reg .u32 %r29; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r41; .reg .u32 %r62; .reg .u32 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u64 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r94; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .pred %r101; .reg .u32 %r102; .reg .pred %r103; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .pred %r109; .reg .u32 %r110; .reg .pred %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .pred %r116; .reg .pred %r117; .reg .u32 %r118; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r124; .reg .u32 %r125; .reg .u32 %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .pred %r130; .reg .pred %r131; .reg .u32 %r132; .reg .u32 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .u32 %r138; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u32 %r145; .reg .pred %r146; .reg .pred %r147; .reg .pred %r148; .reg .u32 %r149; .reg .pred %r150; .reg .pred %r151; .reg .u32 %r152; .reg .pred %r153; .reg .u32 %r155; mov.u64 %r96,%ar0; mov.u64 %r97,%ar1; mov.u64 %r98,%ar2; .loc 1 340 0 ld.u32 %r28,[%r97+20]; ld.u32 %r29,[%r98+20]; setp.ge.s32 %r101,%r28,%r29; @ %r101 bra $L56; mov.u32 %r99,%r28; mov.u32 %r28,%r29; mov.u32 %r29,%r99; mov.u64 %r100,%r97; mov.u64 %r97,%r98; mov.u64 %r98,%r100; $L56: .loc 1 346 0 ld.u32 %r67,[%r97+8]; .loc 1 349 0 add.u32 %r79,%r28,%r29; .loc 1 350 0 ld.u32 %r102,[%r97+12]; setp.ge.s32 %r103,%r102,%r79; @ %r103 bra $L57; .loc 1 351 0 add.u32 %r67,%r67,1; $L57: .loc 1 352 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r96; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r67; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r106,[%value_in]; } .loc 1 353 0 add.u64 %r89,%r106,24; cvt.s64.s32 %r107,%r79; shl.b64 %r108,%r107,2; add.u64 %r74,%r89,%r108; setp.ge.u64 %r109,%r89,%r74; @ %r109 bra $L58; mov.u64 %r90,%r89; .loc 1 354 0 mov.u32 %r110,0; $L59: st.u32 [%r90],%r110; .loc 1 353 0 add.u64 %r90,%r90,4; setp.gt.u64 %r111,%r74,%r90; @ %r111 bra $L59; $L58: .loc 1 355 0 add.u64 %r75,%r97,24; .loc 1 356 0 cvt.s64.s32 %r112,%r28; shl.b64 %r113,%r112,2; add.u64 %r76,%r75,%r113; .loc 1 357 0 add.u64 %r88,%r98,24; .loc 1 358 0 cvt.s64.s32 %r114,%r29; shl.b64 %r115,%r114,2; add.u64 %r77,%r88,%r115; .loc 1 361 0 setp.ge.u64 %r116,%r88,%r77; @ %r116 bra $L60; .loc 1 367 0 mov.u32 %r155,0; $L65: .loc 1 363 0 ld.u32 %r37,[%r88]; and.b32 %r80,%r37,65535; setp.eq.u32 %r117,%r80,0; @ %r117 bra $L61; mov.u64 %r91,%r89; .loc 1 365 0 mov.u64 %r70,%r75; .loc 1 367 0 mov.u32 %r68,%r155; $L62: mov.u64 %r71,%r91; .loc 1 370 0 ld.u32 %r38,[%r70]; ld.u32 %r41,[%r91]; and.b32 %r118,%r38,65535; and.b32 %r120,%r41,65535; mad.lo.u32 %r121,%r118,%r80,%r120; add.u32 %r81,%r121,%r68; .loc 1 372 0 add.u64 %r70,%r70,4; shr.u32 %r122,%r38,16; shr.u32 %r124,%r41,16; mad.lo.u32 %r125,%r122,%r80,%r124; .loc 1 371 0 shr.u32 %r126,%r81,16; .loc 1 372 0 add.u32 %r83,%r125,%r126; .loc 1 373 0 shr.u32 %r68,%r83,16; .loc 1 374 0 shl.b32 %r127,%r83,16; and.b32 %r128,%r81,65535; or.b32 %r129,%r127,%r128; st.u32 [%r91],%r129; add.u64 %r91,%r91,4; .loc 1 376 0 setp.gt.u64 %r130,%r76,%r70; @ %r130 bra $L62; .loc 1 377 0 st.u32 [%r71+4],%r68; ld.u32 %r37,[%r88]; $L61: .loc 1 379 0 shr.u32 %r84,%r37,16; setp.eq.u32 %r131,%r84,0; @ %r131 bra $L63; .loc 1 384 0 ld.u32 %r73,[%r89]; mov.u64 %r94,%r75; mov.u32 %r62,%r73; mov.u64 %r72,%r89; .loc 1 383 0 mov.u32 %r69,%r155; bra $L64; $L68: mov.u64 %r72,%r87; $L64: .loc 1 387 0 ld.u16 %r132,[%r94]; shr.u32 %r135,%r62,16; mad.lo.u32 %r136,%r132,%r84,%r135; add.u32 %r85,%r136,%r69; .loc 1 389 0 add.u64 %r87,%r72,4; shl.b32 %r137,%r85,16; and.b32 %r138,%r73,65535; or.b32 %r139,%r137,%r138; st.u32 [%r72],%r139; .loc 1 390 0 ld.u32 %r62,[%r87]; ld.u32 %r141,[%r94]; shr.u32 %r140,%r141,16; and.b32 %r143,%r62,65535; mad.lo.u32 %r144,%r140,%r84,%r143; .loc 1 388 0 shr.u32 %r145,%r85,16; .loc 1 390 0 add.u32 %r73,%r144,%r145; .loc 1 391 0 shr.u32 %r69,%r73,16; add.u64 %r94,%r94,4; .loc 1 393 0 setp.gt.u64 %r146,%r76,%r94; @ %r146 bra $L68; .loc 1 394 0 st.u32 [%r72+4],%r73; $L63: .loc 1 361 0 add.u64 %r88,%r88,4; add.u64 %r89,%r89,4; setp.gt.u64 %r147,%r77,%r88; @ %r147 bra $L65; $L60: .loc 1 416 0 setp.le.s32 %r148,%r79,0; @ %r148 bra $L66; add.u64 %r78,%r74,-4; ld.u32 %r149,[%r74+-4]; setp.ne.u32 %r150,%r149,0; @ %r150 bra $L66; $L67: add.u32 %r79,%r79,-1; setp.eq.u32 %r151,%r79,0; @ %r151 bra $L66; add.u64 %r78,%r78,-4; ld.u32 %r152,[%r78]; setp.eq.u32 %r153,%r152,0; @ %r153 bra $L67; $L66: .loc 1 417 0 st.u32 [%r106+20],%r79; .loc 1 419 0 mov.u64 %value,%r106; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __pow5mult .visible .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r25; .reg .u32 %r26; .reg .u64 %r27; .reg .u64 %r29; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u32 %r43; .reg .u32 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .pred %r51; .reg .pred %r52; .reg .u32 %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .u64 %r58; .reg .u32 %r59; .reg .pred %r60; .reg .u64 %r64; .reg .pred %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .pred %r70; .reg .u64 %r74; .reg .u64 %r75; mov.u64 %r37,%ar0; mov.u64 %r38,%ar1; mov.u32 %r39,%ar2; .loc 1 429 0 and.b32 %r26,%r39,3; setp.eq.u32 %r40,%r26,0; @ %r40 bra $L84; .loc 1 430 0 cvta.const.u64 %r45,p05$2582; add.u32 %r46,%r26,-1; cvt.s64.s32 %r47,%r46; shl.b64 %r48,%r47,2; add.u64 %r49,%r45,%r48; mov.u32 %r44,0; ld.u32 %r43,[%r49]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r38; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r43; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r44; call (%value_in),__multadd,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r50,[%value_in]; } mov.u64 %r38,%r50; $L84: .loc 1 432 0 shr.s32 %r25,%r39,2; setp.eq.u32 %r51,%r25,0; @ %r51 bra $L90; .loc 1 435 0 ld.u64 %r27,[%r37+112]; setp.ne.u64 %r52,%r27,0; @ %r52 bra $L86; .loc 1 323 0 mov.u32 %r54,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r54; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r55,[%value_in]; } mov.u64 %r27,%r55; .loc 1 324 0 mov.u32 %r56,625; st.u32 [%r27+24],%r56; .loc 1 325 0 st.u32 [%r27+20],%r54; .loc 1 438 0 st.u64 [%r37+112],%r27; .loc 1 439 0 mov.u64 %r58,0; st.u64 [%r27],%r58; $L86: .loc 1 424 0 mov.u64 %r36,%r38; bra $L87; $L89: mov.u64 %r27,%r29; $L87: .loc 1 443 0 and.b32 %r59,%r25,1; setp.eq.u32 %r60,%r59,0; @ %r60 bra $L88; .loc 1 445 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r36; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r64,[%value_in]; } .loc 1 139 0 setp.eq.u64 %r65,%r36,0; @ %r65 bra $L91; .loc 1 141 0 ld.s32 %r66,[%r36+8]; shl.b64 %r67,%r66,3; ld.u64 %r68,[%r37+120]; add.u64 %r34,%r68,%r67; ld.u64 %r35,[%r34]; st.u64 [%r36],%r35; .loc 1 142 0 st.u64 [%r34],%r36; .loc 1 447 0 mov.u64 %r36,%r64; bra $L88; $L91: mov.u64 %r36,%r64; $L88: .loc 1 449 0 shr.s32 %r25,%r25,1; setp.eq.u32 %r69,%r25,0; @ %r69 bra $L83; .loc 1 451 0 ld.u64 %r29,[%r27]; setp.ne.u64 %r70,%r29,0; @ %r70 bra $L89; .loc 1 453 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r37; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r74,[%value_in]; } mov.u64 %r29,%r74; st.u64 [%r27],%r29; .loc 1 454 0 mov.u64 %r75,0; st.u64 [%r74],%r75; bra $L89; $L90: .loc 1 433 0 mov.u64 %r36,%r38; $L83: .loc 1 459 0 mov.u64 %value,%r36; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __lshift .visible .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u32 %r26; .reg .u64 %r33; .reg .u32 %r36; .reg .u32 %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u64 %r42; .reg .u32 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r58; .reg .u64 %r61; .reg .u64 %r65; .reg .u64 %r69; .reg .u64 %r71; .reg .u64 %r73; .reg .u64 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .pred %r77; .reg .pred %r79; .reg .u64 %r82; .reg .pred %r83; .reg .u32 %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u32 %r87; .reg .pred %r88; .reg .u64 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .pred %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; .reg .u32 %r97; .reg .u32 %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .u32 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; mov.u64 %r73,%ar0; mov.u64 %r74,%ar1; mov.u32 %r75,%ar2; .loc 1 469 0 shr.s32 %r43,%r75,5; .loc 1 473 0 ld.u32 %r48,[%r74+8]; .loc 1 474 0 ld.u32 %r76,[%r74+20]; add.u32 %r26,%r43,%r76; add.u32 %r39,%r26,1; .loc 1 475 0 ld.u32 %r49,[%r74+12]; setp.le.s32 %r77,%r39,%r49; @ %r77 bra $L102; $L103: .loc 1 476 0 add.u32 %r48,%r48,1; .loc 1 475 0 add.u32 %r49,%r49,%r49; setp.gt.s32 %r79,%r39,%r49; @ %r79 bra $L103; $L102: .loc 1 477 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r73; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r48; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r82,[%value_in]; } .loc 1 478 0 add.u64 %r56,%r82,24; .loc 1 479 0 setp.le.s32 %r83,%r43,0; @ %r83 bra $L104; mov.u64 %r65,%r56; add.u32 %r84,%r43,-1; cvt.u64.u32 %r69,%r84; shl.b64 %r85,%r69,2; add.u64 %r86,%r85,4; add.u64 %r71,%r86,%r56; .loc 1 480 0 mov.u32 %r87,0; $L105: st.u32 [%r65],%r87; add.u64 %r65,%r65,4; .loc 1 479 0 setp.ne.u64 %r88,%r65,%r71; @ %r88 bra $L105; add.u64 %r89,%r69,1; shl.b64 %r90,%r89,2; add.u64 %r56,%r56,%r90; $L104: .loc 1 481 0 add.u64 %r44,%r74,24; .loc 1 482 0 ld.s32 %r91,[%r74+20]; shl.b64 %r92,%r91,2; add.u64 %r45,%r44,%r92; .loc 1 484 0 and.b32 %r46,%r75,31; setp.eq.u32 %r93,%r46,0; @ %r93 bra $L106; .loc 1 486 0 mov.u32 %r94,32; sub.u32 %r47,%r94,%r46; mov.u64 %r58,%r44; mov.u64 %r42,%r56; .loc 1 487 0 mov.u32 %r41,0; $L107: mov.u64 %r40,%r42; .loc 1 490 0 ld.u32 %r96,[%r58]; shl.b32 %r95,%r96,%r46; or.b32 %r97,%r95,%r41; st.u32 [%r42],%r97; .loc 1 491 0 ld.u32 %r98,[%r58]; shr.u32 %r41,%r98,%r47; add.u64 %r58,%r58,4; add.u64 %r42,%r42,4; .loc 1 493 0 setp.gt.u64 %r99,%r45,%r58; @ %r99 bra $L107; .loc 1 494 0 st.u32 [%r40+4],%r41; setp.eq.u32 %r100,%r41,0; @ %r100 bra $L108; .loc 1 495 0 add.u32 %r39,%r26,2; bra $L108; $L106: mov.u64 %r33,%r44; mov.u64 %r61,%r56; $L109: .loc 1 514 0 ld.u32 %r36,[%r33]; st.u32 [%r61],%r36; add.u64 %r33,%r33,4; add.u64 %r61,%r61,4; .loc 1 515 0 setp.gt.u64 %r101,%r45,%r33; @ %r101 bra $L109; $L108: .loc 1 516 0 add.u32 %r102,%r39,-1; st.u32 [%r82+20],%r102; .loc 1 141 0 ld.s32 %r103,[%r74+8]; shl.b64 %r104,%r103,3; ld.u64 %r105,[%r73+120]; add.u64 %r54,%r105,%r104; ld.u64 %r55,[%r54]; st.u64 [%r74],%r55; .loc 1 142 0 st.u64 [%r54],%r74; .loc 1 519 0 mov.u64 %value,%r82; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __mcmp .visible .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r29; .reg .u64 %r30; .reg .u32 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .pred %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; mov.u64 %r33,%ar0; mov.u64 %r34,%ar1; .loc 1 527 0 ld.u32 %r28,[%r33+20]; .loc 1 528 0 ld.u32 %r29,[%r34+20]; .loc 1 535 0 sub.u32 %r32,%r28,%r29; setp.ne.u32 %r35,%r32,0; @ %r35 bra $L117; .loc 1 537 0 add.u64 %r30,%r33,24; .loc 1 538 0 cvt.s64.s32 %r36,%r29; shl.b64 %r23,%r36,2; add.u64 %r26,%r30,%r23; .loc 1 539 0 add.u64 %r37,%r34,24; .loc 1 540 0 add.u64 %r27,%r37,%r23; $L120: .loc 1 543 0 add.u64 %r26,%r26,-4; ld.u32 %r24,[%r26]; add.u64 %r27,%r27,-4; ld.u32 %r25,[%r27]; setp.eq.u32 %r38,%r24,%r25; @ %r38 bra $L119; .loc 1 544 0 setp.lt.u32 %r39,%r24,%r25; selp.u32 %r32,-1,1,%r39; bra $L117; $L119: .loc 1 545 0 setp.lt.u64 %r40,%r30,%r26; @ %r40 bra $L120; $L117: .loc 1 549 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __mdiff .visible .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r30; .reg .u32 %r32; .reg .u32 %r44; .reg .u32 %r54; .reg .u32 %r56; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u64 %r61; .reg .u64 %r63; .reg .u32 %r65; .reg .u64 %r67; .reg .u32 %r68; .reg .u64 %r69; .reg .u32 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .u32 %r74; .reg .u64 %r76; .reg .u64 %r77; .reg .u32 %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u64 %r82; .reg .u64 %r86; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .pred %r103; .reg .u64 %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .u32 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u32 %r118; .reg .u32 %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u32 %r124; .reg .pred %r125; .reg .pred %r126; .reg .u32 %r127; .reg .u32 %r128; .reg .u32 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r137; .reg .u64 %r138; .reg .pred %r139; .reg .u32 %r140; .reg .pred %r141; .reg .u32 %r144; .reg .u64 %r145; .reg .u32 %r146; .reg .pred %r148; mov.u64 %r96,%ar0; mov.u64 %r97,%ar1; mov.u64 %r98,%ar2; .loc 1 527 0 ld.u32 %r60,[%r97+20]; .loc 1 528 0 ld.u32 %r74,[%r98+20]; .loc 1 535 0 sub.u32 %r56,%r60,%r74; add.u64 %r94,%r97,24; add.u64 %r58,%r98,24; setp.ne.u32 %r103,%r56,0; @ %r103 bra $L124; .loc 1 538 0 cvt.s64.s32 %r104,%r74; shl.b64 %r76,%r104,2; add.u64 %r77,%r94,%r76; .loc 1 540 0 add.u64 %r79,%r58,%r76; $L128: .loc 1 543 0 add.u64 %r77,%r77,-4; ld.u32 %r78,[%r77]; add.u64 %r79,%r79,-4; ld.u32 %r80,[%r79]; setp.eq.u32 %r105,%r78,%r80; @ %r105 bra $L125; .loc 1 544 0 setp.ge.u32 %r106,%r78,%r80; @ %r106 bra $L126; mov.u64 %r101,%r94; mov.u64 %r94,%r58; mov.u64 %r58,%r101; mov.u64 %r102,%r97; mov.u64 %r97,%r98; mov.u64 %r98,%r102; .loc 1 576 0 mov.u32 %r56,1; bra $L126; $L125: .loc 1 545 0 setp.le.u64 %r107,%r77,%r94; @ ! %r107 bra $L128; bra $L127; $L136: .loc 1 579 0 mov.u32 %r56,0; $L126: .loc 1 580 0 ld.u32 %r110,[%r97+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r96; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r110; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r111,[%value_in]; } mov.u64 %r95,%r111; .loc 1 581 0 st.u32 [%r111+16],%r56; .loc 1 582 0 ld.u32 %r70,[%r97+20]; .loc 1 584 0 cvt.s64.s32 %r112,%r70; shl.b64 %r113,%r112,2; add.u64 %r61,%r94,%r113; .loc 1 587 0 ld.s32 %r114,[%r98+20]; shl.b64 %r115,%r114,2; add.u64 %r63,%r58,%r115; .loc 1 588 0 add.u64 %r59,%r111,24; .loc 1 589 0 mov.u32 %r57,0; bra $L129; $L135: .loc 1 596 0 mov.u64 %r94,%r67; $L129: .loc 1 593 0 ld.u32 %r30,[%r94]; ld.u32 %r32,[%r58]; and.b32 %r116,%r30,65535; add.u32 %r117,%r116,%r57; and.b32 %r118,%r32,65535; sub.u32 %r65,%r117,%r118; .loc 1 596 0 add.u64 %r67,%r94,4; add.u64 %r58,%r58,4; shr.u32 %r119,%r30,16; shr.u32 %r120,%r32,16; sub.u32 %r121,%r119,%r120; .loc 1 594 0 shr.s32 %r122,%r65,16; .loc 1 596 0 add.u32 %r68,%r121,%r122; .loc 1 597 0 shr.s32 %r57,%r68,16; add.u64 %r86,%r59,4; mov.u64 %r82,%r86; .loc 1 599 0 shl.b32 %r123,%r68,16; and.b32 %r124,%r65,65535; or.b32 %r54,%r123,%r124; st.u32 [%r59],%r54; mov.u64 %r59,%r86; .loc 1 601 0 setp.gt.u64 %r125,%r63,%r58; @ %r125 bra $L135; .loc 1 602 0 setp.le.u64 %r126,%r61,%r67; @ %r126 bra $L130; $L131: .loc 1 604 0 ld.u32 %r44,[%r67]; and.b32 %r127,%r44,65535; add.u32 %r71,%r127,%r57; .loc 1 607 0 add.u64 %r67,%r67,4; shr.u32 %r128,%r44,16; .loc 1 605 0 shr.s32 %r129,%r71,16; .loc 1 607 0 add.u32 %r73,%r128,%r129; .loc 1 608 0 shr.s32 %r57,%r73,16; .loc 1 610 0 shl.b32 %r130,%r73,16; and.b32 %r131,%r71,65535; or.b32 %r54,%r130,%r131; st.u32 [%r86],%r54; add.u64 %r86,%r86,4; .loc 1 602 0 setp.gt.u64 %r132,%r61,%r67; @ %r132 bra $L131; sub.u64 %r134,%r61,%r94; add.u64 %r135,%r134,-5; and.b64 %r137,%r135,-4; add.u64 %r138,%r137,4; add.u64 %r82,%r82,%r138; $L130: .loc 1 629 0 add.u64 %r69,%r82,-4; setp.ne.u32 %r139,%r54,0; @ %r139 bra $L132; $L133: .loc 1 630 0 add.u32 %r70,%r70,-1; .loc 1 629 0 add.u64 %r69,%r69,-4; ld.u32 %r140,[%r69]; setp.eq.u32 %r141,%r140,0; @ %r141 bra $L133; $L132: .loc 1 631 0 st.u32 [%r111+20],%r70; .loc 1 632 0 bra $L123; $L127: .loc 1 566 0 mov.u32 %r144,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r96; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r144; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r145,[%value_in]; } mov.u64 %r95,%r145; .loc 1 567 0 mov.u32 %r146,1; st.u32 [%r95+20],%r146; .loc 1 568 0 st.u32 [%r95+24],%r144; .loc 1 569 0 bra $L123; $L124: .loc 1 571 0 setp.ge.s32 %r148,%r56,0; @ %r148 bra $L136; mov.u64 %r99,%r94; mov.u64 %r94,%r58; mov.u64 %r58,%r99; mov.u64 %r100,%r97; mov.u64 %r97,%r98; mov.u64 %r98,%r100; .loc 1 576 0 mov.u32 %r56,1; bra $L126; $L123: .loc 1 633 0 mov.u64 %value,%r95; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ulp .visible .func (.param .f64 %value_out) __ulp (.param .f64 %in_ar0) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .u32 %r24; .reg .u32 %r29; .reg .u32 %r31; .reg .u32 %r32; .reg .u64 %r34; .reg .f64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .pred %r41; .reg .u64 %r42; .reg .pred %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u64 %r50; .reg .pred %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u64 %r60; .reg .u64 %r61; mov.f64 %r36,%ar0; .loc 1 643 0 mov.b64 %r37,%r36; shr.u64 %r38,%r37,32; cvt.u32.u64 %r40,%r38; and.b32 %r39,%r40,2146435072; add.u32 %r23,%r39,-54525952; .loc 1 645 0 setp.le.s32 %r41,%r23,0; @ %r41 bra $L141; .loc 1 651 0 cvt.u64.u32 %r42,%r23; .loc 1 653 0 shl.b64 %r34,%r42,32; bra $L142; $L141: .loc 1 660 0 neg.s32 %r24,%r23; shr.s32 %r31,%r24,20; .loc 1 661 0 setp.gt.s32 %r47,%r31,19; @ %r47 bra $L143; .loc 1 663 0 mov.u32 %r49,524288; shr.s32 %r48,%r49,%r31; cvt.u64.u32 %r50,%r48; .loc 1 665 0 shl.b64 %r34,%r50,32; bra $L142; $L143: .loc 1 670 0 mov.u64 %r34,0; .loc 1 671 0 add.u32 %r32,%r31,-20; .loc 1 673 0 setp.gt.s32 %r56,%r32,30; @ %r56 bra $L145; mov.u32 %r58,31; sub.u32 %r57,%r58,%r32; mov.u32 %r59,1; shl.b32 %r29,%r59,%r57; bra $L144; $L145: mov.u32 %r29,1; $L144: cvt.u64.u32 %r60,%r29; and.b64 %r61,%r34,-4294967296; or.b64 %r34,%r61,%r60; $L142: .loc 1 678 0 mov.b64 %value,%r34; .loc 1 679 0 st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __b2d .visible .func (.param .f64 %value_out) __b2d (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r26; .reg .u32 %r33; .reg .u32 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u32 %r44; .reg .u32 %r47; .reg .u32 %r48; .reg .u64 %r53; .reg .f64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .u32 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u64 %r67; .reg .pred %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .pred %r79; .reg .pred %r80; .reg .u32 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r90; .reg .pred %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u32 %r97; .reg .u64 %r98; .reg .u64 %r102; .reg .u64 %r103; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .pred %r112; mov.u64 %r55,%ar0; mov.u64 %r56,%ar1; .loc 1 695 0 add.u64 %r38,%r55,24; .loc 1 696 0 ld.s32 %r57,[%r55+20]; shl.b64 %r58,%r57,2; add.u64 %r39,%r38,%r58; .loc 1 697 0 add.u64 %r40,%r39,-4; ld.u32 %r41,[%r39+-4]; .loc 1 702 0 { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r41; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r60,[%value_in]; } .loc 1 703 0 mov.u32 %r62,32; sub.u32 %r61,%r62,%r60; st.u32 [%r56],%r61; .loc 1 705 0 setp.gt.s32 %r63,%r60,10; @ %r63 bra $L147; .loc 1 707 0 mov.u32 %r64,11; sub.u32 %r26,%r64,%r60; shr.u32 %r65,%r41,%r26; or.b32 %r66,%r65,1072693248; cvt.u64.u32 %r67,%r66; shl.b64 %r53,%r67,32; .loc 1 708 0 setp.ge.u64 %r71,%r38,%r40; @ %r71 bra $L154; ld.u32 %r72,[%r39+-8]; shr.u32 %r48,%r72,%r26; bra $L148; $L154: mov.u32 %r48,0; $L148: .loc 1 710 0 add.u32 %r73,%r60,21; shl.b32 %r74,%r41,%r73; or.b32 %r75,%r74,%r48; cvt.u64.u32 %r76,%r75; and.b64 %r77,%r53,-4294967296; or.b64 %r53,%r77,%r76; .loc 1 712 0 bra $L149; $L147: add.u32 %r37,%r60,-11; .loc 1 714 0 setp.ge.u64 %r79,%r38,%r40; @ %r79 bra $L150; ld.u32 %r44,[%r39+-8]; .loc 1 715 0 setp.eq.u32 %r80,%r37,0; @ %r80 bra $L151; .loc 1 717 0 sub.u32 %r33,%r62,%r37; shl.b32 %r82,%r41,%r37; or.b32 %r83,%r82,1072693248; shr.u32 %r84,%r44,%r33; or.b32 %r85,%r83,%r84; cvt.u64.u32 %r86,%r85; shl.b64 %r53,%r86,32; shl.b32 %r47,%r44,%r37; .loc 1 714 0 add.u64 %r90,%r39,-8; .loc 1 718 0 setp.ge.u64 %r91,%r38,%r90; @ %r91 bra $L152; ld.u32 %r93,[%r39+-12]; shr.u32 %r92,%r93,%r33; or.b32 %r47,%r47,%r92; $L152: .loc 1 720 0 cvt.u64.u32 %r94,%r47; and.b64 %r95,%r53,-4294967296; or.b64 %r53,%r95,%r94; bra $L149; $L151: .loc 1 725 0 or.b32 %r97,%r41,1072693248; cvt.u64.u32 %r98,%r97; .loc 1 727 0 cvt.u64.u32 %r102,%r44; shl.b64 %r103,%r98,32; or.b64 %r53,%r103,%r102; $L149: .loc 1 755 0 mov.b64 %r54,%r53; bra $L158; $L153: .loc 1 717 0 shl.b32 %r106,%r41,%r37; or.b32 %r107,%r106,1072693248; cvt.u64.u32 %r108,%r107; shl.b64 %r53,%r108,32; mov.u32 %r47,0; bra $L152; $L150: .loc 1 715 0 setp.ne.u32 %r112,%r37,0; @ %r112 bra $L153; .loc 1 714 0 mov.u32 %r44,%r37; bra $L151; $L158: .loc 1 756 0 mov.f64 %value,%r54; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __d2b .visible .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r22; .reg .u32 %r23; .reg .u32 %r25; .reg .u32 %r30; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r50; .reg .u32 %r51; .reg .u64 %r54; .reg .f64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u32 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .pred %r64; .reg .u32 %r65; .reg .u64 %r66; .reg .pred %r67; .reg .u64 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u32 %r77; .reg .pred %r78; .reg .u32 %r80; .reg .u32 %r81; .reg .u32 %r82; .reg .pred %r83; .reg .u32 %r84; .reg .u32 %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .u32 %r89; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u32 %r94; .reg .u32 %r95; .reg .u32 %r96; mov.u64 %r54,%ar0; mov.f64 %r55,%ar1; mov.u64 %r56,%ar2; mov.u64 %r57,%ar3; .loc 1 785 0 mov.u32 %r59,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r54; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r59; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r60,[%value_in]; } mov.b64 %r61,%r55; shr.u64 %r62,%r61,32; cvt.u32.u64 %r51,%r62; .loc 1 791 0 and.b32 %r22,%r51,1048575; .loc 1 799 0 shr.u32 %r63,%r51,20; and.b32 %r23,%r63,2047; setp.ne.u32 %r64,%r23,0; @ %r64 bra $L160; .loc 1 791 0 st.u32 [%frame],%r22; bra $L161; $L160: .loc 1 800 0 or.b32 %r65,%r22,1048576; st.u32 [%frame],%r65; $L161: mov.b64 %r66,%r55; cvt.u32.u64 %r50,%r66; .loc 1 804 0 setp.eq.u32 %r67,%r50,0; @ %r67 bra $L162; .loc 1 806 0 st.u32 [%frame+4],%r50; .loc 1 807 0 add.u64 %r69,%frame,4; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r69; call (%value_in),__lo0bits,(%out_arg1); ld.param.u32 %r70,[%value_in]; } mov.u32 %r46,%r70; .loc 1 808 0 setp.eq.u32 %r71,%r46,0; @ %r71 bra $L163; .loc 1 810 0 ld.u32 %r25,[%frame]; mov.u32 %r73,32; sub.u32 %r72,%r73,%r46; shl.b32 %r74,%r25,%r72; ld.u32 %r76,[%frame+4]; or.b32 %r75,%r74,%r76; st.u32 [%r60+24],%r75; .loc 1 811 0 shr.u32 %r30,%r25,%r46; st.u32 [%frame],%r30; bra $L164; $L163: .loc 1 814 0 ld.u32 %r77,[%frame+4]; st.u32 [%r60+24],%r77; ld.u32 %r30,[%frame]; $L164: .loc 1 815 0 st.u32 [%r60+28],%r30; setp.eq.u32 %r78,%r30,0; selp.u32 %r45,1,2,%r78; st.u32 [%r60+20],%r45; bra $L166; $L162: .loc 1 824 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; call (%value_in),__lo0bits,(%out_arg1); ld.param.u32 %r80,[%value_in]; } .loc 1 825 0 ld.u32 %r81,[%frame]; st.u32 [%r60+24],%r81; .loc 1 826 0 mov.u32 %r82,1; st.u32 [%r60+20],%r82; .loc 1 828 0 add.u32 %r46,%r80,32; .loc 1 826 0 mov.u32 %r45,%r82; $L166: .loc 1 886 0 setp.eq.u32 %r83,%r23,0; @ %r83 bra $L167; .loc 1 893 0 add.u32 %r84,%r23,-1075; add.u32 %r85,%r84,%r46; st.u32 [%r56],%r85; .loc 1 894 0 mov.u32 %r87,53; sub.u32 %r86,%r87,%r46; st.u32 [%r57],%r86; bra $L159; $L167: .loc 1 900 0 add.u32 %r88,%r46,-1074; st.u32 [%r56],%r88; .loc 1 902 0 cvt.s64.s32 %r90,%r45; shl.b64 %r91,%r90,2; add.u64 %r92,%r60,%r91; ld.u32 %r89,[%r92+20]; { .param .u32 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r89; call (%value_in),__hi0bits,(%out_arg1); ld.param.u32 %r94,[%value_in]; } shl.b32 %r95,%r45,5; sub.u32 %r96,%r95,%r94; st.u32 [%r57],%r96; $L159: .loc 1 909 0 mov.u64 %value,%r60; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __ratio .visible .func (.param .f64 %value_out) __ratio (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .f64 %r22; .reg .u32 %r35; .reg .f64 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r47; .reg .f64 %r48; .reg .f64 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u64 %r62; .reg .u32 %r63; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .u32 %r70; .reg .u64 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; mov.u64 %r43,%ar0; mov.u64 %r44,%ar1; .loc 1 920 0 add.u64 %r47,%frame,4; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r43; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r47; call (%value_in),__b2d,(%out_arg1,%out_arg2); ld.param.f64 %r48,[%value_in]; } mov.f64 %r39,%r48; mov.b64 %r40,%r39; .loc 1 921 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r44; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; call (%value_in),__b2d,(%out_arg1,%out_arg2); ld.param.f64 %r51,[%value_in]; } mov.f64 %r22,%r51; mov.b64 %r41,%r22; .loc 1 923 0 ld.u32 %r53,[%r43+20]; ld.u32 %r54,[%r44+20]; sub.u32 %r52,%r53,%r54; shl.b32 %r55,%r52,5; ld.u32 %r57,[%frame+4]; ld.u32 %r58,[%frame]; sub.u32 %r56,%r57,%r58; add.u32 %r35,%r55,%r56; .loc 1 942 0 setp.le.s32 %r59,%r35,0; @ %r59 bra $L171; .loc 1 943 0 shl.b32 %r60,%r35,20; shr.u64 %r62,%r40,32; cvt.u32.u64 %r64,%r62; add.u32 %r63,%r60,%r64; cvt.u64.u32 %r65,%r63; shl.b64 %r66,%r65,32; and.b64 %r67,%r40,4294967295; or.b64 %r68,%r67,%r66; mov.b64 %r39,%r68; bra $L172; $L171: .loc 1 947 0 shl.b32 %r70,%r35,20; shr.u64 %r73,%r41,32; cvt.u32.u64 %r75,%r73; sub.u32 %r74,%r75,%r70; cvt.u64.u32 %r76,%r74; shl.b64 %r77,%r76,32; and.b64 %r78,%r41,4294967295; or.b64 %r79,%r78,%r77; mov.b64 %r22,%r79; $L172: .loc 1 950 0 div.rn.f64 %value,%r39,%r22; .loc 1 951 0 st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _mprec_log10 .visible .func (.param .f64 %value_out) _mprec_log10 (.param .u32 %in_ar0) { .reg .f64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .f64 %r24; .reg .u32 %r25; .reg .pred %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .pred %r31; mov.u32 %r25,%ar0; .loc 1 983 0 setp.gt.s32 %r26,%r25,23; @ %r26 bra $L176; .loc 1 984 0 cvta.const.u64 %r27,__mprec_tens; cvt.s64.s32 %r28,%r25; shl.b64 %r29,%r28,3; add.u64 %r30,%r27,%r29; ld.f64 %r24,[%r30]; bra $L173; $L176: .loc 1 982 0 mov.f64 %r24,0d3ff0000000000000; $L174: .loc 1 987 0 mul.f64 %r24,%r24,0d4024000000000000; .loc 1 988 0 add.u32 %r25,%r25,-1; .loc 1 985 0 setp.ne.u32 %r31,%r25,0; @ %r31 bra $L174; $L173: .loc 1 991 0 mov.f64 %value,%r24; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __copybits .visible .func __copybits (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r30; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .pred %r60; .reg .pred %r61; .reg .u64 %r63; .reg .u64 %r65; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .u32 %r70; .reg .pred %r71; mov.u64 %r50,%ar0; mov.u32 %r51,%ar1; mov.u64 %r52,%ar2; .loc 1 1004 0 add.u32 %r53,%r51,-1; shr.s32 %r54,%r53,5; cvt.s64.s32 %r55,%r54; add.u64 %r56,%r55,1; shl.b64 %r57,%r56,2; add.u64 %r35,%r50,%r57; .loc 1 1005 0 add.u64 %r36,%r52,24; .loc 1 1007 0 ld.s32 %r58,[%r52+20]; shl.b64 %r59,%r58,2; add.u64 %r37,%r36,%r59; .loc 1 1008 0 setp.ge.u64 %r60,%r36,%r37; @ %r60 bra $L179; mov.u64 %r45,%r50; mov.u64 %r46,%r36; $L180: .loc 1 1009 0 ld.u32 %r30,[%r46]; st.u32 [%r45],%r30; add.u64 %r45,%r45,4; add.u64 %r46,%r46,4; .loc 1 1008 0 setp.gt.u64 %r61,%r37,%r46; @ %r61 bra $L180; sub.u64 %r63,%r37,%r52; add.u64 %r65,%r63,-25; and.b64 %r67,%r65,-4; add.u64 %r68,%r67,4; add.u64 %r50,%r50,%r68; $L179: .loc 1 1018 0 setp.le.u64 %r69,%r35,%r50; @ %r69 bra $L178; mov.u64 %r34,%r50; .loc 1 1019 0 mov.u32 %r70,0; $L182: st.u32 [%r34],%r70; add.u64 %r34,%r34,4; .loc 1 1018 0 setp.gt.u64 %r71,%r35,%r34; @ %r71 bra $L182; $L178: .loc 1 1020 0 ret; } // BEGIN GLOBAL FUNCTION DEF: __any_on .visible .func (.param .u32 %value_out) __any_on (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .u32 %r27; .reg .u32 %r28; .reg .u64 %r30; .reg .u64 %r33; .reg .u32 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .pred %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .pred %r44; .reg .pred %r45; .reg .u32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .u32 %r50; .reg .pred %r51; .reg .pred %r52; mov.u64 %r37,%ar0; mov.u32 %r38,%ar1; .loc 1 1030 0 add.u64 %r23,%r37,24; .loc 1 1031 0 ld.u32 %r24,[%r37+20]; .loc 1 1032 0 shr.s32 %r25,%r38,5; .loc 1 1033 0 setp.ge.s32 %r39,%r24,%r25; @ %r39 bra $L186; cvt.s64.s32 %r40,%r24; shl.b64 %r41,%r40,2; add.u64 %r33,%r23,%r41; bra $L187; $L186: cvt.s64.s32 %r42,%r25; shl.b64 %r43,%r42,2; add.u64 %r33,%r23,%r43; .loc 1 1035 0 setp.le.s32 %r44,%r24,%r25; @ %r44 bra $L187; and.b32 %r26,%r38,31; setp.eq.u32 %r45,%r26,0; @ %r45 bra $L187; .loc 1 1036 0 ld.u32 %r27,[%r33]; .loc 1 1037 0 shr.u32 %r28,%r27,%r26; .loc 1 1038 0 shl.b32 %r46,%r28,%r26; .loc 1 1039 0 setp.ne.u32 %r47,%r27,%r46; @ %r47 bra $L191; $L187: .loc 1 1044 0 setp.ge.u64 %r48,%r23,%r33; @ %r48 bra $L192; .loc 1 1045 0 add.u64 %r30,%r33,-4; ld.u32 %r36,[%r33+-4]; setp.ne.u32 %r49,%r36,0; @ ! %r49 bra $L189; bra $L193; $L190: add.u64 %r30,%r30,-4; ld.u32 %r50,[%r30]; setp.ne.u32 %r51,%r50,0; @ %r51 bra $L194; $L189: .loc 1 1044 0 setp.lt.u64 %r52,%r23,%r30; @ %r52 bra $L190; bra $L185; $L191: .loc 1 1040 0 mov.u32 %r36,1; bra $L185; $L192: .loc 1 1047 0 mov.u32 %r36,0; bra $L185; $L193: .loc 1 1040 0 mov.u32 %r36,1; bra $L185; $L194: mov.u32 %r36,1; $L185: .loc 1 1048 0 mov.u32 %value,%r36; st.param.u32 [%value_out],%value; ret; } lib_a-mrand48.o/0 0 0 644 1738 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _mrand48_r .visible .func (.param .u64 %value_out) _mrand48_r (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/mrand48.c" // BEGIN GLOBAL FUNCTION DECL: mrand48 .visible .func (.param .u64 %value_out) mrand48; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _mrand48_r .visible .func (.param .u64 %value_out) _mrand48_r (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r29; .reg .u64 %r32; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; mov.u64 %r29,%ar0; .loc 1 21 0 add.u64 %r32,%r29,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r32; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r34,[%r29+244]; shl.b64 %r35,%r34,16; ld.u16 %r36,[%r29+242]; add.u64 %value,%r35,%r36; .loc 1 23 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: mrand48 .visible .func (.param .u64 %value_out) mrand48 { .reg .u64 %value; .reg .u64 %r22; .reg .u64 %r32; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .loc 1 29 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 21 0 add.u64 %r32,%r22,240; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r22; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r32; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r34,[%r22+244]; shl.b64 %r35,%r34,16; ld.u16 %r36,[%r22+242]; add.u64 %value,%r35,%r36; .loc 1 30 0 st.param.u64 [%value_out],%value; ret; } /158 0 0 0 644 19834 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: nl_langinfo .visible .func (.param .u64 %value_out) nl_langinfo (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/locale/nl_langinfo.c" // BEGIN GLOBAL FUNCTION DECL: setlocale .extern .func (.param .u64 %value_out) setlocale (.param .u32 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strncmp .extern .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __nvptx_realloc .extern .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strstr .extern .func (.param .u64 %value_out) strstr (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __get_current_time_locale .extern .func (.param .u64 %value_out) __get_current_time_locale; // BEGIN GLOBAL FUNCTION DECL: __get_current_numeric_locale .extern .func (.param .u64 %value_out) __get_current_numeric_locale; // BEGIN GLOBAL FUNCTION DECL: __get_current_messages_locale .extern .func (.param .u64 %value_out) __get_current_messages_locale; // BEGIN GLOBAL FUNCTION DECL: __get_current_monetary_locale .extern .func (.param .u64 %value_out) __get_current_monetary_locale; // BEGIN GLOBAL FUNCTION DECL: localeconv .extern .func (.param .u64 %value_out) localeconv; // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strcat .extern .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[6] = {122,104,95,67,78,0 }; // BEGIN VAR DEF: cset$2276 .global .align 8 .u64 cset$2276[1]; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[1] = {0 }; // BEGIN VAR DEF: csym$2275 .global .align 8 .u64 csym$2275[1]; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[6] = {65,83,67,73,73,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[2] = {67,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[6] = {80,79,83,73,88,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[4] = {73,83,79,0 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[6] = {101,117,99,75,82,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[9] = {85,83,45,65,83,67,73,73,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[6] = {101,117,99,74,80,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[6] = {101,117,99,67,78,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[5] = {73,83,79,95,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[4] = {69,85,67,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[6] = {106,97,95,74,80,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[6] = {107,111,95,75,82,0 }; // BEGIN GLOBAL FUNCTION DEF: nl_langinfo .visible .func (.param .u64 %value_out) nl_langinfo (.param .u32 %in_ar0) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %r26; .reg .u32 %r67; .reg .u64 %r75; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r86; .reg .u64 %r87; .reg .u32 %r88; .reg .pred %r89; .reg .pred %r90; .reg .pred %r91; .reg .pred %r92; .reg .pred %r93; .reg .pred %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .pred %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .pred %r113; .reg .pred %r114; .reg .pred %r115; .reg .u32 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .pred %r119; .reg .u32 %r121; .reg .u64 %r122; .reg .pred %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u32 %r127; .reg .pred %r128; .reg .u64 %r130; .reg .u64 %r133; .reg .u32 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .pred %r137; .reg .pred %r138; .reg .u64 %r141; .reg .u32 %r142; .reg .pred %r143; .reg .u64 %r145; .reg .u64 %r146; .reg .u32 %r147; .reg .pred %r148; .reg .u64 %r150; .reg .u32 %r152; .reg .pred %r153; .reg .u64 %r155; .reg .u32 %r157; .reg .pred %r158; .reg .u64 %r160; .reg .u32 %r161; .reg .pred %r162; .reg .u64 %r164; .reg .u32 %r165; .reg .pred %r166; .reg .u64 %r168; .reg .u32 %r169; .reg .pred %r170; .reg .u64 %r172; .reg .u64 %r173; .reg .pred %r174; .reg .u64 %r175; .reg .u64 %r176; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .u32 %r182; .reg .u64 %r183; .reg .u64 %r184; .reg .u64 %r185; .reg .u64 %r186; .reg .u64 %r187; .reg .u32 %r188; .reg .u64 %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .u64 %r193; .reg .u32 %r194; .reg .u64 %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u64 %r198; .reg .u64 %r199; .reg .u32 %r200; .reg .u64 %r201; .reg .u64 %r202; .reg .u64 %r203; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r206; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u64 %r211; .reg .u64 %r212; .reg .u64 %r213; .reg .u64 %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .u16 %r217; .reg .u32 %r218; .reg .pred %r219; .reg .u64 %r220; .reg .u64 %r221; .reg .u16 %r222; .reg .u16 %r223; .reg .pred %r224; .reg .pred %r226; .reg .u64 %r227; .reg .u64 %r230; .reg .u32 %r231; .reg .pred %r232; .reg .pred %r233; .reg .u64 %r235; .reg .u32 %r238; .reg .u32 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .pred %r243; .reg .pred %r244; .reg .u64 %r246; .reg .u64 %r248; .reg .u64 %r250; .reg .u64 %r251; .reg .u64 %r254; .reg .u64 %r255; .reg .u64 %r256; .reg .u32 %r257; .reg .u64 %r260; .reg .u64 %r261; .reg .u64 %r262; mov.u32 %r88,%ar0; .loc 1 195 0 setp.gt.s32 %r89,%r88,44; @ %r89 bra $L3; setp.ge.s32 %r90,%r88,33; @ %r90 bra $L4; setp.eq.u32 %r91,%r88,6; @ %r91 bra $L5; setp.gt.s32 %r92,%r88,6; @ %r92 bra $L6; setp.eq.u32 %r93,%r88,2; @ %r93 bra $L7; setp.gt.s32 %r94,%r88,2; @ %r94 bra $L8; setp.eq.u32 %r95,%r88,0; @ %r95 bra $L9; setp.eq.u32 %r96,%r88,1; @ %r96 bra $L10; bra $L46; $L8: setp.eq.u32 %r97,%r88,4; @ %r97 bra $L11; setp.gt.s32 %r98,%r88,4; @ ! %r98 bra $L66; bra $L12; $L6: setp.gt.s32 %r99,%r88,20; @ %r99 bra $L14; setp.ge.s32 %r100,%r88,14; @ ! %r100 bra $L67; bra $L15; $L3: setp.eq.u32 %r101,%r88,51; @ %r101 bra $L17; setp.gt.s32 %r102,%r88,51; @ %r102 bra $L18; setp.eq.u32 %r103,%r88,47; @ %r103 bra $L19; setp.gt.s32 %r104,%r88,47; @ %r104 bra $L20; setp.eq.u32 %r105,%r88,45; @ %r105 bra $L21; setp.eq.u32 %r106,%r88,46; @ %r106 bra $L22; bra $L46; $L20: setp.eq.u32 %r107,%r88,49; @ %r107 bra $L23; setp.gt.s32 %r108,%r88,49; @ ! %r108 bra $L68; bra $L24; $L18: setp.eq.u32 %r109,%r88,55; @ %r109 bra $L26; setp.gt.s32 %r110,%r88,55; @ %r110 bra $L27; setp.eq.u32 %r111,%r88,53; @ %r111 bra $L28; setp.gt.s32 %r112,%r88,53; @ ! %r112 bra $L69; bra $L29; $L27: setp.eq.u32 %r113,%r88,57; @ %r113 bra $L31; setp.lt.s32 %r114,%r88,57; @ %r114 bra $L32; setp.eq.u32 %r115,%r88,84; @ %r115 bra $L33; bra $L46; $L9: .loc 1 267 0 mov.u64 %r117,0; mov.u32 %r116,2; { .param .u64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r116; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r117; call (%value_in),setlocale,(%out_arg1,%out_arg2); ld.param.u64 %r118,[%value_in]; } setp.ne.u64 %r119,%r118,0; @ %r119 bra $L34; $L41: .loc 1 266 0 cvta.const.u64 %r87,$LC1; bra $L1; $L34: .loc 1 268 0 mov.u32 %r121,46; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r121; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r122,[%value_in]; } setp.eq.u64 %r123,%r122,0; @ %r123 bra $L35; .loc 1 269 0 add.u64 %r87,%r122,1; .loc 1 271 0 mov.u64 %r126,4; cvta.const.u64 %r125,$LC5; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r125; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r126; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r127,[%value_in]; } setp.ne.u32 %r128,%r127,0; @ %r128 bra $L36; .loc 1 272 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r130,[%value_in]; } .loc 1 274 0 cvt.u32.u64 %r134,%r130; cvt.s64.s32 %r133,%r134; ld.global.u64 %r135,[cset$2276]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r135; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r133; call (%value_in),__nvptx_realloc,(%out_arg1,%out_arg2); ld.param.u64 %r136,[%value_in]; } .loc 1 276 0 setp.ne.u64 %r137,%r136,0; @ %r137 bra $L37; ld.global.u64 %r26,[cset$2276]; setp.eq.u64 %r138,%r26,0; @ %r138 bra $L38; .loc 1 277 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call __nvptx_free,(%out_arg1); } bra $L38; $L36: .loc 1 286 0 cvta.const.u64 %r141,$LC6; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r141; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r142,[%value_in]; } setp.ne.u32 %r143,%r142,0; @ %r143 bra $L39; .loc 1 287 0 mov.u64 %r146,5; cvta.const.u64 %r145,$LC7; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r145; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r146; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r147,[%value_in]; } setp.eq.u32 %r148,%r147,0; @ %r148 bra $L47; .loc 1 289 0 cvta.const.u64 %r150,$LC8; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r150; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r146; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r152,[%value_in]; } setp.eq.u32 %r153,%r152,0; @ %r153 bra $L48; .loc 1 291 0 cvta.const.u64 %r155,$LC9; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r155; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r146; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r157,[%value_in]; } setp.ne.u32 %r158,%r157,0; @ %r158 bra $L1; .loc 1 292 0 cvta.const.u64 %r87,$LC4; bra $L1; $L39: .loc 1 293 0 cvta.const.u64 %r160,$LC10; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r87; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r160; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r161,[%value_in]; } setp.ne.u32 %r162,%r161,0; @ %r162 bra $L1; $L40: .loc 1 294 0 cvta.const.u64 %r87,$LC2; bra $L1; $L35: .loc 1 296 0 cvta.const.u64 %r164,$LC11; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r164; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r165,[%value_in]; } setp.eq.u32 %r166,%r165,0; @ %r166 bra $L40; .loc 1 297 0 cvta.const.u64 %r168,$LC12; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r168; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r169,[%value_in]; } .loc 1 296 0 setp.eq.u32 %r170,%r169,0; @ %r170 bra $L40; .loc 1 299 0 cvta.const.u64 %r172,$LC10; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r118; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r172; call (%value_in),strstr,(%out_arg1,%out_arg2); ld.param.u64 %r173,[%value_in]; } setp.ne.u64 %r174,%r173,0; @ %r174 bra $L40; bra $L41; $L10: .loc 1 307 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r175,[%value_in]; } ld.u64 %r87,[%r175+320]; .loc 1 308 0 bra $L1; $L7: .loc 1 310 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r176,[%value_in]; } ld.u64 %r87,[%r176+312]; .loc 1 311 0 bra $L1; $L66: .loc 1 313 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r177,[%value_in]; } ld.u64 %r87,[%r177+304]; .loc 1 314 0 bra $L1; $L11: .loc 1 316 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r178,[%value_in]; } ld.u64 %r87,[%r178+456]; .loc 1 317 0 bra $L1; $L12: .loc 1 319 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r179,[%value_in]; } ld.u64 %r87,[%r179+328]; .loc 1 320 0 bra $L1; $L5: .loc 1 322 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r180,[%value_in]; } ld.u64 %r87,[%r180+336]; .loc 1 323 0 bra $L1; $L67: .loc 1 326 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r181,[%value_in]; } add.u32 %r182,%r88,-7; cvt.s64.s32 %r183,%r182; add.u64 %r184,%r183,31; shl.b64 %r185,%r184,3; add.u64 %r186,%r181,%r185; ld.u64 %r87,[%r186]; .loc 1 327 0 bra $L1; $L15: .loc 1 330 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r187,[%value_in]; } add.u32 %r188,%r88,-14; cvt.s64.s32 %r189,%r188; add.u64 %r190,%r189,24; shl.b64 %r191,%r190,3; add.u64 %r192,%r187,%r191; ld.u64 %r87,[%r192]; .loc 1 331 0 bra $L1; $L14: .loc 1 335 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r193,[%value_in]; } add.u32 %r194,%r88,-21; cvt.s64.s32 %r195,%r194; add.u64 %r196,%r195,12; shl.b64 %r197,%r196,3; add.u64 %r198,%r193,%r197; ld.u64 %r87,[%r198]; .loc 1 336 0 bra $L1; $L4: .loc 1 340 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r199,[%value_in]; } add.u32 %r200,%r88,-33; cvt.s64.s32 %r201,%r200; shl.b64 %r202,%r201,3; add.u64 %r203,%r199,%r202; ld.u64 %r87,[%r203]; .loc 1 341 0 bra $L1; $L21: .loc 1 343 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r204,[%value_in]; } ld.u64 %r87,[%r204+464]; .loc 1 344 0 bra $L1; $L22: .loc 1 346 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r205,[%value_in]; } ld.u64 %r87,[%r205+472]; .loc 1 347 0 bra $L1; $L19: .loc 1 349 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r206,[%value_in]; } ld.u64 %r87,[%r206+480]; .loc 1 350 0 bra $L1; $L68: .loc 1 352 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r207,[%value_in]; } ld.u64 %r87,[%r207+488]; .loc 1 353 0 bra $L1; $L23: .loc 1 355 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r208,[%value_in]; } ld.u64 %r87,[%r208+496]; .loc 1 356 0 bra $L1; $L33: .loc 1 358 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r209,[%value_in]; } ld.u64 %r87,[%r209+344]; .loc 1 359 0 bra $L1; $L24: .loc 1 361 0 { .param .u64 %value_in; call (%value_in),__get_current_numeric_locale; ld.param.u64 %r210,[%value_in]; } ld.u64 %r87,[%r210]; .loc 1 362 0 bra $L1; $L17: .loc 1 364 0 { .param .u64 %value_in; call (%value_in),__get_current_numeric_locale; ld.param.u64 %r211,[%value_in]; } ld.u64 %r87,[%r211+8]; .loc 1 365 0 bra $L1; $L69: .loc 1 367 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r212,[%value_in]; } ld.u64 %r87,[%r212]; .loc 1 368 0 bra $L1; $L28: .loc 1 370 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r213,[%value_in]; } ld.u64 %r87,[%r213+8]; .loc 1 371 0 bra $L1; $L29: .loc 1 378 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r214,[%value_in]; } ld.u64 %r87,[%r214+16]; .loc 1 379 0 bra $L1; $L26: .loc 1 381 0 { .param .u64 %value_in; call (%value_in),__get_current_messages_locale; ld.param.u64 %r215,[%value_in]; } ld.u64 %r87,[%r215+24]; .loc 1 382 0 bra $L1; $L32: .loc 1 385 0 { .param .u64 %value_in; call (%value_in),__get_current_monetary_locale; ld.param.u64 %r216,[%value_in]; } ld.u64 %r78,[%r216+8]; .loc 1 386 0 ld.s8 %r218,[%r78]; cvt.u16.u32 %r217,%r218; setp.eq.u16 %r219,%r217,0; @ %r219 bra $L41; .loc 1 387 0 { .param .u64 %value_in; call (%value_in),localeconv; ld.param.u64 %r220,[%value_in]; } ld.s8 %r79,[%r220+82]; .loc 1 389 0 { .param .u64 %value_in; call (%value_in),localeconv; ld.param.u64 %r221,[%value_in]; } ld.s8 %r67,[%r221+84]; cvt.u16.u32 %r222,%r67; cvt.u16.u32 %r223,%r79; setp.ne.u16 %r224,%r222,%r223; @ %r224 bra $L41; .loc 1 392 0 setp.ne.u16 %r226,%r222,127; @ %r226 bra $L42; .loc 1 393 0 { .param .u64 %value_in; call (%value_in),__get_current_monetary_locale; ld.param.u64 %r227,[%value_in]; } ld.u64 %r230,[%r227+16]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r78; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r230; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r231,[%value_in]; } setp.eq.u32 %r232,%r231,0; @ %r232 bra $L49; bra $L41; $L42: .loc 1 396 0 setp.ne.u32 %r233,%r67,0; selp.u32 %r86,45,43,%r233; bra $L43; $L49: .loc 1 394 0 mov.u32 %r86,46; $L43: .loc 1 398 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r78; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r235,[%value_in]; } .loc 1 400 0 cvt.u32.u64 %r239,%r235; add.u32 %r238,%r239,2; cvt.s64.s32 %r240,%r238; ld.global.u64 %r241,[csym$2275]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r241; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r240; call (%value_in),__nvptx_realloc,(%out_arg1,%out_arg2); ld.param.u64 %r242,[%value_in]; } .loc 1 401 0 setp.ne.u64 %r243,%r242,0; @ %r243 bra $L44; ld.global.u64 %r75,[csym$2275]; setp.eq.u64 %r244,%r75,0; @ %r244 bra $L45; .loc 1 402 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r75; call __nvptx_free,(%out_arg1); } bra $L45; $L31: .loc 1 416 0 { .param .u64 %value_in; call (%value_in),__get_current_time_locale; ld.param.u64 %r246,[%value_in]; } ld.u64 %r87,[%r246+448]; .loc 1 417 0 bra $L1; $L46: .loc 1 432 0 cvta.const.u64 %r87,$LC1; bra $L1; $L47: .loc 1 288 0 cvta.const.u64 %r87,$LC3; bra $L1; $L48: .loc 1 290 0 cvta.const.u64 %r87,$LC0; .loc 1 434 0 bra $L1; $L38: .loc 1 279 0 mov.u64 %r248,0; st.global.u64 [cset$2276],%r248; .loc 1 285 0 cvta.const.u64 %r87,$LC1; bra $L1; $L37: .loc 1 279 0 st.global.u64 [cset$2276],%r136; .loc 1 281 0 cvta.const.u64 %r250,$LC13; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r136; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r250; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r251,[%value_in]; } .loc 1 282 0 add.u64 %r254,%r122,5; ld.global.u64 %r255,[cset$2276]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r255; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r254; call (%value_in),strcat,(%out_arg1,%out_arg2); ld.param.u64 %r256,[%value_in]; } .loc 1 283 0 ld.global.u64 %r87,[cset$2276]; bra $L1; $L44: .loc 1 404 0 st.global.u64 [csym$2275],%r242; .loc 1 407 0 cvt.u32.u32 %r257,%r86; st.u8 [%r242],%r257; .loc 1 408 0 add.u64 %r260,%r242,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r260; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r78; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r261,[%value_in]; } .loc 1 409 0 ld.global.u64 %r87,[csym$2275]; bra $L1; $L45: .loc 1 404 0 mov.u64 %r262,0; st.global.u64 [csym$2275],%r262; .loc 1 384 0 cvta.const.u64 %r87,$LC1; $L1: .loc 1 435 0 mov.u64 %value,%r87; st.param.u64 [%value_out],%value; ret; } lib_a-nrand48.o/0 0 0 644 2164 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _nrand48_r .visible .func (.param .u64 %value_out) _nrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/nrand48.c" // BEGIN GLOBAL FUNCTION DECL: nrand48 .visible .func (.param .u64 %value_out) nrand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __dorand48 .extern .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: _nrand48_r .visible .func (.param .u64 %value_out) _nrand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u64 %r39; .reg .u16 %r40; mov.u64 %r30,%ar0; mov.u64 %r31,%ar1; .loc 1 21 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r30; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r35,[%r31+4]; shl.b64 %r36,%r35,15; .loc 1 23 0 ld.u16 %r37,[%r31+2]; shr.u32 %r38,%r37,1; cvt.u16.u32 %r40,%r38; cvt.u64.u16 %r39,%r40; .loc 1 22 0 add.u64 %value,%r36,%r39; .loc 1 24 0 st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: nrand48 .visible .func (.param .u64 %value_out) nrand48 (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r31; .reg .u64 %r34; .reg .u64 %r36; .reg .u64 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u16 %r41; mov.u64 %r31,%ar0; .loc 1 21 0 ld.global.u64 %r34,[_impure_ptr]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r34; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r31; call __dorand48,(%out_arg1,%out_arg2); } .loc 1 22 0 ld.u16 %r36,[%r31+4]; shl.b64 %r37,%r36,15; .loc 1 23 0 ld.u16 %r38,[%r31+2]; shr.u32 %r39,%r38,1; cvt.u16.u32 %r41,%r39; cvt.u64.u16 %r40,%r41; .loc 1 22 0 add.u64 %value,%r37,%r40; .loc 1 32 0 st.param.u64 [%value_out],%value; ret; } lib_a-printf.o/ 0 0 0 644 1419 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: printf .visible .func (.param .u32 %value_out) printf (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../../newlib/libc/machine/nvptx/printf.c" // BEGIN GLOBAL FUNCTION DECL: vprintf .extern .func (.param .u32 %value_out) vprintf (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_uni .extern .shared .u32 __nvptx_uni[32]; // BEGIN GLOBAL FUNCTION DEF: printf .visible .func (.param .u32 %value_out) printf (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %args; ld.param.u64 %args,[%in_ar1]; .reg .u64 %r24; .reg .u32 %r28; .reg .u32 %r30; .reg .pred %r31; .reg .u64 %r32; { .reg .u32 %ustmp0; .reg .u64 %ustmp1; mov.u32 %ustmp0,%tid.y; mul.wide.u32 %ustmp1,%ustmp0,4; mov.u64 %r32,__nvptx_uni; add.u64 %r32,%r32,%ustmp1; ld.shared.u32 %r30,[%r32]; mov.u32 %ustmp0,%laneid; and.b32 %r30,%r30,%ustmp0; setp.eq.u32 %r31,%r30,%ustmp0; } mov.u64 %r24,%ar0; .loc 1 27 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%args; @ %r31 call (%value_in),vprintf,(%out_arg1,%out_arg2); ld.param.u32 %r28,[%value_in]; } shfl.idx.b32 %r28,%r28,%r30,31; .loc 1 30 0 mov.u32 %value,%r28; st.param.u32 [%value_out],%value; ret; } lib_a-putchar.o/0 0 0 644 2087 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: putchar .visible .func (.param .u32 %value_out) putchar (.param .u32 %in_ar0); .file 1 "../../../../../../../newlib/libc/machine/nvptx/putchar.c" // BEGIN GLOBAL FUNCTION DECL: vprintf .extern .func (.param .u32 %value_out) vprintf (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL VAR DECL: __nvptx_uni .extern .shared .u32 __nvptx_uni[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {37,99,0 }; // BEGIN GLOBAL FUNCTION DEF: putchar .visible .func (.param .u32 %value_out) putchar (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u32 %r31; .reg .pred %r32; .reg .u64 %r33; { .reg .u32 %ustmp0; .reg .u64 %ustmp1; mov.u32 %ustmp0,%tid.y; mul.wide.u32 %ustmp1,%ustmp0,4; mov.u64 %r33,__nvptx_uni; add.u64 %r33,%r33,%ustmp1; ld.shared.u32 %r31,[%r33]; mov.u32 %ustmp0,%laneid; and.b32 %r31,%r31,%ustmp0; setp.eq.u32 %r32,%r31,%ustmp0; } mov.u32 %r25,%ar0; and.b32 %r24,%r25,255; .loc 1 26 0 st.u32 [%frame],%r24; .loc 1 27 0 cvta.const.u64 %r26,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; @ %r32 call (%value_in),vprintf,(%out_arg1,%out_arg2); ld.param.u32 %r28,[%value_in]; } shfl.idx.b32 %r28,%r28,%r31,31; .loc 1 28 0 setp.ge.s32 %r29,%r28,0; .loc 1 29 0 selp.u32 %value,%r24,-1,%r29; .loc 1 31 0 st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-puts.o/ 0 0 0 644 1962 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: puts .visible .func (.param .u32 %value_out) puts (.param .u64 %in_ar0); .file 1 "../../../../../../../newlib/libc/machine/nvptx/puts.c" // BEGIN GLOBAL FUNCTION DECL: vprintf .extern .func (.param .u32 %value_out) vprintf (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL VAR DECL: __nvptx_uni .extern .shared .u32 __nvptx_uni[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {37,115,10,0 }; // BEGIN GLOBAL FUNCTION DEF: puts .visible .func (.param .u32 %value_out) puts (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r26; .reg .u32 %r28; .reg .pred %r29; .reg .u64 %r30; { .reg .u32 %ustmp0; .reg .u64 %ustmp1; mov.u32 %ustmp0,%tid.y; mul.wide.u32 %ustmp1,%ustmp0,4; mov.u64 %r30,__nvptx_uni; add.u64 %r30,%r30,%ustmp1; ld.shared.u32 %r28,[%r30]; mov.u32 %ustmp0,%laneid; and.b32 %r28,%r28,%ustmp0; setp.eq.u32 %r29,%r28,%ustmp0; } mov.u64 %r23,%ar0; .loc 1 25 0 st.u64 [%frame],%r23; .loc 1 26 0 cvta.const.u64 %r24,$LC0; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; @ %r29 call (%value_in),vprintf,(%out_arg1,%out_arg2); ld.param.u32 %r26,[%value_in]; } shfl.idx.b32 %r26,%r26,%r28,31; .loc 1 27 0 mov.u32 %value,%r26; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-rand.o/ 0 0 0 644 1168 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: srand .visible .func srand (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/rand.c" // BEGIN GLOBAL FUNCTION DECL: rand .visible .func (.param .u32 %value_out) rand; // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: srand .visible .func srand (.param .u32 %in_ar0) { .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r24; .reg .u64 %r25; .reg .u64 %r26; mov.u32 %r24,%ar0; .loc 1 78 0 ld.global.u64 %r25,[_impure_ptr]; cvt.u64.u32 %r26,%r24; st.u64 [%r25+232],%r26; .loc 1 79 0 ret; } // BEGIN GLOBAL FUNCTION DEF: rand .visible .func (.param .u32 %value_out) rand { .reg .u32 %value; .reg .u64 %r24; .reg .u64 %r27; .reg .u64 %r30; .reg .u64 %r32; .reg .u32 %r33; .loc 1 84 0 ld.global.u64 %r27,[_impure_ptr]; .loc 1 91 0 ld.u64 %r30,[%r27+232]; mad.lo.u64 %r24,%r30,6364136223846793005,1; .loc 1 90 0 st.u64 [%r27+232],%r24; .loc 1 92 0 shr.u64 %r32,%r24,32; cvt.u32.u64 %r33,%r32; and.b32 %value,%r33,2147483647; .loc 1 93 0 st.param.u32 [%value_out],%value; ret; } lib_a-rand48.o/ 0 0 0 644 1841 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __dorand48 .visible .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/rand48.c" // BEGIN GLOBAL FUNCTION DEF: __dorand48 .visible .func __dorand48 (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .u64 %r23; .reg .u32 %r24; .reg .u64 %r25; .reg .u32 %r30; .reg .u32 %r33; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u64 %r63; .reg .u64 %r64; .reg .u16 %r65; .reg .u64 %r67; .reg .u16 %r68; .reg .u64 %r69; .reg .u64 %r70; .reg .u32 %r71; .reg .u32 %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r77; .reg .u64 %r78; mov.u64 %r58,%ar0; mov.u64 %r59,%ar1; .loc 1 167 0 ld.u16 %r22,[%r58+246]; cvt.u16.u32 %r60,%r22; cvt.u64.u16 %r23,%r60; ld.u16 %r24,[%r59]; cvt.u16.u32 %r61,%r24; cvt.u64.u16 %r25,%r61; .loc 1 168 0 ld.u16 %r63,[%r58+252]; .loc 1 167 0 mad.lo.u64 %r53,%r23,%r25,%r63; .loc 1 170 0 shr.u64 %r54,%r53,16; .loc 1 171 0 ld.u16 %r30,[%r59+2]; .loc 1 172 0 ld.u16 %r33,[%r58+248]; .loc 1 171 0 cvt.u16.u32 %r65,%r30; cvt.u64.u16 %r64,%r65; .loc 1 172 0 cvt.u16.u32 %r68,%r33; cvt.u64.u16 %r67,%r68; mul.lo.u64 %r69,%r67,%r25; .loc 1 171 0 mad.lo.u64 %r70,%r64,%r23,%r69; add.u64 %r55,%r70,%r54; .loc 1 174 0 shr.u64 %r56,%r55,16; .loc 1 175 0 ld.u16 %r71,[%r59+4]; mul.lo.u32 %r73,%r33,%r30; mad.lo.u32 %r74,%r71,%r22,%r73; ld.u16 %r75,[%r58+250]; mad.lo.u32 %r77,%r75,%r24,%r74; cvt.s64.s32 %r78,%r77; add.u64 %r57,%r78,%r56; .loc 1 169 0 st.u16 [%r59],%r53; .loc 1 173 0 st.u16 [%r59+2],%r55; .loc 1 178 0 st.u16 [%r59+4],%r57; .loc 1 179 0 ret; } lib_a-rand_r.o/ 0 0 0 644 1224 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rand_r .visible .func (.param .u32 %value_out) rand_r (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/stdlib/rand_r.c" // BEGIN GLOBAL FUNCTION DEF: rand_r .visible .func (.param .u32 %value_out) rand_r (.param .u64 %in_ar0) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u32 %r32; .reg .u32 %r34; .reg .u64 %r35; .reg .pred %r36; .reg .u64 %r38; .reg .u64 %r39; .reg .pred %r40; mov.u64 %r35,%ar0; .loc 1 28 0 ld.u32 %r28,[%r35]; .loc 1 29 0 setp.eq.u64 %r36,%r28,0; @ %r36 bra $L4; .loc 1 31 0 div.s64 %r29,%r28,127773; .loc 1 32 0 mad.lo.u64 %r38,%r29,-127773,%r28; mul.lo.u64 %r39,%r29,-2836; mad.lo.u64 %r30,%r38,16807,%r39; .loc 1 33 0 setp.lt.s64 %r40,%r30,0; @ %r40 bra $L3; cvt.u32.u64 %r32,%r30; and.b32 %r34,%r32,2147483647; bra $L2; $L3: .loc 1 34 0 add.u64 %r31,%r30,2147483647; cvt.u32.u64 %r32,%r31; and.b32 %r34,%r32,2147483647; bra $L2; $L4: mov.u32 %r34,719435623; mov.u32 %r32,%r34; $L2: .loc 1 35 0 st.u32 [%r35],%r32; .loc 1 37 0 mov.u32 %value,%r34; st.param.u32 [%value_out],%value; ret; } /179 0 0 0 644 2877 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rawmemchr .visible .func (.param .u64 %value_out) rawmemchr (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/string/rawmemchr.c" // BEGIN GLOBAL FUNCTION DEF: rawmemchr .visible .func (.param .u64 %value_out) rawmemchr (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r81; .reg .u64 %r84; .reg .u64 %r90; .reg .u64 %r91; .reg .u32 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r99; .reg .u64 %r107; .reg .u32 %r108; .reg .u32 %r109; .reg .u64 %r110; .reg .pred %r111; .reg .u16 %r112; .reg .u16 %r113; .reg .pred %r114; .reg .u16 %r115; .reg .pred %r117; .reg .u64 %r118; .reg .pred %r119; .reg .u32 %r120; .reg .u32 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .u16 %r130; .reg .u16 %r131; .reg .pred %r132; .reg .u64 %r133; .reg .u64 %r134; .reg .u64 %r135; .reg .u64 %r136; .reg .u64 %r137; .reg .pred %r138; .reg .u16 %r139; .reg .u16 %r140; .reg .pred %r141; .reg .u16 %r143; mov.u64 %r107,%ar0; mov.u32 %r108,%ar1; .loc 1 75 0 cvt.u32.u32 %r109,%r108; cvt.u32.u8 %r93,%r109; .loc 1 82 0 and.b64 %r110,%r107,7; setp.eq.u64 %r111,%r110,0; @ %r111 bra $L2; .loc 1 84 0 ld.u8 %r112,[%r107]; cvt.u16.u32 %r113,%r93; setp.eq.u16 %r114,%r112,%r113; @ %r114 bra $L1; cvt.u16.u32 %r143,%r93; bra $L4; $L5: ld.u8 %r115,[%r107]; setp.eq.u16 %r117,%r115,%r143; @ %r117 bra $L1; $L4: .loc 1 86 0 add.u64 %r107,%r107,1; .loc 1 82 0 and.b64 %r118,%r107,7; setp.ne.u64 %r119,%r118,0; @ %r119 bra $L5; $L2: .loc 1 97 0 shl.b32 %r120,%r108,8; and.b32 %r121,%r120,65535; and.b32 %r122,%r108,255; or.b32 %r123,%r121,%r122; cvt.s64.s32 %r94,%r123; .loc 1 98 0 shl.b64 %r81,%r94,16; or.b64 %r95,%r81,%r94; .loc 1 100 0 shl.b64 %r90,%r95,32; or.b64 %r91,%r90,%r95; .loc 1 104 0 ld.u64 %r124,[%r107]; xor.b64 %r99,%r91,%r124; add.u64 %r125,%r99,-72340172838076673; not.b64 %r126,%r99; and.b64 %r127,%r125,%r126; and.b64 %r128,%r127,-9187201950435737472; setp.eq.u64 %r129,%r128,0; @ %r129 bra $L6; $L8: .loc 1 117 0 ld.u8 %r130,[%r107]; cvt.u16.u32 %r131,%r93; setp.eq.u16 %r132,%r130,%r131; @ %r132 bra $L1; cvt.u16.u32 %r140,%r93; bra $L7; $L6: .loc 1 106 0 add.u64 %r107,%r107,8; .loc 1 104 0 ld.u64 %r133,[%r107]; xor.b64 %r84,%r91,%r133; add.u64 %r134,%r84,-72340172838076673; not.b64 %r135,%r84; and.b64 %r136,%r134,%r135; and.b64 %r137,%r136,-9187201950435737472; setp.ne.u64 %r138,%r137,0; @ ! %r138 bra $L6; bra $L8; $L7: .loc 1 119 0 add.u64 %r107,%r107,1; .loc 1 117 0 ld.u8 %r139,[%r107]; setp.ne.u16 %r141,%r139,%r140; @ %r141 bra $L7; $L1: .loc 1 121 0 mov.u64 %value,%r107; st.param.u64 [%value_out],%value; ret; } lib_a-realloc.o/0 0 0 644 2167 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __nvptx_realloc .visible .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../../newlib/libc/machine/nvptx/realloc.c" // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __nvptx_free .extern .func __nvptx_free (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: __nvptx_realloc .visible .func (.param .u64 %value_out) __nvptx_realloc (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r31; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r36; .reg .u32 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .pred %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u64 %r52; mov.u64 %r28,%ar0; mov.u64 %r29,%ar1; .loc 1 37 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r31,[%value_in]; } .loc 1 39 0 set.u32.ne.u64 %r33,%r28,0; neg.s32 %r34,%r33; set.u32.ne.u64 %r36,%r31,0; neg.s32 %r37,%r36; cvt.u16.u32 %r39,%r34; cvt.u16.u32 %r40,%r37; and.b16 %r38,%r39,%r40; cvt.u32.u16 %r41,%r38; cvt.u16.u8 %r42,%r41; setp.eq.u16 %r43,%r42,0; @ %r43 bra $L1; .loc 1 42 0 ld.u64 %r45,[%r28+-8]; min.u64 %r44,%r29,%r45; .loc 1 43 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r28; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r44; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r52,[%value_in]; } .loc 1 44 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r28; call __nvptx_free,(%out_arg1); } $L1: .loc 1 48 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } /198 0 0 0 644 1867 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _realloc_os_r .visible .func (.param .u64 %value_out) _realloc_os_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../../newlib/libc/machine/nvptx/reallocr.c" // BEGIN GLOBAL FUNCTION DECL: __nvptx_malloc .extern .func (.param .u64 %value_out) __nvptx_malloc (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: _realloc_os_r .visible .func (.param .u64 %value_out) _realloc_os_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .pred %r28; .reg .u64 %r30; .reg .pred %r31; .reg .u64 %r35; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 22 0 setp.ge.u64 %r28,%r27,%r26; @ %r28 bra $L2; .loc 1 24 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),__nvptx_malloc,(%out_arg1); ld.param.u64 %r30,[%value_in]; } .loc 1 25 0 setp.eq.u64 %r31,%r25,0; @ %r31 bra $L3; .loc 1 26 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r30; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r35,[%value_in]; } .loc 1 24 0 mov.u64 %r25,%r30; bra $L2; $L3: mov.u64 %r25,%r30; $L2: .loc 1 29 0 mov.u64 %value,%r25; st.param.u64 [%value_out],%value; ret; } lib_a-reent.o/ 0 0 0 644 4227 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: cleanup_glue .visible .func cleanup_glue (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/reent/reent.c" // BEGIN GLOBAL FUNCTION DECL: _reclaim_reent .visible .func _reclaim_reent (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _free_r .extern .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DEF: errno .visible .global .align 4 .u32 errno[1]; // BEGIN GLOBAL FUNCTION DEF: cleanup_glue .visible .func cleanup_glue (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r22; .reg .u64 %r23; .reg .u64 %r24; .reg .pred %r25; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 38 0 ld.u64 %r22,[%r24]; setp.eq.u64 %r25,%r22,0; @ %r25 bra $L2; .loc 1 39 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r22; call cleanup_glue,(%out_arg1,%out_arg2); } $L2: .loc 1 41 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call _free_r,(%out_arg1,%out_arg2); } .loc 1 42 0 ret; } // BEGIN GLOBAL FUNCTION DEF: _reclaim_reent .visible .func _reclaim_reent (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r26; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .pred %r41; .reg .pred %r42; .reg .u64 %r43; .reg .pred %r44; .reg .pred %r47; .reg .pred %r48; .reg .pred %r51; .reg .pred %r54; .reg .pred %r55; .reg .pred %r58; .reg .pred %r59; .reg .u32 %r62; .reg .pred %r63; .reg .u64 %r65; .reg .pred %r66; mov.u64 %r39,%ar0; .loc 1 48 0 ld.global.u64 %r40,[_impure_ptr]; setp.ne.u64 %r41,%r40,%r39; @ ! %r41 bra $L6; .loc 1 55 0 ld.u64 %r34,[%r39+120]; setp.eq.u64 %r42,%r34,0; @ %r42 bra $L9; mov.u64 %r38,0; $L12: .loc 1 62 0 add.u64 %r43,%r34,%r38; ld.u64 %r26,[%r43]; .loc 1 63 0 setp.eq.u64 %r44,%r26,0; @ %r44 bra $L10; $L11: .loc 1 66 0 ld.u64 %r36,[%r26]; .loc 1 67 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; call _free_r,(%out_arg1,%out_arg2); } mov.u64 %r26,%r36; .loc 1 63 0 setp.ne.u64 %r47,%r26,0; @ %r47 bra $L11; ld.u64 %r34,[%r39+120]; $L10: add.u64 %r38,%r38,8; .loc 1 58 0 setp.ne.u64 %r48,%r38,512; @ %r48 bra $L12; .loc 1 71 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r34; call _free_r,(%out_arg1,%out_arg2); } $L9: .loc 1 73 0 ld.u64 %r28,[%r39+96]; setp.eq.u64 %r51,%r28,0; @ %r51 bra $L13; .loc 1 74 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r28; call _free_r,(%out_arg1,%out_arg2); } $L13: .loc 1 102 0 ld.u64 %r35,[%r39+504]; setp.eq.u64 %r54,%r35,0; @ %r54 bra $L14; add.u64 %r29,%r39,512; setp.eq.u64 %r55,%r35,%r29; @ %r55 bra $L14; $L15: .loc 1 108 0 ld.u64 %r37,[%r35]; .loc 1 109 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r35; call _free_r,(%out_arg1,%out_arg2); } mov.u64 %r35,%r37; .loc 1 105 0 setp.ne.u64 %r58,%r29,%r35; @ %r58 bra $L15; $L14: .loc 1 115 0 ld.u64 %r30,[%r39+136]; setp.eq.u64 %r59,%r30,0; @ %r59 bra $L16; .loc 1 116 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r30; call _free_r,(%out_arg1,%out_arg2); } $L16: .loc 1 123 0 ld.u32 %r62,[%r39+80]; setp.eq.u32 %r63,%r62,0; @ %r63 bra $L6; .loc 1 127 0 ld.u64 %r65,[%r39+88]; { $LCT0: .callprototype _ ( .param .u64 %in_ar0); .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; call %r65,(%out_arg1),$LCT0; } .loc 1 129 0 ld.u64 %r33,[%r39+1312]; setp.eq.u64 %r66,%r33,0; @ %r66 bra $L6; .loc 1 130 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r39; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r33; call cleanup_glue,(%out_arg1,%out_arg2); } $L6: .loc 1 136 0 ret; } lib_a-rindex.o/ 0 0 0 644 1016 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: rindex .visible .func (.param .u64 %value_out) rindex (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/string/rindex.c" // BEGIN GLOBAL FUNCTION DECL: strrchr .extern .func (.param .u64 %value_out) strrchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: rindex .visible .func (.param .u64 %value_out) rindex (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u32 %r24; .reg .u64 %r27; mov.u64 %r23,%ar0; mov.u32 %r24,%ar1; .loc 1 44 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; call (%value_in),strrchr,(%out_arg1,%out_arg2); ld.param.u64 %r27,[%value_in]; } .loc 1 45 0 mov.u64 %value,%r27; st.param.u64 [%value_out],%value; ret; } /216 0 0 0 644 1186 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysign .visible .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %ar1; ld.param.f64 %ar1,[%in_ar1]; .reg .u64 %r27; .reg .f64 %r29; .reg .f64 %r30; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u64 %r42; .reg .u64 %r43; mov.f64 %r29,%ar0; mov.f64 %r30,%ar1; .loc 1 78 0 mov.b64 %r27,%r29; shr.u64 %r32,%r27,32; cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; mov.b64 %r35,%r30; shr.u64 %r36,%r35,32; cvt.u32.u64 %r38,%r36; and.b32 %r37,%r38,-2147483648; or.b32 %r39,%r33,%r37; cvt.u64.u32 %r40,%r39; shl.b64 %r41,%r40,32; and.b64 %r42,%r27,4294967295; or.b64 %r43,%r42,%r41; mov.b64 %value,%r43; .loc 1 80 0 st.param.f64 [%value_out],%value; ret; } /236 0 0 0 644 756 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_finite.c" // BEGIN GLOBAL FUNCTION DEF: finite .visible .func (.param .u32 %value_out) finite (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .f64 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r35; mov.f64 %r29,%ar0; .loc 1 31 0 mov.b64 %r31,%r29; shr.u64 %r32,%r31,32; .loc 1 32 0 cvt.u32.u64 %r34,%r32; and.b32 %r33,%r34,2147483647; add.u32 %r35,%r33,-2146435072; shr.u32 %value,%r35,31; .loc 1 33 0 st.param.u32 [%value_out],%value; ret; } /254 0 0 0 644 1961 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyd .visible .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r32; .reg .f64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u32 %r37; .reg .pred %r38; .reg .u32 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .u16 %r45; .reg .u16 %r46; .reg .u16 %r47; .reg .u32 %r48; .reg .u16 %r49; .reg .pred %r50; .reg .u32 %r51; .reg .pred %r52; .reg .pred %r53; .reg .u32 %r55; .reg .u32 %r56; .reg .u16 %r57; .reg .u16 %r58; .reg .u32 %r60; mov.f64 %r33,%ar0; mov.b64 %r34,%r33; shr.u64 %r35,%r34,32; cvt.u32.u64 %r27,%r35; cvt.u32.u64 %r28,%r34; .loc 1 16 0 or.b32 %r37,%r27,%r28; setp.eq.u32 %r38,%r37,0; @ %r38 bra $L3; .loc 1 17 0 set.u32.eq.u32 %r40,%r28,0; neg.s32 %r41,%r40; cvt.u32.u32 %r39,%r41; set.u32.eq.u32 %r43,%r27,-2147483648; neg.s32 %r44,%r43; cvt.u16.u32 %r46,%r44; cvt.u16.u8 %r47,%r39; and.b16 %r45,%r46,%r47; .loc 1 16 0 cvt.u32.u16 %r48,%r45; cvt.u16.u8 %r49,%r48; setp.ne.u16 %r50,%r49,0; @ %r50 bra $L4; .loc 1 19 0 and.b32 %r30,%r27,2147483647; add.u32 %r51,%r30,-1048576; setp.le.u32 %r52,%r51,2145386495; @ %r52 bra $L5; .loc 1 22 0 setp.le.u32 %r53,%r30,1048575; @ %r53 bra $L6; .loc 1 26 0 set.u32.eq.u32 %r55,%r30,2146435072; neg.s32 %r56,%r55; cvt.u16.u32 %r58,%r56; and.b16 %r57,%r58,%r47; .loc 1 18 0 cvt.u32.u16 %r60,%r57; cvt.u32.u8 %r32,%r60; bra $L1; $L3: mov.u32 %r32,2; bra $L1; $L4: mov.u32 %r32,2; bra $L1; $L5: .loc 1 21 0 mov.u32 %r32,4; bra $L1; $L6: .loc 1 25 0 mov.u32 %r32,3; $L1: .loc 1 31 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-s_frexp.o/0 0 0 644 1959 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/s_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexp .visible .func (.param .f64 %value_out) frexp (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r29; .reg .u32 %r30; .reg .u32 %r35; .reg .u64 %r36; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u64 %r41; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .pred %r47; .reg .pred %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .u32 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; mov.f64 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 98 0 mov.b64 %r40,%r38; shr.u64 %r41,%r40,32; cvt.u32.u64 %r29,%r41; .loc 1 99 0 and.b32 %r30,%r29,2147483647; .loc 1 100 0 mov.u32 %r42,0; st.u32 [%r39],%r42; .loc 1 101 0 setp.gt.s32 %r43,%r30,2146435071; @ %r43 bra $L2; cvt.u32.u64 %r46,%r40; or.b32 %r45,%r30,%r46; setp.eq.u32 %r47,%r45,0; @ %r47 bra $L2; .loc 1 102 0 setp.gt.s32 %r48,%r30,1048575; @ %r48 bra $L4; .loc 1 103 0 mul.f64 %r38,%r38,0d4350000000000000; .loc 1 104 0 mov.b64 %r49,%r38; shr.u64 %r50,%r49,32; cvt.u32.u64 %r29,%r50; .loc 1 105 0 and.b32 %r30,%r29,2147483647; mov.u32 %r35,-54; bra $L3; $L4: mov.u32 %r35,%r42; $L3: .loc 1 108 0 shr.s32 %r51,%r30,20; add.u32 %r52,%r51,-1022; add.u32 %r53,%r52,%r35; st.u32 [%r39],%r53; .loc 1 110 0 mov.b64 %r36,%r38; .loc 1 109 0 and.b32 %r54,%r29,-2146435073; or.b32 %r55,%r54,1071644672; .loc 1 110 0 cvt.u64.u32 %r56,%r55; shl.b64 %r57,%r56,32; and.b64 %r58,%r36,4294967295; or.b64 %r59,%r58,%r57; mov.b64 %r38,%r59; $L2: .loc 1 112 0 mov.f64 %value,%r38; st.param.f64 [%value_out],%value; ret; } /276 0 0 0 644 393 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL VAR DEF: __infinity .visible .const .align 8 .u64 __infinity[1] = {9218868437227405312 }; // END PREAMBLE // BEGIN GLOBAL VAR DEF: __infinityld .visible .const .align 8 .u64 __infinityld[2] = {9218868437227405312 }; // BEGIN GLOBAL VAR DEF: __infinityf .visible .const .align 4 .u32 __infinityf[1] = {2139095040 }; lib_a-s_isinf.o/0 0 0 644 1169 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinf .visible .func (.param .u32 %value_out) isinf (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 22 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 24 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 23 0 and.b32 %r48,%r33,2147483647; .loc 1 24 0 or.b32 %r27,%r47,%r48; .loc 1 25 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 26 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 27 0 st.param.u32 [%value_out],%value; ret; } /296 0 0 0 644 1182 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isinfd.c" // BEGIN GLOBAL FUNCTION DEF: __isinfd .visible .func (.param .u32 %value_out) __isinfd (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r33; .reg .u32 %r34; .reg .u32 %r37; .reg .f64 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u32 %r48; .reg .u32 %r49; .reg .u32 %r51; .reg .u32 %r52; .reg .u32 %r53; .reg .u32 %r54; mov.f64 %r41,%ar0; .loc 1 16 0 mov.b64 %r42,%r41; shr.u64 %r43,%r42,32; cvt.u32.u64 %r33,%r43; cvt.u32.u64 %r34,%r42; .loc 1 18 0 neg.s32 %r45,%r34; or.b32 %r46,%r45,%r34; shr.u32 %r47,%r46,31; .loc 1 17 0 and.b32 %r48,%r33,2147483647; .loc 1 18 0 or.b32 %r27,%r47,%r48; .loc 1 19 0 mov.u32 %r49,2146435072; sub.u32 %r37,%r49,%r27; .loc 1 20 0 neg.s32 %r51,%r37; or.b32 %r52,%r51,%r37; shr.u32 %r53,%r52,31; mov.u32 %r54,1; sub.u32 %value,%r54,%r53; .loc 1 21 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_isnan.o/0 0 0 644 1030 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnan .visible .func (.param .u32 %value_out) isnan (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 199 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 201 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 200 0 and.b32 %r45,%r30,2147483647; .loc 1 201 0 or.b32 %r27,%r44,%r45; .loc 1 202 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 203 0 shr.u32 %value,%r47,31; .loc 1 204 0 st.param.u32 [%value_out],%value; ret; } /314 0 0 0 644 1043 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_isnand.c" // BEGIN GLOBAL FUNCTION DEF: __isnand .visible .func (.param .u32 %value_out) __isnand (.param .f64 %in_ar0) { .reg .u32 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %r27; .reg .u32 %r30; .reg .u32 %r31; .reg .f64 %r38; .reg .u64 %r39; .reg .u64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .u32 %r47; .reg .u32 %r48; mov.f64 %r38,%ar0; .loc 1 115 0 mov.b64 %r39,%r38; shr.u64 %r40,%r39,32; cvt.u32.u64 %r30,%r40; cvt.u32.u64 %r31,%r39; .loc 1 117 0 neg.s32 %r42,%r31; or.b32 %r43,%r42,%r31; shr.u32 %r44,%r43,31; .loc 1 116 0 and.b32 %r45,%r30,2147483647; .loc 1 117 0 or.b32 %r27,%r44,%r45; .loc 1 118 0 mov.u32 %r48,2146435072; sub.u32 %r47,%r48,%r27; .loc 1 119 0 shr.u32 %value,%r47,31; .loc 1 120 0 st.param.u32 [%value_out],%value; ret; } lib_a-s_ldexp.o/0 0 0 644 2587 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/s_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finite .extern .func (.param .u32 %value_out) finite (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbn .extern .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexp .visible .func (.param .f64 %value_out) ldexp (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f64 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f64 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f64 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 75 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f64 %r37,%r32,0d0000000000000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 76 0 { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbn,(%out_arg1,%out_arg2); ld.param.f64 %r50,[%value_in]; } mov.f64 %r32,%r50; .loc 1 77 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),finite,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f64 %r54,%r32,0d0000000000000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 79 0 mov.f64 %value,%r32; st.param.f64 [%value_out],%value; ret; } lib_a-s_modf.o/ 0 0 0 644 3141 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_modf.c" // BEGIN GLOBAL FUNCTION DEF: modf .visible .func (.param .f64 %value_out) modf (.param .f64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r23; .reg .f64 %r32; .reg .u32 %r38; .reg .f64 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .u32 %r45; .reg .f64 %r52; .reg .f64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r58; .reg .pred %r59; .reg .pred %r60; .reg .u32 %r61; .reg .u64 %r62; .reg .u64 %r66; .reg .f64 %r67; .reg .u32 %r68; .reg .u32 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u32 %r72; .reg .u64 %r73; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u64 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u32 %r92; .reg .u32 %r93; .reg .u32 %r94; .reg .pred %r95; .reg .u32 %r96; .reg .u64 %r97; .reg .u64 %r101; .reg .u64 %r102; .reg .u32 %r106; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; mov.f64 %r53,%ar0; mov.u64 %r54,%ar1; mov.b64 %r55,%r53; shr.u64 %r56,%r55,32; cvt.u32.u64 %r38,%r56; cvt.u32.u64 %r44,%r55; .loc 1 92 0 shr.s32 %r58,%r38,20; and.b32 %r23,%r58,2047; add.u32 %r42,%r23,-1023; .loc 1 93 0 setp.gt.s32 %r59,%r42,19; @ %r59 bra $L2; .loc 1 94 0 setp.ge.s32 %r60,%r42,0; @ %r60 bra $L3; .loc 1 95 0 and.b32 %r61,%r38,-2147483648; cvt.u64.u32 %r62,%r61; shl.b64 %r66,%r62,32; mov.b64 %r67,%r66; st.f64 [%r54],%r67; .loc 1 96 0 mov.f64 %r52,%r53; bra $L1; $L3: .loc 1 98 0 mov.u32 %r68,1048575; shr.s32 %r45,%r68,%r42; .loc 1 99 0 and.b32 %r69,%r38,%r45; or.b32 %r70,%r69,%r44; setp.ne.u32 %r71,%r70,0; @ %r71 bra $L5; .loc 1 101 0 st.f64 [%r54],%r53; .loc 1 103 0 and.b32 %r72,%r38,-2147483648; cvt.u64.u32 %r73,%r72; shl.b64 %r77,%r73,32; mov.b64 %r52,%r77; .loc 1 104 0 bra $L1; $L5: .loc 1 106 0 not.b32 %r78,%r45; and.b32 %r79,%r78,%r38; cvt.u64.u32 %r80,%r79; shl.b64 %r84,%r80,32; mov.b64 %r32,%r84; st.f64 [%r54],%r32; .loc 1 107 0 sub.f64 %r52,%r53,%r32; bra $L1; $L2: .loc 1 110 0 setp.le.s32 %r85,%r42,51; @ %r85 bra $L6; .loc 1 112 0 st.f64 [%r54],%r53; .loc 1 114 0 and.b32 %r86,%r38,-2147483648; cvt.u64.u32 %r87,%r86; shl.b64 %r91,%r87,32; mov.b64 %r52,%r91; .loc 1 115 0 bra $L1; $L6: .loc 1 117 0 add.u32 %r92,%r23,-1043; mov.u32 %r93,-1; shr.u32 %r43,%r93,%r92; .loc 1 118 0 and.b32 %r94,%r43,%r44; setp.ne.u32 %r95,%r94,0; @ %r95 bra $L7; .loc 1 120 0 st.f64 [%r54],%r53; .loc 1 122 0 and.b32 %r96,%r38,-2147483648; cvt.u64.u32 %r97,%r96; shl.b64 %r101,%r97,32; mov.b64 %r52,%r101; .loc 1 123 0 bra $L1; $L7: .loc 1 125 0 cvt.u64.u32 %r102,%r38; not.b32 %r106,%r43; and.b32 %r107,%r106,%r44; cvt.u64.u32 %r108,%r107; shl.b64 %r109,%r102,32; or.b64 %r110,%r109,%r108; mov.b64 %r40,%r110; st.f64 [%r54],%r40; .loc 1 126 0 sub.f64 %r52,%r53,%r40; $L1: .loc 1 129 0 mov.f64 %value,%r52; st.param.f64 [%value_out],%value; ret; } lib_a-s_nan.o/ 0 0 0 644 500 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/s_nan.c" // BEGIN GLOBAL FUNCTION DEF: nan .visible .func (.param .f64 %value_out) nan (.param .u64 %in_ar0) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 49 0 mov.f64 %value,0d7ff8000000000000; .loc 1 50 0 st.param.f64 [%value_out],%value; ret; } /332 0 0 0 644 4054 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/s_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysign .extern .func (.param .f64 %value_out) copysign (.param .f64 %in_ar0, .param .f64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbn .visible .func (.param .f64 %value_out) scalbn (.param .f64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .f64 %ar0; ld.param.f64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r41; .reg .u32 %r43; .reg .u32 %r44; .reg .f64 %r46; .reg .u64 %r49; .reg .u64 %r50; .reg .f64 %r51; .reg .f64 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u32 %r67; .reg .u32 %r68; .reg .pred %r69; .reg .f64 %r70; .reg .f64 %r72; .reg .pred %r73; .reg .u32 %r74; .reg .u32 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u64 %r80; .reg .pred %r81; .reg .pred %r82; .reg .f64 %r83; .reg .f64 %r85; .reg .f64 %r86; .reg .f64 %r88; .reg .u32 %r89; .reg .u32 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; mov.f64 %r52,%ar0; mov.u32 %r53,%ar1; .loc 1 86 0 mov.b64 %r54,%r52; shr.u64 %r55,%r54,32; cvt.u32.u64 %r41,%r55; .loc 1 87 0 shr.s32 %r56,%r41,20; and.b32 %r43,%r56,2047; .loc 1 88 0 setp.ne.u32 %r57,%r43,0; @ %r57 bra $L2; .loc 1 89 0 and.b32 %r58,%r41,2147483647; cvt.u32.u64 %r61,%r54; or.b32 %r60,%r58,%r61; setp.eq.u32 %r62,%r60,0; @ %r62 bra $L10; .loc 1 90 0 mul.f64 %r52,%r52,0d4350000000000000; .loc 1 93 0 setp.ge.s32 %r63,%r53,-50000; @ %r63 bra $L4; mul.f64 %r51,%r52,0d01a56e1fc2f8f359; bra $L1; $L2: .loc 1 95 0 setp.ne.u32 %r64,%r43,2047; @ %r64 bra $L5; add.f64 %r51,%r52,%r52; bra $L1; $L4: .loc 1 91 0 mov.b64 %r65,%r52; shr.u64 %r66,%r65,32; cvt.u32.u64 %r41,%r66; .loc 1 92 0 shr.s32 %r67,%r41,20; and.b32 %r68,%r67,2047; add.u32 %r43,%r68,-54; $L5: .loc 1 96 0 add.u32 %r44,%r53,%r43; .loc 1 97 0 setp.le.s32 %r69,%r44,2046; @ %r69 bra $L6; mov.f64 %r70,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r70; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r72,[%value_in]; } mul.f64 %r51,%r72,0d7e37e43c8800759c; bra $L1; $L6: .loc 1 98 0 setp.le.s32 %r73,%r44,0; @ %r73 bra $L7; .loc 1 99 0 mov.b64 %r49,%r52; and.b32 %r74,%r41,-2146435073; shl.b32 %r75,%r44,20; or.b32 %r76,%r74,%r75; cvt.u64.u32 %r77,%r76; shl.b64 %r78,%r77,32; and.b64 %r79,%r49,4294967295; or.b64 %r80,%r79,%r78; mov.b64 %r51,%r80; bra $L1; $L7: .loc 1 100 0 setp.ge.s32 %r81,%r44,-53; @ %r81 bra $L8; .loc 1 101 0 setp.le.s32 %r82,%r53,50000; @ %r82 bra $L9; .loc 1 102 0 mov.f64 %r83,0d7e37e43c8800759c; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r83; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r85,[%value_in]; } mul.f64 %r51,%r85,0d7e37e43c8800759c; bra $L1; $L9: .loc 1 103 0 mov.f64 %r86,0d01a56e1fc2f8f359; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r86; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r52; call (%value_in),copysign,(%out_arg1,%out_arg2); ld.param.f64 %r88,[%value_in]; } mul.f64 %r51,%r88,0d01a56e1fc2f8f359; bra $L1; $L8: .loc 1 106 0 mov.b64 %r50,%r52; .loc 1 105 0 add.u32 %r89,%r44,54; .loc 1 106 0 shl.b32 %r90,%r89,20; and.b32 %r91,%r41,-2146435073; or.b32 %r92,%r90,%r91; cvt.u64.u32 %r93,%r92; shl.b64 %r94,%r93,32; and.b64 %r95,%r50,4294967295; or.b64 %r96,%r95,%r94; mov.b64 %r46,%r96; .loc 1 107 0 mul.f64 %r51,%r46,0d3c90000000000000; bra $L1; $L10: .loc 1 89 0 mov.f64 %r51,%r52; $L1: .loc 1 108 0 mov.f64 %value,%r51; st.param.f64 [%value_out],%value; ret; } lib_a-seed48.o/ 0 0 0 644 2796 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _seed48_r .visible .func (.param .u64 %value_out) _seed48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/seed48.c" // BEGIN GLOBAL FUNCTION DECL: seed48 .visible .func (.param .u64 %value_out) seed48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN VAR DEF: sseed$2019 .global .align 2 .u16 sseed$2019[3]; // BEGIN GLOBAL FUNCTION DEF: _seed48_r .visible .func (.param .u64 %value_out) _seed48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u16 %r32; .reg .u16 %r34; .reg .u16 %r36; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u16 %r41; .reg .u16 %r42; .reg .u16 %r43; mov.u64 %r29,%ar0; mov.u64 %r30,%ar1; .loc 1 24 0 cvta.global.u64 %r31,sseed$2019; ld.u16 %r32,[%r29+240]; st.u16 [%r31],%r32; .loc 1 25 0 ld.u16 %r34,[%r29+242]; st.u16 [%r31+2],%r34; .loc 1 26 0 ld.u16 %r36,[%r29+244]; st.u16 [%r31+4],%r36; .loc 1 27 0 ld.u16 %r37,[%r30]; st.u16 [%r29+240],%r37; .loc 1 28 0 ld.u16 %r38,[%r30+2]; st.u16 [%r29+242],%r38; .loc 1 29 0 ld.u16 %r39,[%r30+4]; st.u16 [%r29+244],%r39; .loc 1 30 0 mov.u16 %r40,-6547; st.u16 [%r29+246],%r40; .loc 1 31 0 mov.u16 %r41,-8468; st.u16 [%r29+248],%r41; .loc 1 32 0 mov.u16 %r42,5; st.u16 [%r29+250],%r42; .loc 1 33 0 mov.u16 %r43,11; st.u16 [%r29+252],%r43; .loc 1 35 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: seed48 .visible .func (.param .u64 %value_out) seed48 (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u64 %r30; .reg .u64 %r31; .reg .u16 %r32; .reg .u16 %r34; .reg .u16 %r36; .reg .u16 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u16 %r40; .reg .u16 %r41; .reg .u16 %r42; .reg .u16 %r43; mov.u64 %r30,%ar0; .loc 1 42 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 24 0 cvta.global.u64 %r31,sseed$2019; ld.u16 %r32,[%r22+240]; st.u16 [%r31],%r32; .loc 1 25 0 ld.u16 %r34,[%r22+242]; st.u16 [%r31+2],%r34; .loc 1 26 0 ld.u16 %r36,[%r22+244]; st.u16 [%r31+4],%r36; .loc 1 27 0 ld.u16 %r37,[%r30]; st.u16 [%r22+240],%r37; .loc 1 28 0 ld.u16 %r38,[%r30+2]; st.u16 [%r22+242],%r38; .loc 1 29 0 ld.u16 %r39,[%r30+4]; st.u16 [%r22+244],%r39; .loc 1 30 0 mov.u16 %r40,-6547; st.u16 [%r22+246],%r40; .loc 1 31 0 mov.u16 %r41,-8468; st.u16 [%r22+248],%r41; .loc 1 32 0 mov.u16 %r42,5; st.u16 [%r22+250],%r42; .loc 1 33 0 mov.u16 %r43,11; st.u16 [%r22+252],%r43; .loc 1 43 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } /350 0 0 0 644 887 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_copysign.c" // BEGIN GLOBAL FUNCTION DEF: copysignf .visible .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .f32 %ar1; ld.param.f32 %ar1,[%in_ar1]; .reg .u32 %r24; .reg .f32 %r28; .reg .f32 %r29; .reg .u32 %r30; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r33; mov.f32 %r28,%ar0; mov.f32 %r29,%ar1; .loc 1 34 0 mov.b32 %r31,%r28; and.b32 %r30,%r31,2147483647; mov.b32 %r33,%r29; and.b32 %r32,%r33,-2147483648; or.b32 %r24,%r30,%r32; .loc 1 35 0 mov.b32 %value,%r24; .loc 1 36 0 st.param.f32 [%value_out],%value; ret; } /371 0 0 0 644 699 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_finite.c" // BEGIN GLOBAL FUNCTION DEF: finitef .visible .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.le.s32 %r31,%r29,2139095039; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /390 0 0 0 644 1176 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_fpclassify.c" // BEGIN GLOBAL FUNCTION DEF: __fpclassifyf .visible .func (.param .u32 %value_out) __fpclassifyf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r26; .reg .u32 %r27; .reg .f32 %r28; .reg .u32 %r29; .reg .pred %r30; .reg .u32 %r31; .reg .pred %r32; .reg .u32 %r33; .reg .pred %r34; .reg .u32 %r36; mov.f32 %r28,%ar0; .loc 1 16 0 mov.b32 %r29,%r28; and.b32 %r26,%r29,2147483647; setp.eq.u32 %r30,%r26,0; @ %r30 bra $L3; .loc 1 18 0 add.u32 %r31,%r26,-8388608; setp.le.u32 %r32,%r31,2130706431; @ %r32 bra $L4; .loc 1 21 0 add.u32 %r33,%r26,-1; setp.le.u32 %r34,%r33,8388606; @ %r34 bra $L5; .loc 1 24 0 set.u32.eq.u32 %r36,%r26,2139095040; neg.s32 %r27,%r36; bra $L1; $L3: .loc 1 17 0 mov.u32 %r27,2; bra $L1; $L4: .loc 1 20 0 mov.u32 %r27,4; bra $L1; $L5: .loc 1 23 0 mov.u32 %r27,3; $L1: .loc 1 28 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } /413 0 0 0 644 1886 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/math/sf_frexp.c" // BEGIN GLOBAL FUNCTION DEF: frexpf .visible .func (.param .f32 %value_out) frexpf (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r31; .reg .u32 %r32; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r45; .reg .u32 %r46; .reg .u16 %r47; .reg .u16 %r48; .reg .u16 %r49; .reg .u32 %r50; .reg .u16 %r51; .reg .pred %r52; .reg .pred %r53; .reg .f32 %r54; .reg .u32 %r55; .reg .u32 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r31,%r38; .loc 1 34 0 and.b32 %r32,%r31,2147483647; .loc 1 35 0 mov.u32 %r40,0; st.u32 [%r39],%r40; .loc 1 36 0 set.u32.gt.s32 %r42,%r32,2139095039; neg.s32 %r43,%r42; set.u32.eq.u32 %r45,%r32,0; neg.s32 %r46,%r45; cvt.u16.u32 %r48,%r43; cvt.u16.u32 %r49,%r46; or.b16 %r47,%r48,%r49; cvt.u32.u16 %r50,%r47; cvt.u16.u8 %r51,%r50; setp.ne.u16 %r52,%r51,0; @ %r52 bra $L4; .loc 1 37 0 setp.gt.s32 %r53,%r32,8388607; @ %r53 bra $L5; .loc 1 38 0 mul.f32 %r54,%r38,0f4c000000; .loc 1 39 0 mov.b32 %r31,%r54; .loc 1 40 0 and.b32 %r32,%r31,2147483647; mov.u32 %r36,-25; bra $L3; $L5: mov.u32 %r36,%r40; $L3: .loc 1 43 0 shr.s32 %r55,%r32,23; add.u32 %r56,%r55,-126; add.u32 %r57,%r56,%r36; st.u32 [%r39],%r57; .loc 1 44 0 and.b32 %r58,%r31,-2139095041; or.b32 %r59,%r58,1056964608; .loc 1 45 0 mov.b32 %r37,%r59; .loc 1 46 0 bra $L1; $L4: .loc 1 36 0 mov.f32 %r37,%r38; $L1: .loc 1 47 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } /431 0 0 0 644 694 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isinf.c" // BEGIN GLOBAL FUNCTION DEF: isinff .visible .func (.param .u32 %value_out) isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 21 0 mov.b32 %r23,%r27; .loc 1 22 0 and.b32 %r29,%r23,2147483647; .loc 1 23 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 24 0 st.param.u32 [%value_out],%value; ret; } /449 0 0 0 644 703 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isinff.c" // BEGIN GLOBAL FUNCTION DEF: __isinff .visible .func (.param .u32 %value_out) __isinff (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 13 0 mov.b32 %r23,%r27; .loc 1 14 0 and.b32 %r29,%r23,2147483647; .loc 1 15 0 set.u32.eq.u32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 16 0 st.param.u32 [%value_out],%value; ret; } /468 0 0 0 644 694 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isnan.c" // BEGIN GLOBAL FUNCTION DEF: isnanf .visible .func (.param .u32 %value_out) isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 31 0 mov.b32 %r23,%r27; .loc 1 32 0 and.b32 %r29,%r23,2147483647; .loc 1 33 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 34 0 st.param.u32 [%value_out],%value; ret; } /486 0 0 0 644 703 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_isnanf.c" // BEGIN GLOBAL FUNCTION DEF: __isnanf .visible .func (.param .u32 %value_out) __isnanf (.param .f32 %in_ar0) { .reg .u32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %r23; .reg .f32 %r27; .reg .u32 %r29; .reg .u32 %r31; mov.f32 %r27,%ar0; .loc 1 23 0 mov.b32 %r23,%r27; .loc 1 24 0 and.b32 %r29,%r23,2147483647; .loc 1 25 0 set.u32.gt.s32 %r31,%r29,2139095040; neg.s32 %value,%r31; .loc 1 26 0 st.param.u32 [%value_out],%value; ret; } /505 0 0 0 644 2583 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/math/sf_ldexp.c" // BEGIN GLOBAL FUNCTION DECL: finitef .extern .func (.param .u32 %value_out) finitef (.param .f32 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: scalbnf .extern .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DEF: ldexpf .visible .func (.param .f32 %value_out) ldexpf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .f32 %r32; .reg .u32 %r33; .reg .u32 %r35; .reg .u32 %r37; .reg .u32 %r38; .reg .u32 %r40; .reg .u32 %r41; .reg .u16 %r42; .reg .u16 %r43; .reg .u16 %r44; .reg .u32 %r45; .reg .u16 %r46; .reg .pred %r47; .reg .f32 %r50; .reg .u32 %r52; .reg .u32 %r54; .reg .u32 %r55; .reg .u32 %r57; .reg .u32 %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .u16 %r63; .reg .pred %r64; .reg .u64 %r65; .reg .u32 %r66; mov.f32 %r32,%ar0; mov.u32 %r33,%ar1; .loc 1 26 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r35,[%value_in]; } set.u32.eq.f32 %r37,%r32,0f00000000; neg.s32 %r38,%r37; set.u32.eq.u32 %r40,%r35,0; neg.s32 %r41,%r40; cvt.u16.u32 %r43,%r38; cvt.u16.u32 %r44,%r41; or.b16 %r42,%r43,%r44; cvt.u32.u16 %r45,%r42; cvt.u16.u8 %r46,%r45; setp.ne.u16 %r47,%r46,0; @ %r47 bra $L2; .loc 1 27 0 { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r33; call (%value_in),scalbnf,(%out_arg1,%out_arg2); ld.param.f32 %r50,[%value_in]; } mov.f32 %r32,%r50; .loc 1 28 0 { .param .u32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r32; call (%value_in),finitef,(%out_arg1); ld.param.u32 %r52,[%value_in]; } set.u32.eq.f32 %r54,%r32,0f00000000; neg.s32 %r55,%r54; set.u32.eq.u32 %r57,%r52,0; neg.s32 %r58,%r57; cvt.u16.u32 %r60,%r55; cvt.u16.u32 %r61,%r58; or.b16 %r59,%r60,%r61; cvt.u32.u16 %r62,%r59; cvt.u16.u8 %r63,%r62; setp.eq.u16 %r64,%r63,0; @ %r64 bra $L2; { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r65,[%value_in]; } mov.u32 %r66,34; st.u32 [%r65],%r66; $L2: .loc 1 30 0 mov.f32 %value,%r32; st.param.f32 [%value_out],%value; ret; } lib_a-sf_modf.o/0 0 0 644 1776 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_modf.c" // BEGIN GLOBAL FUNCTION DEF: modff .visible .func (.param .f32 %value_out) modff (.param .f32 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r31; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r36; .reg .f32 %r37; .reg .f32 %r38; .reg .u64 %r39; .reg .u32 %r40; .reg .u32 %r41; .reg .pred %r42; .reg .pred %r43; .reg .u32 %r44; .reg .f32 %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .pred %r48; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u32 %r52; mov.f32 %r38,%ar0; mov.u64 %r39,%ar1; .loc 1 33 0 mov.b32 %r35,%r38; .loc 1 34 0 shr.s32 %r40,%r35,23; and.b32 %r41,%r40,255; add.u32 %r34,%r41,-127; .loc 1 35 0 setp.gt.s32 %r42,%r34,22; @ %r42 bra $L2; .loc 1 36 0 setp.ge.s32 %r43,%r34,0; @ %r43 bra $L3; .loc 1 37 0 and.b32 %r44,%r35,-2147483648; mov.b32 %r45,%r44; st.f32 [%r39],%r45; .loc 1 38 0 mov.f32 %r37,%r38; bra $L1; $L3: .loc 1 40 0 mov.u32 %r46,8388607; shr.s32 %r36,%r46,%r34; .loc 1 41 0 and.b32 %r47,%r35,%r36; setp.ne.u32 %r48,%r47,0; @ %r48 bra $L5; .loc 1 43 0 st.f32 [%r39],%r38; .loc 1 45 0 and.b32 %r49,%r35,-2147483648; mov.b32 %r37,%r49; .loc 1 46 0 bra $L1; $L5: .loc 1 48 0 not.b32 %r50,%r36; and.b32 %r51,%r50,%r35; mov.b32 %r31,%r51; st.f32 [%r39],%r31; .loc 1 49 0 sub.f32 %r37,%r38,%r31; bra $L1; $L2: .loc 1 54 0 st.f32 [%r39],%r38; .loc 1 56 0 and.b32 %r52,%r35,-2147483648; mov.b32 %r37,%r52; $L1: .loc 1 59 0 mov.f32 %value,%r37; st.param.f32 [%value_out],%value; ret; } lib_a-sf_nan.o/ 0 0 0 644 497 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libm/common/sf_nan.c" // BEGIN GLOBAL FUNCTION DEF: nanf .visible .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .loc 1 17 0 mov.f32 %value,0f7fc00000; .loc 1 18 0 st.param.f32 [%value_out],%value; ret; } /523 0 0 0 644 3414 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libm/common/sf_scalbn.c" // BEGIN GLOBAL FUNCTION DECL: copysignf .extern .func (.param .f32 %value_out) copysignf (.param .f32 %in_ar0, .param .f32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: scalbnf .visible .func (.param .f32 %value_out) scalbnf (.param .f32 %in_ar0, .param .u32 %in_ar1) { .reg .f32 %value; .reg .f32 %ar0; ld.param.f32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r22; .reg .u32 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .f32 %r46; .reg .f32 %r47; .reg .u32 %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .u32 %r53; .reg .u32 %r54; .reg .pred %r55; .reg .f32 %r56; .reg .f32 %r58; .reg .pred %r59; .reg .u32 %r60; .reg .u32 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .pred %r64; .reg .f32 %r65; .reg .f32 %r67; .reg .f32 %r68; .reg .f32 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .u32 %r73; .reg .u32 %r74; .reg .f32 %r75; mov.f32 %r47,%ar0; mov.u32 %r48,%ar1; .loc 1 46 0 mov.b32 %r22,%r47; .loc 1 47 0 and.b32 %r42,%r22,2147483647; .loc 1 49 0 setp.eq.u32 %r49,%r42,0; @ %r49 bra $L11; .loc 1 51 0 setp.le.u32 %r50,%r42,2139095039; @ %r50 bra $L3; .loc 1 52 0 add.f32 %r46,%r47,%r47; bra $L1; $L3: .loc 1 53 0 setp.gt.u32 %r51,%r42,8388607; @ %r51 bra $L4; .loc 1 54 0 mul.f32 %r47,%r47,0f4c000000; .loc 1 57 0 setp.lt.s32 %r52,%r48,-50000; @ %r52 bra $L5; .loc 1 55 0 mov.b32 %r41,%r47; .loc 1 56 0 shr.s32 %r53,%r41,23; and.b32 %r54,%r53,255; add.u32 %r40,%r54,-25; bra $L6; $L5: .loc 1 57 0 mul.f32 %r46,%r47,0f0da24260; bra $L1; $L4: .loc 1 46 0 mov.u32 %r41,%r22; .loc 1 48 0 shr.u32 %r40,%r42,23; $L6: .loc 1 59 0 add.u32 %r43,%r40,%r48; .loc 1 60 0 setp.le.s32 %r55,%r43,254; @ %r55 bra $L7; mov.f32 %r56,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r56; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r58,[%value_in]; } mul.f32 %r46,%r58,0f7149f2ca; bra $L1; $L7: .loc 1 61 0 setp.le.s32 %r59,%r43,0; @ %r59 bra $L8; .loc 1 62 0 and.b32 %r60,%r41,-2139095041; shl.b32 %r61,%r43,23; or.b32 %r62,%r60,%r61; mov.b32 %r46,%r62; bra $L1; $L8: .loc 1 63 0 setp.ge.s32 %r63,%r43,-22; @ %r63 bra $L9; .loc 1 64 0 setp.le.s32 %r64,%r48,50000; @ %r64 bra $L10; .loc 1 65 0 mov.f32 %r65,0f7149f2ca; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r65; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r67,[%value_in]; } mul.f32 %r46,%r67,0f7149f2ca; bra $L1; $L10: .loc 1 66 0 mov.f32 %r68,0f0da24260; { .param .f32 %value_in; .param .f32 %out_arg1; st.param.f32 [%out_arg1],%r68; .param .f32 %out_arg2; st.param.f32 [%out_arg2],%r47; call (%value_in),copysignf,(%out_arg1,%out_arg2); ld.param.f32 %r70,[%value_in]; } mul.f32 %r46,%r70,0f0da24260; bra $L1; $L9: .loc 1 68 0 add.u32 %r71,%r43,25; .loc 1 69 0 shl.b32 %r72,%r71,23; and.b32 %r73,%r41,-2139095041; or.b32 %r74,%r72,%r73; .loc 1 70 0 mov.b32 %r75,%r74; mul.f32 %r46,%r75,0f33000000; bra $L1; $L11: .loc 1 50 0 mov.f32 %r46,%r47; $L1: .loc 1 71 0 mov.f32 %value,%r46; st.param.f32 [%value_out],%value; ret; } /542 0 0 0 644 4133 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _siprintf_r .visible .func (.param .u32 %value_out) _siprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdio/siprintf.c" // BEGIN GLOBAL FUNCTION DECL: siprintf .visible .func (.param .u32 %value_out) siprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfiprintf_r .extern .func (.param .u32 %value_out) _svfiprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: _siprintf_r .visible .func (.param .u32 %value_out) _siprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r22; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r36; .reg .u32 %r37; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; .loc 1 124 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 125 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 132 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfiprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r36,[%value_in]; } .loc 1 134 0 ld.u64 %r22,[%frame]; mov.u32 %r37,0; st.u8 [%r22],%r37; .loc 1 136 0 mov.u32 %value,%r36; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: siprintf .visible .func (.param .u32 %value_out) siprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 157 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 158 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 165 0 ld.global.u64 %r36,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r36; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfiprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r37,[%value_in]; } .loc 1 167 0 ld.u64 %r23,[%frame]; mov.u32 %r38,0; st.u8 [%r23],%r38; .loc 1 169 0 mov.u32 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-siscanf.o/0 0 0 644 5071 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: siscanf .visible .func (.param .u32 %value_out) siscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/stdio/siscanf.c" // BEGIN GLOBAL FUNCTION DECL: _siscanf_r .visible .func (.param .u32 %value_out) _siscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __seofread .extern .func (.param .u32 %value_out) __seofread (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ssvfiscanf_r .extern .func (.param .u32 %value_out) __ssvfiscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: siscanf .visible .func (.param .u32 %value_out) siscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u64 %r41; .reg .u32 %r42; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; .loc 1 135 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 136 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 137 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 138 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 139 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 140 0 st.u64 [%frame+120],%r33; .loc 1 141 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 147 0 ld.global.u64 %r41,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r41; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfiscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r42,[%value_in]; } .loc 1 150 0 mov.u32 %value,%r42; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _siscanf_r .visible .func (.param .u32 %value_out) _siscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u32 %r41; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; mov.u64 %r28,%ar2; .loc 1 173 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 174 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 175 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 176 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 177 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 178 0 st.u64 [%frame+120],%r33; .loc 1 179 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 185 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfiscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r41,[%value_in]; } .loc 1 188 0 mov.u32 %value,%r41; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } /560 0 0 0 644 6960 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _snprintf_r .visible .func (.param .u32 %value_out) _snprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); .file 1 "../../../../../../newlib/libc/stdio/snprintf.c" // BEGIN GLOBAL FUNCTION DECL: snprintf .visible .func (.param .u32 %value_out) snprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: _snprintf_r .visible .func (.param .u32 %value_out) _snprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %args; ld.param.u64 %args,[%in_ar4]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .u16 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .u16 %r38; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r48; .reg .u16 %r50; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r59; mov.u64 %r29,%ar0; mov.u64 %r30,%ar1; mov.u64 %r31,%ar2; mov.u64 %r32,%ar3; .loc 1 52 0 setp.le.u64 %r33,%r31,2147483647; @ %r33 bra $L2; .loc 1 54 0 mov.u32 %r34,139; st.u32 [%r29],%r34; .loc 1 55 0 mov.u32 %r28,-1; bra $L1; $L2: .loc 1 57 0 mov.u16 %r35,520; st.u16 [%frame+16],%r35; .loc 1 58 0 st.u64 [%frame],%r30; st.u64 [%frame+24],%r30; .loc 1 59 0 setp.eq.u64 %r36,%r31,0; @ %r36 bra $L4; cvt.u32.u64 %r37,%r31; add.u32 %r25,%r37,-1; st.u32 [%frame+12],%r25; st.u32 [%frame+32],%r25; .loc 1 60 0 mov.u16 %r38,-1; st.u16 [%frame+18],%r38; .loc 1 66 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r44,[%value_in]; } mov.u32 %r28,%r44; .loc 1 68 0 setp.lt.s32 %r45,%r28,-1; @ %r45 bra $L5; $L7: .loc 1 71 0 ld.u64 %r24,[%frame]; mov.u32 %r46,0; st.u8 [%r24],%r46; bra $L1; $L4: .loc 1 59 0 cvt.u32.u64 %r48,%r31; st.u32 [%frame+12],%r48; st.u32 [%frame+32],%r48; .loc 1 60 0 mov.u16 %r50,-1; st.u16 [%frame+18],%r50; .loc 1 66 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r56,[%value_in]; } mov.u32 %r28,%r56; .loc 1 68 0 setp.lt.s32 %r57,%r28,-1; @ ! %r57 bra $L1; bra $L6; $L5: .loc 1 69 0 mov.u32 %r58,139; st.u32 [%r29],%r58; bra $L7; $L6: mov.u32 %r59,139; st.u32 [%r29],%r59; $L1: .loc 1 73 0 mov.u32 %value,%r28; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: snprintf .visible .func (.param .u32 %value_out) snprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u32 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .pred %r33; .reg .u32 %r34; .reg .u16 %r35; .reg .pred %r36; .reg .u32 %r37; .reg .u16 %r38; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r48; .reg .u16 %r50; .reg .u32 %r56; .reg .pred %r57; .reg .u32 %r58; .reg .u32 %r59; mov.u64 %r30,%ar0; mov.u64 %r31,%ar1; mov.u64 %r32,%ar2; .loc 1 100 0 ld.global.u64 %r25,[_impure_ptr]; .loc 1 102 0 setp.le.u64 %r33,%r31,2147483647; @ %r33 bra $L9; .loc 1 104 0 mov.u32 %r34,139; st.u32 [%r25],%r34; .loc 1 105 0 mov.u32 %r29,-1; bra $L8; $L9: .loc 1 107 0 mov.u16 %r35,520; st.u16 [%frame+16],%r35; .loc 1 108 0 st.u64 [%frame],%r30; st.u64 [%frame+24],%r30; .loc 1 109 0 setp.eq.u64 %r36,%r31,0; @ %r36 bra $L11; cvt.u32.u64 %r37,%r31; add.u32 %r26,%r37,-1; st.u32 [%frame+12],%r26; st.u32 [%frame+32],%r26; .loc 1 110 0 mov.u16 %r38,-1; st.u16 [%frame+18],%r38; .loc 1 116 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r44,[%value_in]; } mov.u32 %r29,%r44; .loc 1 118 0 setp.lt.s32 %r45,%r29,-1; @ %r45 bra $L12; $L14: .loc 1 121 0 ld.u64 %r24,[%frame]; mov.u32 %r46,0; st.u8 [%r24],%r46; bra $L8; $L11: .loc 1 109 0 cvt.u32.u64 %r48,%r31; st.u32 [%frame+12],%r48; st.u32 [%frame+32],%r48; .loc 1 110 0 mov.u16 %r50,-1; st.u16 [%frame+18],%r50; .loc 1 116 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r32; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r56,[%value_in]; } mov.u32 %r29,%r56; .loc 1 118 0 setp.lt.s32 %r57,%r29,-1; @ ! %r57 bra $L8; bra $L13; $L12: .loc 1 119 0 mov.u32 %r58,139; st.u32 [%r25],%r58; bra $L14; $L13: mov.u32 %r59,139; st.u32 [%r25],%r59; $L8: .loc 1 123 0 mov.u32 %value,%r29; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-sprintf.o/0 0 0 644 4120 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _sprintf_r .visible .func (.param .u32 %value_out) _sprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdio/sprintf.c" // BEGIN GLOBAL FUNCTION DECL: sprintf .visible .func (.param .u32 %value_out) sprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: _sprintf_r .visible .func (.param .u32 %value_out) _sprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r22; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r36; .reg .u32 %r37; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; .loc 1 597 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 598 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 605 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r36,[%value_in]; } .loc 1 607 0 ld.u64 %r22,[%frame]; mov.u32 %r37,0; st.u8 [%r22],%r37; .loc 1 609 0 mov.u32 %value,%r36; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: sprintf .visible .func (.param .u32 %value_out) sprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u64 %r36; .reg .u32 %r37; .reg .u32 %r38; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 636 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 637 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 644 0 ld.global.u64 %r36,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r36; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r37,[%value_in]; } .loc 1 646 0 ld.u64 %r23,[%frame]; mov.u32 %r38,0; st.u8 [%r23],%r38; .loc 1 648 0 mov.u32 %value,%r37; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-srand48.o/0 0 0 644 1879 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _srand48_r .visible .func _srand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/srand48.c" // BEGIN GLOBAL FUNCTION DECL: srand48 .visible .func srand48 (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DEF: _srand48_r .visible .func _srand48_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r26; .reg .u64 %r27; .reg .u16 %r28; .reg .u64 %r29; .reg .u16 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 22 0 mov.u16 %r28,13070; st.u16 [%r26+240],%r28; .loc 1 23 0 st.u16 [%r26+242],%r27; .loc 1 24 0 shr.u64 %r29,%r27,16; st.u16 [%r26+244],%r29; .loc 1 25 0 mov.u16 %r30,-6547; st.u16 [%r26+246],%r30; .loc 1 26 0 mov.u16 %r31,-8468; st.u16 [%r26+248],%r31; .loc 1 27 0 mov.u16 %r32,5; st.u16 [%r26+250],%r32; .loc 1 28 0 mov.u16 %r33,11; st.u16 [%r26+252],%r33; .loc 1 29 0 ret; } // BEGIN GLOBAL FUNCTION DEF: srand48 .visible .func srand48 (.param .u64 %in_ar0) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r22; .reg .u64 %r27; .reg .u16 %r28; .reg .u64 %r29; .reg .u16 %r30; .reg .u16 %r31; .reg .u16 %r32; .reg .u16 %r33; mov.u64 %r27,%ar0; .loc 1 36 0 ld.global.u64 %r22,[_impure_ptr]; .loc 1 22 0 mov.u16 %r28,13070; st.u16 [%r22+240],%r28; .loc 1 23 0 st.u16 [%r22+242],%r27; .loc 1 24 0 shr.u64 %r29,%r27,16; st.u16 [%r22+244],%r29; .loc 1 25 0 mov.u16 %r30,-6547; st.u16 [%r22+246],%r30; .loc 1 26 0 mov.u16 %r31,-8468; st.u16 [%r22+248],%r31; .loc 1 27 0 mov.u16 %r32,5; st.u16 [%r22+250],%r32; .loc 1 28 0 mov.u16 %r33,11; st.u16 [%r22+252],%r33; .loc 1 37 0 ret; } lib_a-sscanf.o/ 0 0 0 644 5058 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: sscanf .visible .func (.param .u32 %value_out) sscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/stdio/sscanf.c" // BEGIN GLOBAL FUNCTION DECL: _sscanf_r .visible .func (.param .u32 %value_out) _sscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __seofread .extern .func (.param .u32 %value_out) __seofread (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ssvfscanf_r .extern .func (.param .u32 %value_out) __ssvfscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: sscanf .visible .func (.param .u32 %value_out) sscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %args; ld.param.u64 %args,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u64 %r41; .reg .u32 %r42; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; .loc 1 416 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 417 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 418 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 419 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 420 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 421 0 st.u64 [%frame+120],%r33; .loc 1 422 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 428 0 ld.global.u64 %r41,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r41; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r42,[%value_in]; } .loc 1 431 0 mov.u32 %value,%r42; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _sscanf_r .visible .func (.param .u32 %value_out) _sscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %args; ld.param.u64 %args,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r23; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u32 %r41; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; mov.u64 %r28,%ar2; .loc 1 460 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 461 0 st.u64 [%frame],%r27; st.u64 [%frame+24],%r27; .loc 1 462 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 463 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 464 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 465 0 st.u64 [%frame+120],%r33; .loc 1 466 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 472 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%args; call (%value_in),__ssvfscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r41,[%value_in]; } .loc 1 475 0 mov.u32 %value,%r41; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-stpcpy.o/ 0 0 0 644 1854 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: stpcpy .visible .func (.param .u64 %value_out) stpcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/stpcpy.c" // BEGIN GLOBAL FUNCTION DEF: stpcpy .visible .func (.param .u64 %value_out) stpcpy (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .pred %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .pred %r112; .reg .u32 %r113; .reg .pred %r114; mov.u64 %r98,%ar0; mov.u64 %r99,%ar1; .loc 1 71 0 mov.u64 %r86,%r98; or.b64 %r100,%r99,%r98; and.b64 %r101,%r100,7; setp.ne.u64 %r102,%r101,0; @ %r102 bra $L2; .loc 1 78 0 ld.u64 %r79,[%r99]; add.u64 %r103,%r79,-72340172838076673; not.b64 %r104,%r79; and.b64 %r105,%r103,%r104; and.b64 %r106,%r105,-9187201950435737472; setp.ne.u64 %r107,%r106,0; @ %r107 bra $L2; $L3: .loc 1 80 0 add.u64 %r99,%r99,8; add.u64 %r98,%r98,8; st.u64 [%r86],%r79; .loc 1 78 0 ld.u64 %r79,[%r99]; mov.u64 %r86,%r98; add.u64 %r108,%r79,-72340172838076673; not.b64 %r109,%r79; and.b64 %r110,%r108,%r109; and.b64 %r111,%r110,-9187201950435737472; setp.eq.u64 %r112,%r111,0; @ %r112 bra $L3; $L2: mov.u64 %r94,%r98; mov.u64 %r93,%r99; $L4: mov.u64 %r97,%r94; .loc 1 88 0 ld.s8 %r85,[%r93]; cvt.u32.u32 %r113,%r85; st.u8 [%r94],%r113; add.u64 %r94,%r94,1; add.u64 %r93,%r93,1; setp.ne.u32 %r114,%r85,0; @ %r114 bra $L4; .loc 1 91 0 mov.u64 %value,%r97; st.param.u64 [%value_out],%value; ret; } lib_a-stpncpy.o/0 0 0 644 3245 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: stpncpy .visible .func (.param .u64 %value_out) stpncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/stpncpy.c" // BEGIN GLOBAL FUNCTION DEF: stpncpy .visible .func (.param .u64 %value_out) stpncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r91; .reg .u32 %r92; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u32 %r108; .reg .u32 %r109; .reg .u32 %r111; .reg .u32 %r112; .reg .u16 %r113; .reg .u16 %r114; .reg .u16 %r115; .reg .u32 %r116; .reg .u16 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .pred %r124; .reg .u32 %r125; .reg .pred %r126; .reg .pred %r127; .reg .pred %r128; .reg .pred %r129; .reg .u32 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .pred %r133; mov.u64 %r102,%ar0; mov.u64 %r103,%ar1; mov.u64 %r104,%ar2; .loc 1 83 0 mov.u64 %r100,%r102; or.b64 %r105,%r103,%r102; and.b64 %r106,%r105,7; set.u32.eq.u64 %r108,%r106,0; neg.s32 %r109,%r108; set.u32.gt.u64 %r111,%r104,7; neg.s32 %r112,%r111; cvt.u16.u32 %r114,%r109; cvt.u16.u32 %r115,%r112; and.b16 %r113,%r114,%r115; cvt.u32.u16 %r116,%r113; cvt.u16.u8 %r117,%r116; setp.ne.u16 %r118,%r117,0; @ ! %r118 bra $L3; bra $L2; $L4: .loc 1 92 0 add.u64 %r104,%r104,-8; .loc 1 93 0 add.u64 %r103,%r103,8; add.u64 %r100,%r100,8; mov.u64 %r102,%r100; st.u64 [%r97],%r79; .loc 1 90 0 setp.le.u64 %r119,%r104,7; @ %r119 bra $L3; $L2: mov.u64 %r97,%r100; ld.u64 %r79,[%r103]; add.u64 %r120,%r79,-72340172838076673; not.b64 %r121,%r79; and.b64 %r122,%r120,%r121; and.b64 %r123,%r122,-9187201950435737472; setp.eq.u64 %r124,%r123,0; @ %r124 bra $L4; mov.u64 %r102,%r100; bra $L5; $L7: .loc 1 103 0 add.u64 %r87,%r87,-1; add.u64 %r91,%r91,1; mov.u64 %r89,%r91; .loc 1 104 0 ld.s8 %r85,[%r98]; cvt.u32.u32 %r125,%r85; st.u8 [%r101],%r125; add.u64 %r98,%r98,1; setp.eq.u32 %r126,%r85,0; @ %r126 bra $L6; $L11: mov.u64 %r101,%r91; .loc 1 101 0 setp.ne.u64 %r127,%r87,0; @ %r127 bra $L7; bra $L1; $L14: .loc 1 104 0 mov.u64 %r101,%r102; $L6: .loc 1 111 0 setp.ne.u64 %r128,%r87,0; @ %r128 bra $L9; bra $L1; $L3: .loc 1 101 0 setp.eq.u64 %r129,%r104,0; @ %r129 bra $L13; $L5: .loc 1 103 0 add.u64 %r87,%r104,-1; .loc 1 104 0 add.u64 %r96,%r103,1; add.u64 %r89,%r102,1; ld.s8 %r92,[%r103]; cvt.u32.u32 %r130,%r92; st.u8 [%r102],%r130; setp.eq.u32 %r131,%r92,0; @ %r131 bra $L14; mov.u64 %r91,%r89; mov.u64 %r98,%r96; bra $L11; $L9: mov.u64 %r86,%r89; add.u64 %r88,%r86,%r87; .loc 1 112 0 mov.u32 %r132,0; $L12: st.u8 [%r86],%r132; add.u64 %r86,%r86,1; .loc 1 111 0 setp.ne.u64 %r133,%r88,%r86; @ %r133 bra $L12; bra $L1; $L13: .loc 1 101 0 mov.u64 %r101,%r102; $L1: .loc 1 115 0 mov.u64 %value,%r101; st.param.u64 [%value_out],%value; ret; } /578 0 0 0 644 2079 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcasecmp .visible .func (.param .u32 %value_out) strcasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strcasecmp.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strcasecmp .visible .func (.param .u32 %value_out) strcasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r49; .reg .u32 %r58; .reg .u32 %r62; .reg .u64 %r66; .reg .u64 %r67; .reg .u32 %r69; .reg .u64 %r72; .reg .u32 %r73; .reg .u64 %r74; .reg .u16 %r77; .reg .u16 %r78; .reg .u16 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; .reg .u64 %r85; .reg .u16 %r88; .reg .u16 %r89; .reg .u16 %r90; .reg .u32 %r91; .reg .u32 %r92; .reg .pred %r93; .reg .u32 %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .u16 %r99; .loc 1 54 0 ld.global.u64 %r49,[__ctype_ptr__]; mov.u64 %r67,%ar0; mov.u64 %r66,%ar1; bra $L2; $L6: add.u64 %r67,%r67,1; add.u64 %r66,%r66,1; $L2: ld.u8 %r58,[%r67]; cvt.u32.u32 %r73,%r58; cvt.u64.u8 %r72,%r73; add.u64 %r74,%r49,%r72; ld.u8 %r99,[%r74+1]; mov.u16 %r78,%r99; and.b16 %r77,%r78,3; cvt.u32.u16 %r81,%r77; cvt.s32.s8 %r80,%r81; cvt.u16.u32 %r79,%r80; setp.ne.u16 %r82,%r79,1; @ %r82 bra $L3; add.u32 %r58,%r58,32; $L3: .loc 1 55 0 ld.u8 %r62,[%r66]; cvt.u32.u32 %r84,%r62; cvt.u64.u8 %r83,%r84; add.u64 %r85,%r49,%r83; ld.u8 %r99,[%r85+1]; mov.u16 %r89,%r99; and.b16 %r88,%r89,3; cvt.u32.u16 %r92,%r88; cvt.s32.s8 %r91,%r92; cvt.u16.u32 %r90,%r91; setp.ne.u16 %r93,%r90,1; @ %r93 bra $L4; add.u32 %r94,%r62,32; .loc 1 56 0 sub.u32 %r69,%r58,%r94; setp.ne.u32 %r95,%r69,0; @ ! %r95 bra $L6; bra $L1; $L4: sub.u32 %r69,%r58,%r62; setp.ne.u32 %r96,%r69,0; @ %r96 bra $L1; setp.ne.u32 %r97,%r62,0; @ %r97 bra $L6; $L1: .loc 1 60 0 mov.u32 %value,%r69; st.param.u32 [%value_out],%value; ret; } /598 0 0 0 644 36446 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/str-two-way.h" // BEGIN FUNCTION DECL: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: strcasestr .visible .func (.param .u64 %value_out) strcasestr (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 2 "../../../../../../newlib/libc/string/strcasestr.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DECL: strncasecmp .extern .func (.param .u32 %value_out) strncasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN FUNCTION DEF: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u32 %r30; .reg .u64 %r36; .reg .u64 %r44; .reg .u64 %r49; .reg .u64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u32 %r59; .reg .u32 %r65; .reg .u32 %r70; .reg .u64 %r74; .reg .u64 %r75; .reg .u64 %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r79; .reg .u32 %r80; .reg .u64 %r81; .reg .u16 %r84; .reg .u16 %r85; .reg .u16 %r86; .reg .u32 %r87; .reg .u32 %r88; .reg .pred %r89; .reg .u32 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u32 %r94; .reg .u64 %r95; .reg .u16 %r98; .reg .u16 %r99; .reg .u16 %r100; .reg .u32 %r101; .reg .u32 %r102; .reg .pred %r103; .reg .u32 %r104; .reg .u16 %r105; .reg .u16 %r106; .reg .pred %r107; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .u32 %r115; .reg .u64 %r116; .reg .u16 %r119; .reg .u16 %r120; .reg .u16 %r121; .reg .u32 %r122; .reg .u32 %r123; .reg .pred %r124; .reg .u32 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u32 %r129; .reg .u64 %r130; .reg .u16 %r133; .reg .u16 %r134; .reg .u16 %r135; .reg .u32 %r136; .reg .u32 %r137; .reg .pred %r138; .reg .u32 %r139; .reg .u16 %r140; .reg .u16 %r141; .reg .pred %r142; .reg .pred %r145; .reg .pred %r146; .reg .pred %r147; .reg .pred %r148; .reg .u64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u64 %r153; .reg .u16 %r154; mov.u64 %r75,%ar0; mov.u64 %r76,%ar1; mov.u64 %r77,%ar2; .loc 1 116 0 ld.global.u64 %r23,[__ctype_ptr__]; .loc 1 113 0 mov.u64 %r56,1; mov.u64 %r54,%r56; .loc 1 112 0 mov.u64 %r36,0; .loc 1 111 0 mov.u64 %r52,-1; .loc 1 140 0 mov.u64 %r153,%r56; .loc 1 114 0 bra $L2; $L9: .loc 1 116 0 add.u64 %r78,%r75,%r151; ld.u8 %r57,[%r78]; cvt.u32.u32 %r80,%r57; cvt.u64.u8 %r79,%r80; add.u64 %r81,%r23,%r79; ld.u8 %r154,[%r81+1]; mov.u16 %r85,%r154; and.b16 %r84,%r85,3; cvt.u32.u16 %r88,%r84; cvt.s32.s8 %r87,%r88; cvt.u16.u32 %r86,%r87; setp.ne.u16 %r89,%r86,1; @ %r89 bra $L3; add.u32 %r57,%r57,32; $L3: cvt.u32.u32 %r90,%r57; cvt.u32.u8 %r70,%r90; .loc 1 117 0 add.u64 %r91,%r75,%r52; add.u64 %r92,%r91,%r54; ld.u8 %r58,[%r92]; cvt.u32.u32 %r94,%r58; cvt.u64.u8 %r93,%r94; add.u64 %r95,%r23,%r93; ld.u8 %r154,[%r95+1]; mov.u16 %r99,%r154; and.b16 %r98,%r99,3; cvt.u32.u16 %r102,%r98; cvt.s32.s8 %r101,%r102; cvt.u16.u32 %r100,%r101; setp.ne.u16 %r103,%r100,1; @ %r103 bra $L4; add.u32 %r58,%r58,32; $L4: cvt.u32.u32 %r104,%r58; .loc 1 118 0 cvt.u16.u32 %r105,%r70; cvt.u16.u8 %r106,%r104; setp.ge.u16 %r107,%r105,%r106; @ %r107 bra $L5; .loc 1 123 0 sub.u64 %r56,%r151,%r52; mov.u64 %r36,%r151; .loc 1 122 0 mov.u64 %r54,1; bra $L2; $L5: .loc 1 125 0 setp.ne.u16 %r110,%r105,%r106; @ %r110 bra $L7; .loc 1 128 0 setp.eq.u64 %r111,%r54,%r56; @ %r111 bra $L8; .loc 1 129 0 add.u64 %r54,%r54,1; bra $L2; $L8: .loc 1 132 0 mov.u64 %r36,%r151; .loc 1 133 0 mov.u64 %r54,1; bra $L2; $L7: .loc 1 139 0 mov.u64 %r52,%r36; add.u64 %r36,%r36,1; .loc 1 140 0 mov.u64 %r56,%r153; mov.u64 %r54,1; $L2: .loc 1 114 0 add.u64 %r151,%r36,%r54; setp.lt.u64 %r112,%r151,%r76; @ %r112 bra $L9; .loc 1 143 0 st.u64 [%r77],%r56; .loc 1 148 0 mov.u64 %r44,1; mov.u64 %r55,%r44; .loc 1 147 0 mov.u64 %r49,0; .loc 1 146 0 mov.u64 %r53,-1; .loc 1 175 0 mov.u64 %r152,%r44; .loc 1 149 0 bra $L10; $L17: .loc 1 151 0 add.u64 %r113,%r75,%r150; ld.u8 %r59,[%r113]; cvt.u32.u32 %r115,%r59; cvt.u64.u8 %r114,%r115; add.u64 %r116,%r23,%r114; ld.u8 %r154,[%r116+1]; mov.u16 %r120,%r154; and.b16 %r119,%r120,3; cvt.u32.u16 %r123,%r119; cvt.s32.s8 %r122,%r123; cvt.u16.u32 %r121,%r122; setp.ne.u16 %r124,%r121,1; @ %r124 bra $L11; add.u32 %r59,%r59,32; $L11: cvt.u32.u32 %r125,%r59; cvt.u32.u8 %r65,%r125; .loc 1 152 0 add.u64 %r126,%r75,%r53; add.u64 %r127,%r126,%r55; ld.u8 %r30,[%r127]; cvt.u32.u32 %r129,%r30; cvt.u64.u8 %r128,%r129; add.u64 %r130,%r23,%r128; ld.u8 %r154,[%r130+1]; mov.u16 %r134,%r154; and.b16 %r133,%r134,3; cvt.u32.u16 %r137,%r133; cvt.s32.s8 %r136,%r137; cvt.u16.u32 %r135,%r136; setp.ne.u16 %r138,%r135,1; @ %r138 bra $L12; add.u32 %r30,%r30,32; $L12: cvt.u32.u32 %r139,%r30; .loc 1 153 0 cvt.u16.u32 %r140,%r65; cvt.u16.u8 %r141,%r139; setp.le.u16 %r142,%r140,%r141; @ %r142 bra $L13; .loc 1 158 0 sub.u64 %r44,%r150,%r53; mov.u64 %r49,%r150; .loc 1 157 0 mov.u64 %r55,1; bra $L10; $L13: .loc 1 160 0 setp.ne.u16 %r145,%r140,%r141; @ %r145 bra $L15; .loc 1 163 0 setp.eq.u64 %r146,%r55,%r44; @ %r146 bra $L16; .loc 1 164 0 add.u64 %r55,%r55,1; bra $L10; $L16: .loc 1 167 0 mov.u64 %r49,%r150; .loc 1 168 0 mov.u64 %r55,1; bra $L10; $L15: .loc 1 174 0 mov.u64 %r53,%r49; add.u64 %r49,%r49,1; .loc 1 175 0 mov.u64 %r44,%r152; mov.u64 %r55,1; $L10: .loc 1 149 0 add.u64 %r150,%r49,%r55; setp.lt.u64 %r147,%r150,%r76; @ %r147 bra $L17; .loc 1 181 0 add.u64 %r51,%r53,1; add.u64 %r74,%r52,1; setp.lt.u64 %r148,%r51,%r74; @ %r148 bra $L1; .loc 1 183 0 st.u64 [%r77],%r44; .loc 1 184 0 mov.u64 %r74,%r51; $L1: .loc 1 185 0 mov.u64 %value,%r74; st.param.u64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,2056; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r76; .reg .u64 %r85; .reg .u64 %r90; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r116; .reg .u64 %r119; .reg .u64 %r144; .reg .u64 %r148; .reg .u64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u64 %r153; .reg .u32 %r154; .reg .u32 %r155; .reg .u32 %r156; .reg .u32 %r157; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r160; .reg .u32 %r161; .reg .u32 %r162; .reg .u32 %r163; .reg .u32 %r164; .reg .u64 %r170; .reg .u64 %r174; .reg .u64 %r185; .reg .u64 %r187; .reg .u64 %r190; .reg .u64 %r196; .reg .u64 %r202; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r210; .reg .u64 %r212; .reg .u64 %r219; .reg .u64 %r221; .reg .u64 %r226; .reg .u64 %r228; .reg .u64 %r230; .reg .u64 %r234; .reg .u64 %r236; .reg .u64 %r238; .reg .u64 %r240; .reg .u64 %r242; .reg .u64 %r243; .reg .u64 %r244; .reg .u64 %r245; .reg .u64 %r246; .reg .u64 %r250; .reg .u64 %r251; .reg .pred %r252; .reg .u64 %r253; .reg .pred %r254; .reg .u64 %r255; .reg .u32 %r256; .reg .u64 %r257; .reg .u16 %r260; .reg .u16 %r261; .reg .u16 %r262; .reg .u32 %r263; .reg .u32 %r264; .reg .pred %r265; .reg .u64 %r266; .reg .u64 %r267; .reg .u64 %r268; .reg .pred %r269; .reg .u32 %r273; .reg .pred %r274; .reg .u64 %r275; .reg .u64 %r277; .reg .u32 %r278; .reg .u64 %r279; .reg .u16 %r282; .reg .u16 %r283; .reg .u16 %r284; .reg .u32 %r285; .reg .u32 %r286; .reg .pred %r287; .reg .u64 %r288; .reg .u64 %r289; .reg .u64 %r290; .reg .pred %r291; .reg .pred %r292; .reg .pred %r293; .reg .pred %r294; .reg .u64 %r295; .reg .pred %r296; .reg .u64 %r297; .reg .u32 %r298; .reg .u64 %r299; .reg .u16 %r302; .reg .u16 %r303; .reg .u16 %r304; .reg .u32 %r305; .reg .u32 %r306; .reg .pred %r307; .reg .u64 %r308; .reg .u32 %r309; .reg .u64 %r310; .reg .u16 %r313; .reg .u16 %r314; .reg .u16 %r315; .reg .u32 %r316; .reg .u32 %r317; .reg .pred %r318; .reg .pred %r319; .reg .pred %r320; .reg .pred %r321; .reg .u64 %r322; .reg .pred %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u64 %r326; .reg .u16 %r329; .reg .u16 %r330; .reg .u16 %r331; .reg .u32 %r332; .reg .u32 %r333; .reg .pred %r334; .reg .u64 %r335; .reg .u32 %r336; .reg .u64 %r337; .reg .u16 %r340; .reg .u16 %r341; .reg .u16 %r342; .reg .u32 %r343; .reg .u32 %r344; .reg .pred %r345; .reg .pred %r346; .reg .u64 %r347; .reg .pred %r348; .reg .u64 %r349; .reg .u32 %r352; .reg .u64 %r354; .reg .u64 %r355; .reg .u64 %r356; .reg .u32 %r358; .reg .u32 %r359; .reg .u32 %r361; .reg .u32 %r362; .reg .u16 %r363; .reg .u16 %r364; .reg .u16 %r365; .reg .u32 %r366; .reg .u16 %r367; .reg .pred %r368; .reg .u64 %r369; .reg .u64 %r370; .reg .u64 %r371; .reg .u64 %r372; .reg .u64 %r374; .reg .u32 %r375; .reg .u64 %r376; .reg .u16 %r379; .reg .u16 %r380; .reg .u16 %r381; .reg .u32 %r382; .reg .u32 %r383; .reg .pred %r384; .reg .u64 %r385; .reg .u64 %r386; .reg .u64 %r387; .reg .pred %r388; .reg .pred %r389; .reg .u64 %r390; .reg .pred %r391; .reg .u64 %r392; .reg .u32 %r393; .reg .u64 %r394; .reg .u16 %r397; .reg .u16 %r398; .reg .u16 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .pred %r402; .reg .u64 %r403; .reg .u32 %r404; .reg .u64 %r405; .reg .u16 %r408; .reg .u16 %r409; .reg .u16 %r410; .reg .u32 %r411; .reg .u32 %r412; .reg .pred %r413; .reg .pred %r414; .reg .pred %r415; .reg .u64 %r417; .reg .u64 %r418; .reg .pred %r419; .reg .u64 %r420; .reg .u32 %r421; .reg .u64 %r422; .reg .u16 %r425; .reg .u16 %r426; .reg .u16 %r427; .reg .u32 %r428; .reg .u32 %r429; .reg .pred %r430; .reg .u64 %r431; .reg .u32 %r432; .reg .u64 %r433; .reg .u16 %r436; .reg .u16 %r437; .reg .u16 %r438; .reg .u32 %r439; .reg .u32 %r440; .reg .pred %r441; .reg .pred %r442; .reg .u64 %r443; .reg .u32 %r446; .reg .u64 %r448; .reg .u64 %r449; .reg .u64 %r450; .reg .u32 %r452; .reg .u32 %r453; .reg .u32 %r455; .reg .u32 %r456; .reg .u16 %r457; .reg .u16 %r458; .reg .u16 %r459; .reg .u32 %r460; .reg .u16 %r461; .reg .pred %r462; .reg .u64 %r464; .reg .u64 %r468; .reg .u64 %r469; .reg .u64 %r470; .reg .u32 %r474; .reg .pred %r475; .reg .u64 %r476; .reg .u64 %r477; .reg .u64 %r478; .reg .pred %r479; .reg .u16 %r480; mov.u64 %r243,%ar0; mov.u64 %r244,%ar1; mov.u64 %r245,%ar2; mov.u64 %r246,%ar3; .loc 1 304 0 add.u64 %r250,%frame,2048; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r245; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r246; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r250; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r251,[%value_in]; } mov.u64 %r202,%frame; $L20: .loc 1 311 0 st.u64 [%r202],%r246; add.u64 %r202,%r202,8; .loc 1 310 0 setp.ne.u64 %r252,%r250,%r202; @ %r252 bra $L20; ld.u64 %r253,[%frame+2048]; add.u64 %r240,%r245,%r253; .loc 1 312 0 setp.eq.u64 %r254,%r246,0; @ %r254 bra $L21; .loc 1 313 0 ld.global.u64 %r76,[__ctype_ptr__]; add.u64 %r238,%r246,-1; mov.u64 %r205,%r245; mov.u64 %r204,%r238; $L23: ld.u8 %r154,[%r205]; cvt.u32.u32 %r256,%r154; cvt.u64.u8 %r255,%r256; add.u64 %r257,%r76,%r255; ld.u8 %r480,[%r257+1]; mov.u16 %r261,%r480; and.b16 %r260,%r261,3; cvt.u32.u16 %r264,%r260; cvt.s32.s8 %r263,%r264; cvt.u16.u32 %r262,%r263; setp.ne.u16 %r265,%r262,1; @ %r265 bra $L22; add.u32 %r154,%r154,32; $L22: cvt.s64.s32 %r266,%r154; shl.b64 %r267,%r266,3; add.u64 %r268,%frame,%r267; st.u64 [%r268],%r204; add.u64 %r205,%r205,1; add.u64 %r204,%r204,-1; .loc 1 312 0 setp.ne.u64 %r269,%r204,-1; @ %r269 bra $L23; .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r245; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r240; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r251; call (%value_in),strncasecmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r273,[%value_in]; } setp.eq.u32 %r274,%r273,0; @ %r274 bra $L63; bra $L25; $L43: .loc 1 329 0 add.u64 %r275,%r243,%r109; ld.global.u64 %r85,[__ctype_ptr__]; ld.u8 %r155,[%r275+-1]; cvt.u32.u32 %r278,%r155; cvt.u64.u8 %r277,%r278; add.u64 %r279,%r85,%r277; ld.u8 %r480,[%r279+1]; mov.u16 %r283,%r480; and.b16 %r282,%r283,3; cvt.u32.u16 %r286,%r282; cvt.s32.s8 %r285,%r286; cvt.u16.u32 %r284,%r285; setp.ne.u16 %r287,%r284,1; @ %r287 bra $L26; add.u32 %r155,%r155,32; $L26: cvt.s64.s32 %r288,%r155; shl.b64 %r289,%r288,3; add.u64 %r290,%frame,%r289; ld.u64 %r153,[%r290]; .loc 1 330 0 setp.eq.u64 %r291,%r153,0; @ %r291 bra $L27; .loc 1 332 0 setp.eq.u64 %r292,%r152,0; @ %r292 bra $L28; ld.u64 %r90,[%frame+2048]; setp.le.u64 %r293,%r90,%r153; @ %r293 bra $L28; .loc 1 337 0 sub.u64 %r153,%r246,%r90; $L28: .loc 1 340 0 add.u64 %r151,%r151,%r153; .loc 1 339 0 mov.u64 %r152,0; .loc 1 341 0 bra $L29; $L27: .loc 1 345 0 max.u64 %r185,%r152,%r251; .loc 1 346 0 setp.ge.u64 %r294,%r185,%r238; @ %r294 bra $L30; add.u64 %r228,%r245,%r185; add.u64 %r295,%r151,%r185; add.u64 %r226,%r243,%r295; bra $L31; $L34: .loc 1 348 0 add.u64 %r185,%r185,1; add.u64 %r228,%r228,1; add.u64 %r226,%r226,1; .loc 1 346 0 setp.eq.u64 %r296,%r185,%r238; @ %r296 bra $L30; $L31: ld.u8 %r156,[%r228]; cvt.u32.u32 %r298,%r156; cvt.u64.u8 %r297,%r298; add.u64 %r299,%r85,%r297; ld.u8 %r480,[%r299+1]; mov.u16 %r303,%r480; and.b16 %r302,%r303,3; cvt.u32.u16 %r306,%r302; cvt.s32.s8 %r305,%r306; cvt.u16.u32 %r304,%r305; setp.ne.u16 %r307,%r304,1; @ %r307 bra $L32; add.u32 %r156,%r156,32; $L32: .loc 1 347 0 ld.u8 %r157,[%r226]; cvt.u32.u32 %r309,%r157; cvt.u64.u8 %r308,%r309; add.u64 %r310,%r85,%r308; ld.u8 %r480,[%r310+1]; mov.u16 %r314,%r480; and.b16 %r313,%r314,3; cvt.u32.u16 %r317,%r313; cvt.s32.s8 %r316,%r317; cvt.u16.u32 %r315,%r316; setp.ne.u16 %r318,%r315,1; @ %r318 bra $L33; add.u32 %r157,%r157,32; $L33: .loc 1 346 0 setp.eq.u32 %r319,%r156,%r157; @ %r319 bra $L34; .loc 1 349 0 setp.lt.u64 %r320,%r185,%r238; @ %r320 bra $L35; $L30: .loc 1 352 0 mov.u64 %r187,%r476; .loc 1 353 0 setp.ge.u64 %r321,%r152,%r251; @ %r321 bra $L64; add.u64 %r236,%r245,%r476; add.u64 %r322,%r151,%r476; add.u64 %r234,%r243,%r322; add.u64 %r230,%r152,-1; bra $L37; $L40: .loc 1 355 0 add.u64 %r190,%r187,-1; add.u64 %r236,%r236,-1; add.u64 %r234,%r234,-1; .loc 1 353 0 setp.eq.u64 %r323,%r190,%r230; @ %r323 bra $L65; mov.u64 %r187,%r190; $L37: add.u64 %r196,%r187,1; ld.u8 %r158,[%r236]; cvt.u32.u32 %r325,%r158; cvt.u64.u8 %r324,%r325; add.u64 %r326,%r85,%r324; ld.u8 %r480,[%r326+1]; mov.u16 %r330,%r480; and.b16 %r329,%r330,3; cvt.u32.u16 %r333,%r329; cvt.s32.s8 %r332,%r333; cvt.u16.u32 %r331,%r332; setp.ne.u16 %r334,%r331,1; @ %r334 bra $L38; add.u32 %r158,%r158,32; $L38: .loc 1 354 0 ld.u8 %r159,[%r234]; cvt.u32.u32 %r336,%r159; cvt.u64.u8 %r335,%r336; add.u64 %r337,%r85,%r335; ld.u8 %r480,[%r337+1]; mov.u16 %r341,%r480; and.b16 %r340,%r341,3; cvt.u32.u16 %r344,%r340; cvt.s32.s8 %r343,%r344; cvt.u16.u32 %r342,%r343; setp.ne.u16 %r345,%r342,1; @ %r345 bra $L39; add.u32 %r159,%r159,32; $L39: .loc 1 353 0 setp.eq.u32 %r346,%r158,%r159; @ %r346 bra $L40; bra $L36; $L64: mov.u64 %r196,%r251; bra $L36; $L65: mov.u64 %r196,%r187; $L36: .loc 1 356 0 add.u64 %r347,%r152,1; setp.le.u64 %r348,%r347,%r196; @ %r348 bra $L41; .loc 1 357 0 add.u64 %r242,%r243,%r151; bra $L19; $L41: .loc 1 360 0 ld.u64 %r108,[%frame+2048]; add.u64 %r151,%r151,%r108; .loc 1 361 0 sub.u64 %r152,%r246,%r108; bra $L29; $L35: sub.u64 %r349,%r151,%r251; add.u64 %r150,%r349,1; .loc 1 365 0 add.u64 %r151,%r150,%r185; .loc 1 366 0 mov.u64 %r152,%r153; $L29: .loc 1 339 0 mov.u64 %r244,%r109; bra $L24; $L63: .loc 1 322 0 mov.u64 %r152,0; .loc 1 324 0 mov.u64 %r151,%r152; .loc 1 352 0 add.u64 %r476,%r251,-1; $L24: .loc 1 325 0 add.u64 %r109,%r151,%r246; sub.u64 %r354,%r109,%r244; add.u64 %r355,%r243,%r244; mov.u32 %r352,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r355; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r352; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r354; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r356,[%value_in]; } set.u32.ne.u64 %r358,%r109,0; neg.s32 %r359,%r358; set.u32.eq.u64 %r361,%r356,0; neg.s32 %r362,%r361; cvt.u16.u32 %r364,%r359; cvt.u16.u32 %r365,%r362; and.b16 %r363,%r364,%r365; cvt.u32.u16 %r366,%r363; cvt.u16.u8 %r367,%r366; setp.ne.u16 %r368,%r367,0; @ %r368 bra $L43; $L61: .loc 1 408 0 mov.u64 %r242,0; bra $L19; $L25: .loc 1 375 0 sub.u64 %r370,%r246,%r251; max.u64 %r369,%r370,%r251; add.u64 %r371,%r369,1; st.u64 [%frame+2048],%r371; .loc 1 376 0 mov.u64 %r148,0; .loc 1 390 0 add.u64 %r477,%r246,-1; .loc 1 396 0 add.u64 %r478,%r251,-1; .loc 1 397 0 setp.eq.u64 %r479,%r478,-1; .loc 1 377 0 bra $L44; $L60: .loc 1 381 0 add.u64 %r372,%r243,%r144; ld.global.u64 %r119,[__ctype_ptr__]; ld.u8 %r160,[%r372+-1]; cvt.u32.u32 %r375,%r160; cvt.u64.u8 %r374,%r375; add.u64 %r376,%r119,%r374; ld.u8 %r480,[%r376+1]; mov.u16 %r380,%r480; and.b16 %r379,%r380,3; cvt.u32.u16 %r383,%r379; cvt.s32.s8 %r382,%r383; cvt.u16.u32 %r381,%r382; setp.ne.u16 %r384,%r381,1; @ %r384 bra $L45; add.u32 %r160,%r160,32; $L45: cvt.s64.s32 %r385,%r160; shl.b64 %r386,%r385,3; add.u64 %r387,%frame,%r386; ld.u64 %r170,[%r387]; .loc 1 382 0 setp.ne.u64 %r388,%r170,0; @ %r388 bra $L46; .loc 1 390 0 setp.ge.u64 %r389,%r251,%r477; @ %r389 bra $L47; add.u64 %r212,%r245,%r251; add.u64 %r390,%r148,%r251; add.u64 %r210,%r243,%r390; mov.u64 %r174,%r251; bra $L48; $L46: .loc 1 384 0 add.u64 %r148,%r148,%r170; .loc 1 385 0 bra $L49; $L52: .loc 1 392 0 add.u64 %r174,%r174,1; add.u64 %r212,%r212,1; add.u64 %r210,%r210,1; .loc 1 390 0 setp.ge.u64 %r391,%r174,%r477; @ %r391 bra $L47; $L48: ld.u8 %r161,[%r212]; cvt.u32.u32 %r393,%r161; cvt.u64.u8 %r392,%r393; add.u64 %r394,%r119,%r392; ld.u8 %r480,[%r394+1]; mov.u16 %r398,%r480; and.b16 %r397,%r398,3; cvt.u32.u16 %r401,%r397; cvt.s32.s8 %r400,%r401; cvt.u16.u32 %r399,%r400; setp.ne.u16 %r402,%r399,1; @ %r402 bra $L50; add.u32 %r161,%r161,32; $L50: .loc 1 391 0 ld.u8 %r162,[%r210]; cvt.u32.u32 %r404,%r162; cvt.u64.u8 %r403,%r404; add.u64 %r405,%r119,%r403; ld.u8 %r480,[%r405+1]; mov.u16 %r409,%r480; and.b16 %r408,%r409,3; cvt.u32.u16 %r412,%r408; cvt.s32.s8 %r411,%r412; cvt.u16.u32 %r410,%r411; setp.ne.u16 %r413,%r410,1; @ %r413 bra $L51; add.u32 %r162,%r162,32; $L51: .loc 1 390 0 setp.eq.u32 %r414,%r161,%r162; @ %r414 bra $L52; .loc 1 393 0 setp.lt.u64 %r415,%r174,%r477; @ %r415 bra $L53; $L47: .loc 1 397 0 @ %r479 bra $L54; add.u64 %r221,%r245,%r478; add.u64 %r417,%r148,%r478; add.u64 %r219,%r243,%r417; bra $L55; $L58: add.u64 %r221,%r221,-1; add.u64 %r219,%r219,-1; sub.u64 %r418,%r221,%r245; setp.eq.u64 %r419,%r418,-1; @ %r419 bra $L54; $L55: ld.u8 %r163,[%r221]; cvt.u32.u32 %r421,%r163; cvt.u64.u8 %r420,%r421; add.u64 %r422,%r119,%r420; ld.u8 %r480,[%r422+1]; mov.u16 %r426,%r480; and.b16 %r425,%r426,3; cvt.u32.u16 %r429,%r425; cvt.s32.s8 %r428,%r429; cvt.u16.u32 %r427,%r428; setp.ne.u16 %r430,%r427,1; @ %r430 bra $L56; add.u32 %r163,%r163,32; $L56: .loc 1 398 0 ld.u8 %r164,[%r219]; cvt.u32.u32 %r432,%r164; cvt.u64.u8 %r431,%r432; add.u64 %r433,%r119,%r431; ld.u8 %r480,[%r433+1]; mov.u16 %r437,%r480; and.b16 %r436,%r437,3; cvt.u32.u16 %r440,%r436; cvt.s32.s8 %r439,%r440; cvt.u16.u32 %r438,%r439; setp.ne.u16 %r441,%r438,1; @ %r441 bra $L57; add.u32 %r164,%r164,32; $L57: .loc 1 397 0 setp.eq.u32 %r442,%r163,%r164; @ %r442 bra $L58; bra $L76; $L53: sub.u64 %r443,%r148,%r251; add.u64 %r116,%r443,1; .loc 1 405 0 add.u64 %r148,%r116,%r174; $L49: .loc 1 390 0 mov.u64 %r244,%r144; $L44: .loc 1 377 0 add.u64 %r144,%r148,%r246; sub.u64 %r448,%r144,%r244; add.u64 %r449,%r243,%r244; mov.u32 %r446,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r449; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r446; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r448; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r450,[%value_in]; } set.u32.eq.u64 %r452,%r450,0; neg.s32 %r453,%r452; set.u32.ne.u64 %r455,%r144,0; neg.s32 %r456,%r455; cvt.u16.u32 %r458,%r453; cvt.u16.u32 %r459,%r456; and.b16 %r457,%r458,%r459; cvt.u32.u16 %r460,%r457; cvt.u16.u8 %r461,%r460; setp.ne.u16 %r462,%r461,0; @ %r462 bra $L60; bra $L61; $L54: .loc 1 401 0 add.u64 %r242,%r243,%r148; bra $L19; $L76: .loc 1 402 0 ld.u64 %r464,[%frame+2048]; add.u64 %r148,%r148,%r464; bra $L49; $L62: .loc 1 325 0 neg.s64 %r468,%r244; add.u64 %r469,%r243,%r244; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r469; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r474; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r468; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r470,[%value_in]; } .loc 1 408 0 mov.u64 %r242,%r246; bra $L19; $L21: .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r245; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r240; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r251; call (%value_in),strncasecmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r474,[%value_in]; } setp.eq.u32 %r475,%r474,0; @ %r475 bra $L62; bra $L25; $L19: .loc 1 409 0 mov.u64 %value,%r242; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strcasestr .visible .func (.param .u64 %value_out) strcasestr (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r22; .reg .u64 %r24; .reg .u32 %r34; .reg .u32 %r35; .reg .u32 %r41; .reg .u32 %r42; .reg .u64 %r45; .reg .u64 %r47; .reg .u32 %r50; .reg .u64 %r51; .reg .u64 %r52; .reg .u64 %r53; .reg .u64 %r58; .reg .u64 %r59; .reg .u64 %r61; .reg .u64 %r67; .reg .u32 %r74; .reg .u32 %r75; .reg .u64 %r77; .reg .u64 %r78; .reg .u64 %r80; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r105; .reg .u64 %r107; .reg .u64 %r113; .reg .u32 %r120; .reg .u32 %r121; .reg .u64 %r124; .reg .u32 %r137; .reg .u32 %r138; .reg .u64 %r141; .reg .u64 %r148; .reg .u64 %r149; .reg .u64 %r154; .reg .u64 %r156; .reg .u64 %r163; .reg .u64 %r165; .reg .u64 %r170; .reg .u64 %r172; .reg .u64 %r174; .reg .u64 %r178; .reg .u64 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .u64 %r183; .reg .pred %r184; .reg .pred %r185; .reg .u32 %r186; .reg .u64 %r187; .reg .u64 %r189; .reg .u16 %r192; .reg .u16 %r193; .reg .u16 %r194; .reg .u32 %r195; .reg .u32 %r196; .reg .pred %r197; .reg .u32 %r198; .reg .u64 %r199; .reg .u64 %r201; .reg .u16 %r204; .reg .u16 %r205; .reg .u16 %r206; .reg .u32 %r207; .reg .u32 %r208; .reg .pred %r209; .reg .u32 %r211; .reg .u32 %r212; .reg .pred %r213; .reg .pred %r214; .reg .pred %r215; .reg .u16 %r216; .reg .u32 %r217; .reg .pred %r218; .reg .pred %r219; .reg .pred %r220; .reg .u64 %r224; .reg .u64 %r228; .reg .u64 %r229; .reg .u32 %r230; .reg .pred %r231; .reg .pred %r232; .reg .u64 %r233; .reg .pred %r234; .reg .u64 %r235; .reg .u32 %r236; .reg .u64 %r237; .reg .u16 %r240; .reg .u16 %r241; .reg .u16 %r242; .reg .u32 %r243; .reg .u32 %r244; .reg .pred %r245; .reg .u64 %r246; .reg .u32 %r247; .reg .u64 %r248; .reg .u16 %r251; .reg .u16 %r252; .reg .u16 %r253; .reg .u32 %r254; .reg .u32 %r255; .reg .pred %r256; .reg .pred %r257; .reg .pred %r258; .reg .pred %r259; .reg .u64 %r260; .reg .pred %r261; .reg .u64 %r262; .reg .u32 %r263; .reg .u64 %r264; .reg .u16 %r267; .reg .u16 %r268; .reg .u16 %r269; .reg .u32 %r270; .reg .u32 %r271; .reg .pred %r272; .reg .u64 %r273; .reg .u32 %r274; .reg .u64 %r275; .reg .u16 %r278; .reg .u16 %r279; .reg .u16 %r280; .reg .u32 %r281; .reg .u32 %r282; .reg .pred %r283; .reg .pred %r284; .reg .u64 %r285; .reg .pred %r286; .reg .u64 %r287; .reg .u32 %r290; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u32 %r296; .reg .u32 %r297; .reg .u32 %r299; .reg .u32 %r300; .reg .u16 %r301; .reg .u16 %r302; .reg .u16 %r303; .reg .u32 %r304; .reg .u16 %r305; .reg .pred %r306; .reg .u64 %r307; .reg .u64 %r308; .reg .u64 %r309; .reg .pred %r310; .reg .u64 %r311; .reg .u32 %r312; .reg .u64 %r313; .reg .u16 %r316; .reg .u16 %r317; .reg .u16 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .pred %r321; .reg .u64 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u16 %r327; .reg .u16 %r328; .reg .u16 %r329; .reg .u32 %r330; .reg .u32 %r331; .reg .pred %r332; .reg .pred %r333; .reg .pred %r334; .reg .u64 %r336; .reg .u64 %r339; .reg .pred %r340; .reg .u64 %r341; .reg .u32 %r342; .reg .u64 %r343; .reg .u16 %r346; .reg .u16 %r347; .reg .u16 %r348; .reg .u32 %r349; .reg .u32 %r350; .reg .pred %r351; .reg .u64 %r352; .reg .u32 %r353; .reg .u64 %r354; .reg .u16 %r357; .reg .u16 %r358; .reg .u16 %r359; .reg .u32 %r360; .reg .u32 %r361; .reg .pred %r362; .reg .pred %r363; .reg .u64 %r364; .reg .u32 %r367; .reg .u64 %r369; .reg .u64 %r370; .reg .u64 %r371; .reg .u32 %r373; .reg .u32 %r374; .reg .u32 %r376; .reg .u32 %r377; .reg .u16 %r378; .reg .u16 %r379; .reg .u16 %r380; .reg .u32 %r381; .reg .u16 %r382; .reg .pred %r383; .reg .pred %r384; .reg .u64 %r385; .reg .u64 %r390; .reg .u64 %r392; .reg .u64 %r393; .reg .u64 %r394; .reg .u64 %r395; .reg .u64 %r396; .reg .pred %r397; .reg .u16 %r398; mov.u64 %r182,%ar0; mov.u64 %r183,%ar1; .loc 2 133 0 ld.s8 %r34,[%r182]; ld.s8 %r35,[%r183]; setp.eq.u32 %r184,%r34,0; @ %r184 bra $L78; setp.eq.u32 %r185,%r35,0; @ %r185 bra $L118; .loc 2 134 0 ld.global.u64 %r24,[__ctype_ptr__]; mov.u64 %r47,%r183; mov.u64 %r45,%r182; .loc 2 128 0 mov.u32 %r50,1; $L83: .loc 2 134 0 add.u64 %r45,%r45,1; cvt.u32.u32 %r186,%r34; cvt.u32.u8 %r41,%r186; cvt.u64.u8 %r187,%r186; add.u64 %r189,%r24,%r187; ld.u8 %r398,[%r189+1]; mov.u16 %r193,%r398; and.b16 %r192,%r193,3; cvt.u32.u16 %r196,%r192; cvt.s32.s8 %r195,%r196; cvt.u16.u32 %r194,%r195; setp.ne.u16 %r197,%r194,1; @ %r197 bra $L80; add.u32 %r41,%r41,32; $L80: .loc 2 135 0 add.u64 %r47,%r47,1; cvt.u32.u32 %r198,%r35; cvt.u32.u8 %r42,%r198; cvt.u64.u8 %r199,%r198; add.u64 %r201,%r24,%r199; ld.u8 %r398,[%r201+1]; mov.u16 %r205,%r398; and.b16 %r204,%r205,3; cvt.u32.u16 %r208,%r204; cvt.s32.s8 %r207,%r208; cvt.u16.u32 %r206,%r207; setp.ne.u16 %r209,%r206,1; @ %r209 bra $L81; add.u32 %r42,%r42,32; $L81: set.u32.eq.u32 %r211,%r41,%r42; neg.s32 %r212,%r211; .loc 2 134 0 and.b32 %r50,%r50,%r212; .loc 2 133 0 ld.s8 %r34,[%r45]; setp.eq.u32 %r213,%r34,0; @ %r213 bra $L82; ld.s8 %r35,[%r47]; setp.ne.u32 %r214,%r35,0; @ %r214 bra $L83; bra $L84; $L78: .loc 2 136 0 setp.eq.u32 %r215,%r35,0; .loc 2 137 0 selp.u64 %r181,%r182,0,%r215; bra $L77; $L82: .loc 2 136 0 ld.s8 %r217,[%r47]; cvt.u16.u32 %r216,%r217; setp.ne.u16 %r218,%r216,0; @ %r218 bra $L120; $L84: .loc 2 138 0 setp.ne.u32 %r219,%r50,0; @ %r219 bra $L121; .loc 2 140 0 sub.u64 %r51,%r47,%r183; .loc 2 141 0 add.u64 %r52,%r182,1; .loc 2 142 0 add.u64 %r53,%r51,-1; .loc 2 145 0 setp.gt.u64 %r220,%r51,31; @ %r220 bra $L85; .loc 1 209 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r183; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r51; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r224,[%value_in]; } .loc 1 213 0 ld.u64 %r229,[%frame]; add.u64 %r228,%r183,%r229; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r183; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r228; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r224; call (%value_in),strncasecmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r230,[%value_in]; } setp.eq.u32 %r231,%r230,0; @ %r231 bra $L122; bra $L134; $L102: .loc 1 223 0 max.u64 %r59,%r224,%r58; .loc 1 224 0 setp.le.u64 %r232,%r51,%r59; @ %r232 bra $L88; ld.global.u64 %r61,[__ctype_ptr__]; add.u64 %r172,%r183,%r59; add.u64 %r233,%r59,%r67; add.u64 %r170,%r52,%r233; bra $L89; $L92: .loc 1 226 0 add.u64 %r59,%r59,1; add.u64 %r172,%r172,1; add.u64 %r170,%r170,1; .loc 1 224 0 setp.eq.u64 %r234,%r51,%r59; @ %r234 bra $L88; $L89: ld.u8 %r74,[%r172]; cvt.u32.u32 %r236,%r74; cvt.u64.u8 %r235,%r236; add.u64 %r237,%r61,%r235; ld.u8 %r398,[%r237+1]; mov.u16 %r241,%r398; and.b16 %r240,%r241,3; cvt.u32.u16 %r244,%r240; cvt.s32.s8 %r243,%r244; cvt.u16.u32 %r242,%r243; setp.ne.u16 %r245,%r242,1; @ %r245 bra $L90; add.u32 %r74,%r74,32; $L90: .loc 1 225 0 ld.u8 %r75,[%r170]; cvt.u32.u32 %r247,%r75; cvt.u64.u8 %r246,%r247; add.u64 %r248,%r61,%r246; ld.u8 %r398,[%r248+1]; mov.u16 %r252,%r398; and.b16 %r251,%r252,3; cvt.u32.u16 %r255,%r251; cvt.s32.s8 %r254,%r255; cvt.u16.u32 %r253,%r254; setp.ne.u16 %r256,%r253,1; @ %r256 bra $L91; add.u32 %r75,%r75,32; $L91: .loc 1 224 0 setp.eq.u32 %r257,%r74,%r75; @ %r257 bra $L92; .loc 1 227 0 setp.gt.u64 %r258,%r51,%r59; @ %r258 bra $L93; $L88: .loc 1 230 0 mov.u64 %r77,%r393; .loc 1 231 0 setp.le.u64 %r259,%r224,%r58; @ %r259 bra $L123; ld.global.u64 %r80,[__ctype_ptr__]; add.u64 %r180,%r183,%r393; add.u64 %r260,%r224,%r67; add.u64 %r178,%r182,%r260; add.u64 %r174,%r58,-1; bra $L95; $L98: .loc 1 233 0 add.u64 %r78,%r77,-1; add.u64 %r180,%r180,-1; add.u64 %r178,%r178,-1; .loc 1 231 0 setp.eq.u64 %r261,%r78,%r174; @ %r261 bra $L124; mov.u64 %r77,%r78; $L95: add.u64 %r148,%r77,1; ld.u8 %r92,[%r180]; cvt.u32.u32 %r263,%r92; cvt.u64.u8 %r262,%r263; add.u64 %r264,%r80,%r262; ld.u8 %r398,[%r264+1]; mov.u16 %r268,%r398; and.b16 %r267,%r268,3; cvt.u32.u16 %r271,%r267; cvt.s32.s8 %r270,%r271; cvt.u16.u32 %r269,%r270; setp.ne.u16 %r272,%r269,1; @ %r272 bra $L96; add.u32 %r92,%r92,32; $L96: .loc 1 232 0 ld.u8 %r93,[%r178]; cvt.u32.u32 %r274,%r93; cvt.u64.u8 %r273,%r274; add.u64 %r275,%r80,%r273; ld.u8 %r398,[%r275+1]; mov.u16 %r279,%r398; and.b16 %r278,%r279,3; cvt.u32.u16 %r282,%r278; cvt.s32.s8 %r281,%r282; cvt.u16.u32 %r280,%r281; setp.ne.u16 %r283,%r280,1; @ %r283 bra $L97; add.u32 %r93,%r93,32; $L97: .loc 1 231 0 setp.eq.u32 %r284,%r92,%r93; @ %r284 bra $L98; bra $L94; $L123: mov.u64 %r148,%r224; bra $L94; $L124: mov.u64 %r148,%r77; $L94: .loc 1 234 0 add.u64 %r285,%r58,1; setp.le.u64 %r286,%r285,%r148; @ %r286 bra $L99; .loc 1 235 0 add.u64 %r181,%r52,%r67; bra $L77; $L99: .loc 1 238 0 ld.u64 %r97,[%frame]; add.u64 %r67,%r67,%r97; .loc 1 239 0 sub.u64 %r58,%r51,%r97; bra $L101; $L93: sub.u64 %r287,%r67,%r224; add.u64 %r149,%r287,1; .loc 1 243 0 add.u64 %r67,%r59,%r149; .loc 1 244 0 mov.u64 %r58,0; $L101: mov.u64 %r53,%r98; bra $L86; $L122: .loc 1 218 0 mov.u64 %r58,0; .loc 1 219 0 mov.u64 %r67,%r58; .loc 1 230 0 add.u64 %r393,%r224,-1; $L86: .loc 1 220 0 add.u64 %r98,%r51,%r67; sub.u64 %r292,%r98,%r53; add.u64 %r293,%r52,%r53; mov.u32 %r290,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r293; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r290; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r292; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r294,[%value_in]; } set.u32.eq.u64 %r296,%r294,0; neg.s32 %r297,%r296; set.u32.ne.u64 %r299,%r98,0; neg.s32 %r300,%r299; cvt.u16.u32 %r302,%r297; cvt.u16.u32 %r303,%r300; and.b16 %r301,%r302,%r303; cvt.u32.u16 %r304,%r301; cvt.u16.u8 %r305,%r304; setp.ne.u16 %r306,%r305,0; @ %r306 bra $L102; bra $L103; $L134: .loc 1 252 0 sub.u64 %r308,%r51,%r224; max.u64 %r307,%r308,%r224; add.u64 %r309,%r307,1; st.u64 [%frame],%r309; .loc 1 253 0 mov.u64 %r113,0; .loc 1 264 0 add.u64 %r396,%r224,-1; .loc 1 265 0 setp.eq.u64 %r397,%r396,-1; bra $L104; $L108: .loc 1 260 0 add.u64 %r105,%r105,1; add.u64 %r156,%r156,1; add.u64 %r154,%r154,1; .loc 1 258 0 setp.eq.u64 %r310,%r51,%r105; @ %r310 bra $L105; $L116: ld.u8 %r120,[%r156]; cvt.u32.u32 %r312,%r120; cvt.u64.u8 %r311,%r312; add.u64 %r313,%r107,%r311; ld.u8 %r398,[%r313+1]; mov.u16 %r317,%r398; and.b16 %r316,%r317,3; cvt.u32.u16 %r320,%r316; cvt.s32.s8 %r319,%r320; cvt.u16.u32 %r318,%r319; setp.ne.u16 %r321,%r318,1; @ %r321 bra $L106; add.u32 %r120,%r120,32; $L106: .loc 1 259 0 ld.u8 %r121,[%r154]; cvt.u32.u32 %r323,%r121; cvt.u64.u8 %r322,%r323; add.u64 %r324,%r107,%r322; ld.u8 %r398,[%r324+1]; mov.u16 %r328,%r398; and.b16 %r327,%r328,3; cvt.u32.u16 %r331,%r327; cvt.s32.s8 %r330,%r331; cvt.u16.u32 %r329,%r330; setp.ne.u16 %r332,%r329,1; @ %r332 bra $L107; add.u32 %r121,%r121,32; $L107: .loc 1 258 0 setp.eq.u32 %r333,%r120,%r121; @ %r333 bra $L108; .loc 1 261 0 setp.gt.u64 %r334,%r51,%r105; @ %r334 bra $L109; $L105: .loc 1 265 0 @ %r397 bra $L110; ld.global.u64 %r124,[__ctype_ptr__]; add.u64 %r165,%r183,%r396; add.u64 %r336,%r224,%r113; add.u64 %r163,%r182,%r336; not.b64 %r394,%r182; sub.u64 %r395,%r394,%r113; bra $L111; $L114: add.u64 %r165,%r165,-1; add.u64 %r163,%r163,-1; add.u64 %r339,%r395,%r163; setp.eq.u64 %r340,%r339,-1; @ %r340 bra $L110; $L111: ld.u8 %r137,[%r165]; cvt.u32.u32 %r342,%r137; cvt.u64.u8 %r341,%r342; add.u64 %r343,%r124,%r341; ld.u8 %r398,[%r343+1]; mov.u16 %r347,%r398; and.b16 %r346,%r347,3; cvt.u32.u16 %r350,%r346; cvt.s32.s8 %r349,%r350; cvt.u16.u32 %r348,%r349; setp.ne.u16 %r351,%r348,1; @ %r351 bra $L112; add.u32 %r137,%r137,32; $L112: .loc 1 266 0 ld.u8 %r138,[%r163]; cvt.u32.u32 %r353,%r138; cvt.u64.u8 %r352,%r353; add.u64 %r354,%r124,%r352; ld.u8 %r398,[%r354+1]; mov.u16 %r358,%r398; and.b16 %r357,%r358,3; cvt.u32.u16 %r361,%r357; cvt.s32.s8 %r360,%r361; cvt.u16.u32 %r359,%r360; setp.ne.u16 %r362,%r359,1; @ %r362 bra $L113; add.u32 %r138,%r138,32; $L113: .loc 1 265 0 setp.eq.u32 %r363,%r137,%r138; @ %r363 bra $L114; bra $L135; $L109: sub.u64 %r364,%r113,%r224; add.u64 %r22,%r364,1; .loc 1 273 0 add.u64 %r113,%r22,%r105; $L117: .loc 1 258 0 mov.u64 %r53,%r141; $L104: .loc 1 254 0 add.u64 %r141,%r51,%r113; sub.u64 %r369,%r141,%r53; add.u64 %r370,%r52,%r53; mov.u32 %r367,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r370; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r367; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r369; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r371,[%value_in]; } set.u32.ne.u64 %r373,%r141,0; neg.s32 %r374,%r373; set.u32.eq.u64 %r376,%r371,0; neg.s32 %r377,%r376; cvt.u16.u32 %r379,%r374; cvt.u16.u32 %r380,%r377; and.b16 %r378,%r379,%r380; cvt.u32.u16 %r381,%r378; cvt.u16.u8 %r382,%r381; setp.eq.u16 %r383,%r382,0; @ %r383 bra $L103; .loc 1 258 0 setp.le.u64 %r384,%r51,%r224; @ %r384 bra $L105; ld.global.u64 %r107,[__ctype_ptr__]; add.u64 %r156,%r183,%r224; add.u64 %r385,%r224,%r113; add.u64 %r154,%r52,%r385; mov.u64 %r105,%r224; bra $L116; $L103: .loc 1 276 0 mov.u64 %r181,0; .loc 2 146 0 bra $L77; $L85: .loc 2 149 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r52; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r53; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r183; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r51; call (%value_in),two_way_long_needle,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r390,[%value_in]; } mov.u64 %r181,%r390; bra $L77; $L118: .loc 2 133 0 mov.u64 %r181,%r182; bra $L77; $L120: .loc 2 137 0 mov.u64 %r181,0; bra $L77; $L121: mov.u64 %r181,%r182; bra $L77; $L110: .loc 1 269 0 add.u64 %r181,%r52,%r113; bra $L77; $L135: .loc 1 270 0 ld.u64 %r392,[%frame]; add.u64 %r113,%r113,%r392; bra $L117; $L77: .loc 2 152 0 mov.u64 %value,%r181; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } lib_a-strcat.o/ 0 0 0 644 2238 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcat .visible .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strcat.c" // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strcat .visible .func (.param .u64 %value_out) strcat (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r78; .reg .u64 %r84; .reg .u64 %r86; .reg .u64 %r92; .reg .u64 %r93; .reg .u64 %r94; .reg .pred %r95; .reg .u64 %r96; .reg .u64 %r97; .reg .u64 %r98; .reg .u64 %r99; .reg .pred %r100; .reg .u16 %r101; .reg .u32 %r102; .reg .pred %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .u32 %r110; .reg .pred %r111; .reg .u64 %r114; mov.u64 %r92,%ar0; mov.u64 %r93,%ar1; .loc 1 81 0 and.b64 %r94,%r92,7; setp.ne.u64 %r95,%r94,0; @ %r95 bra $L6; .loc 1 84 0 ld.u64 %r86,[%r92]; add.u64 %r96,%r86,-72340172838076673; not.b64 %r97,%r86; and.b64 %r98,%r96,%r97; and.b64 %r99,%r98,-9187201950435737472; setp.eq.u64 %r100,%r99,0; @ %r100 bra $L7; mov.u64 %r84,%r92; bra $L2; $L6: mov.u64 %r84,%r92; $L2: .loc 1 90 0 ld.s8 %r102,[%r84]; cvt.u16.u32 %r101,%r102; setp.ne.u16 %r103,%r101,0; @ %r103 bra $L4; bra $L5; $L7: .loc 1 84 0 mov.u64 %r84,%r92; $L3: .loc 1 85 0 add.u64 %r84,%r84,8; .loc 1 84 0 ld.u64 %r78,[%r84]; add.u64 %r104,%r78,-72340172838076673; not.b64 %r105,%r78; and.b64 %r106,%r104,%r105; and.b64 %r107,%r106,-9187201950435737472; setp.eq.u64 %r108,%r107,0; @ %r108 bra $L3; bra $L2; $L4: .loc 1 91 0 add.u64 %r84,%r84,1; .loc 1 90 0 ld.s8 %r110,[%r84]; cvt.u16.u32 %r109,%r110; setp.ne.u16 %r111,%r109,0; @ %r111 bra $L4; $L5: .loc 1 100 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r84; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r93; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r114,[%value_in]; } .loc 1 104 0 mov.u64 %value,%r92; st.param.u64 [%value_out],%value; ret; } lib_a-strchr.o/ 0 0 0 644 5619 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strchr .visible .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strchr.c" // BEGIN GLOBAL FUNCTION DEF: strchr .visible .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r88; .reg .u64 %r89; .reg .u64 %r93; .reg .u32 %r98; .reg .u32 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u32 %r115; .reg .u32 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .u32 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .pred %r133; .reg .pred %r134; .reg .u16 %r135; .reg .u16 %r136; .reg .pred %r137; .reg .pred %r138; .reg .u16 %r139; .reg .pred %r140; .reg .u16 %r141; .reg .pred %r142; .reg .u64 %r143; .reg .pred %r144; .reg .u64 %r145; .reg .u64 %r146; .reg .u64 %r147; .reg .u64 %r148; .reg .pred %r149; .reg .u64 %r150; .reg .u64 %r151; .reg .u64 %r152; .reg .u64 %r153; .reg .pred %r154; .reg .u16 %r155; .reg .pred %r156; .reg .u16 %r157; .reg .pred %r158; .reg .pred %r159; .reg .u16 %r160; .reg .pred %r162; .reg .u64 %r163; .reg .pred %r164; .reg .u64 %r166; .reg .u64 %r167; .reg .u64 %r168; .reg .u64 %r169; .reg .u64 %r170; .reg .u64 %r171; .reg .u64 %r172; .reg .u64 %r173; .reg .pred %r174; .reg .u64 %r175; .reg .u64 %r176; .reg .u64 %r177; .reg .u64 %r178; .reg .u64 %r179; .reg .u64 %r180; .reg .u64 %r181; .reg .u64 %r182; .reg .pred %r183; .reg .pred %r184; .reg .u16 %r185; .reg .u16 %r186; .reg .pred %r187; .reg .pred %r188; .reg .u16 %r189; .reg .pred %r191; .reg .u16 %r193; .reg .u16 %r194; mov.u64 %r129,%ar0; mov.u32 %r130,%ar1; .loc 1 66 0 cvt.u32.u32 %r131,%r130; cvt.u32.u8 %r102,%r131; and.b64 %r127,%r129,7; .loc 1 73 0 setp.eq.u32 %r132,%r102,0; @ %r132 bra $L2; .loc 1 93 0 setp.eq.u64 %r133,%r127,0; @ %r133 bra $L3; .loc 1 95 0 ld.u8 %r121,[%r129]; setp.eq.u32 %r134,%r121,0; @ %r134 bra $L16; .loc 1 97 0 cvt.u16.u32 %r135,%r102; cvt.u16.u32 %r136,%r121; setp.eq.u16 %r137,%r135,%r136; @ %r137 bra $L17; cvt.u16.u32 %r194,%r102; bra $L5; $L2: .loc 1 75 0 setp.eq.u64 %r138,%r127,0; @ %r138 bra $L6; .loc 1 77 0 ld.u8 %r139,[%r129]; setp.eq.u16 %r140,%r139,0; @ ! %r140 bra $L7; bra $L18; $L8: ld.u8 %r141,[%r129]; setp.eq.u16 %r142,%r141,0; @ %r142 bra $L19; $L7: .loc 1 79 0 add.u64 %r129,%r129,1; .loc 1 75 0 and.b64 %r143,%r129,7; setp.ne.u64 %r144,%r143,0; @ %r144 bra $L8; $L6: .loc 1 83 0 ld.u64 %r106,[%r129]; not.b64 %r145,%r106; add.u64 %r146,%r106,-72340172838076673; and.b64 %r147,%r145,%r146; and.b64 %r148,%r147,-9187201950435737472; setp.ne.u64 %r149,%r148,0; @ %r149 bra $L9; $L10: .loc 1 84 0 add.u64 %r129,%r129,8; .loc 1 83 0 ld.u64 %r79,[%r129]; add.u64 %r150,%r79,-72340172838076673; not.b64 %r151,%r79; and.b64 %r152,%r150,%r151; and.b64 %r153,%r152,-9187201950435737472; setp.eq.u64 %r154,%r153,0; @ %r154 bra $L10; $L9: .loc 1 87 0 ld.u8 %r155,[%r129]; setp.eq.u16 %r156,%r155,0; @ %r156 bra $L20; $L11: .loc 1 88 0 add.u64 %r129,%r129,1; .loc 1 87 0 ld.u8 %r157,[%r129]; setp.ne.u16 %r158,%r157,0; @ %r158 bra $L11; .loc 1 88 0 mov.u64 %r128,%r129; bra $L1; $L12: .loc 1 95 0 ld.u8 %r85,[%r129]; setp.eq.u32 %r159,%r85,0; @ %r159 bra $L21; .loc 1 97 0 cvt.u16.u32 %r160,%r85; setp.eq.u16 %r162,%r160,%r194; @ %r162 bra $L22; $L5: .loc 1 99 0 add.u64 %r129,%r129,1; .loc 1 93 0 and.b64 %r163,%r129,7; setp.ne.u64 %r164,%r163,0; @ %r164 bra $L12; $L3: .loc 1 102 0 cvt.u64.u8 %r103,%r131; .loc 1 104 0 shl.b64 %r125,%r103,8; or.b64 %r124,%r103,%r125; shl.b64 %r123,%r124,16; or.b64 %r122,%r123,%r124; shl.b64 %r88,%r122,32; or.b64 %r104,%r88,%r122; .loc 1 107 0 ld.u64 %r108,[%r129]; xor.b64 %r107,%r104,%r108; not.b64 %r166,%r107; add.u64 %r167,%r107,-72340172838076673; and.b64 %r168,%r166,%r167; add.u64 %r169,%r108,-72340172838076673; not.b64 %r170,%r108; and.b64 %r171,%r169,%r170; or.b64 %r172,%r168,%r171; and.b64 %r173,%r172,-9187201950435737472; setp.ne.u64 %r174,%r173,0; @ %r174 bra $L13; $L14: .loc 1 108 0 add.u64 %r129,%r129,8; .loc 1 107 0 ld.u64 %r89,[%r129]; xor.b64 %r93,%r89,%r104; add.u64 %r175,%r89,-72340172838076673; not.b64 %r176,%r89; and.b64 %r177,%r175,%r176; add.u64 %r178,%r93,-72340172838076673; not.b64 %r179,%r93; and.b64 %r180,%r178,%r179; or.b64 %r181,%r177,%r180; and.b64 %r182,%r181,-9187201950435737472; setp.eq.u64 %r183,%r182,0; @ %r183 bra $L14; $L13: .loc 1 118 0 ld.u8 %r115,[%r129]; setp.eq.u32 %r184,%r115,0; @ %r184 bra $L23; cvt.u16.u32 %r185,%r102; cvt.u16.u32 %r186,%r115; setp.eq.u16 %r187,%r185,%r186; @ %r187 bra $L24; cvt.u16.u32 %r193,%r102; $L15: .loc 1 119 0 add.u64 %r129,%r129,1; .loc 1 118 0 ld.u8 %r98,[%r129]; setp.eq.u32 %r188,%r98,0; @ %r188 bra $L25; cvt.u16.u32 %r189,%r98; setp.ne.u16 %r191,%r189,%r193; @ %r191 bra $L15; .loc 1 119 0 mov.u64 %r128,%r129; bra $L1; $L16: .loc 1 96 0 mov.u64 %r128,0; bra $L1; $L17: .loc 1 97 0 mov.u64 %r128,%r129; bra $L1; $L18: .loc 1 77 0 mov.u64 %r128,%r129; bra $L1; $L19: .loc 1 79 0 mov.u64 %r128,%r129; bra $L1; $L20: .loc 1 87 0 mov.u64 %r128,%r129; bra $L1; $L21: .loc 1 96 0 mov.u64 %r128,0; bra $L1; $L22: .loc 1 99 0 mov.u64 %r128,%r129; bra $L1; $L23: .loc 1 96 0 mov.u64 %r128,0; bra $L1; $L24: .loc 1 118 0 mov.u64 %r128,%r129; bra $L1; $L25: .loc 1 96 0 mov.u64 %r128,0; $L1: .loc 1 123 0 mov.u64 %value,%r128; st.param.u64 [%value_out],%value; ret; } /618 0 0 0 644 1434 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strchrnul .visible .func (.param .u64 %value_out) strchrnul (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strchrnul.c" // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: strchrnul .visible .func (.param .u64 %value_out) strchrnul (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r25; .reg .u64 %r28; .reg .pred %r29; .reg .u64 %r31; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; .loc 1 44 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } mov.u64 %r23,%r28; .loc 1 46 0 setp.ne.u64 %r29,%r23,0; @ %r29 bra $L1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } add.u64 %r23,%r24,%r31; $L1: .loc 1 47 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-strcmp.o/ 0 0 0 644 2836 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcmp .visible .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strcmp.c" // BEGIN GLOBAL FUNCTION DEF: strcmp .visible .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r84; .reg .u32 %r86; .reg .u32 %r90; .reg .u32 %r95; .reg .u64 %r96; .reg .u32 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .pred %r106; .reg .u64 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .pred %r113; .reg .pred %r114; .reg .u16 %r115; .reg .u32 %r116; .reg .u16 %r117; .reg .pred %r118; .reg .u32 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .u64 %r123; .reg .pred %r124; .reg .u64 %r125; .reg .pred %r126; .reg .pred %r127; .reg .u16 %r128; .reg .u32 %r129; .reg .u16 %r130; .reg .pred %r131; .reg .u32 %r132; .reg .u32 %r133; mov.u64 %r102,%ar0; mov.u64 %r103,%ar1; .loc 1 78 0 or.b64 %r104,%r102,%r103; and.b64 %r105,%r104,7; setp.ne.u64 %r106,%r105,0; @ %r106 bra $L2; .loc 1 83 0 ld.u64 %r96,[%r103]; ld.u64 %r107,[%r102]; setp.ne.u64 %r108,%r96,%r107; @ %r108 bra $L2; .loc 1 87 0 add.u64 %r109,%r96,-72340172838076673; not.b64 %r110,%r96; and.b64 %r111,%r109,%r110; and.b64 %r112,%r111,-9187201950435737472; setp.ne.u64 %r113,%r112,0; @ ! %r113 bra $L4; bra $L8; $L2: .loc 1 99 0 ld.s8 %r95,[%r102]; setp.eq.u32 %r114,%r95,0; @ %r114 bra $L9; ld.s8 %r116,[%r103]; cvt.u16.u32 %r115,%r116; cvt.u16.u32 %r117,%r95; setp.eq.u16 %r118,%r115,%r117; @ %r118 bra $L6; cvt.u32.u32 %r119,%r95; cvt.u32.u8 %r90,%r119; bra $L5; $L7: .loc 1 87 0 add.u64 %r120,%r84,-72340172838076673; not.b64 %r121,%r84; and.b64 %r122,%r120,%r121; and.b64 %r123,%r122,-9187201950435737472; setp.ne.u64 %r124,%r123,0; @ %r124 bra $L10; $L4: .loc 1 90 0 add.u64 %r102,%r102,8; .loc 1 91 0 add.u64 %r103,%r103,8; .loc 1 83 0 ld.u64 %r84,[%r102]; ld.u64 %r125,[%r103]; setp.eq.u64 %r126,%r84,%r125; @ %r126 bra $L7; bra $L2; $L6: .loc 1 101 0 add.u64 %r102,%r102,1; .loc 1 102 0 add.u64 %r103,%r103,1; .loc 1 99 0 ld.s8 %r86,[%r102]; setp.eq.u32 %r127,%r86,0; @ %r127 bra $L11; ld.s8 %r129,[%r103]; cvt.u16.u32 %r128,%r129; cvt.u16.u32 %r130,%r86; setp.eq.u16 %r131,%r128,%r130; @ %r131 bra $L6; cvt.u32.u32 %r132,%r86; cvt.u32.u8 %r90,%r132; bra $L5; $L9: mov.u32 %r90,%r95; bra $L5; $L11: mov.u32 %r90,%r86; $L5: .loc 1 104 0 ld.u8 %r133,[%r103]; sub.u32 %r101,%r90,%r133; bra $L1; $L8: .loc 1 88 0 cvt.u32.u64 %r101,%r105; bra $L1; $L10: mov.u32 %r101,0; $L1: .loc 1 106 0 mov.u32 %value,%r101; st.param.u32 [%value_out],%value; ret; } lib_a-strcoll.o/0 0 0 644 1018 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcoll .visible .func (.param .u32 %value_out) strcoll (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strcoll.c" // BEGIN GLOBAL FUNCTION DECL: strcmp .extern .func (.param .u32 %value_out) strcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strcoll .visible .func (.param .u32 %value_out) strcoll (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r27; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 47 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),strcmp,(%out_arg1,%out_arg2); ld.param.u32 %r27,[%value_in]; } .loc 1 48 0 mov.u32 %value,%r27; st.param.u32 [%value_out],%value; ret; } lib_a-strcpy.o/ 0 0 0 644 1937 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcpy .visible .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strcpy.c" // BEGIN GLOBAL FUNCTION DEF: strcpy .visible .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r96; .reg .u64 %r100; .reg .u64 %r101; .reg .u64 %r102; .reg .u64 %r103; .reg .pred %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .pred %r109; .reg .u64 %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .pred %r114; .reg .u32 %r115; .reg .pred %r116; mov.u64 %r100,%ar0; mov.u64 %r101,%ar1; .loc 1 79 0 mov.u64 %r96,%r100; or.b64 %r102,%r101,%r100; and.b64 %r103,%r102,7; setp.eq.u64 %r104,%r103,0; @ %r104 bra $L2; .loc 1 73 0 mov.u64 %r88,%r100; bra $L4; $L6: mov.u64 %r88,%r100; $L4: mov.u64 %r87,%r88; mov.u64 %r86,%r101; bra $L3; $L2: .loc 1 86 0 ld.u64 %r79,[%r101]; add.u64 %r105,%r79,-72340172838076673; not.b64 %r106,%r79; and.b64 %r107,%r105,%r106; and.b64 %r108,%r107,-9187201950435737472; setp.ne.u64 %r109,%r108,0; @ %r109 bra $L6; $L5: .loc 1 88 0 add.u64 %r101,%r101,8; add.u64 %r88,%r96,8; st.u64 [%r96],%r79; .loc 1 86 0 ld.u64 %r79,[%r101]; mov.u64 %r96,%r88; add.u64 %r110,%r79,-72340172838076673; not.b64 %r111,%r79; and.b64 %r112,%r110,%r111; and.b64 %r113,%r112,-9187201950435737472; setp.eq.u64 %r114,%r113,0; @ %r114 bra $L5; bra $L4; $L3: .loc 1 95 0 ld.s8 %r85,[%r86]; cvt.u32.u32 %r115,%r85; st.u8 [%r87],%r115; add.u64 %r87,%r87,1; add.u64 %r86,%r86,1; setp.ne.u32 %r116,%r85,0; @ %r116 bra $L3; .loc 1 99 0 mov.u64 %value,%r100; st.param.u64 [%value_out],%value; ret; } lib_a-strcspn.o/0 0 0 644 1678 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strcspn .visible .func (.param .u64 %value_out) strcspn (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strcspn.c" // BEGIN GLOBAL FUNCTION DEF: strcspn .visible .func (.param .u64 %value_out) strcspn (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u16 %r64; .reg .pred %r66; .reg .pred %r67; .reg .u16 %r70; .reg .pred %r71; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; mov.u64 %r61,%ar0; mov.u64 %r62,%ar1; .loc 1 41 0 ld.s8 %r51,[%r61]; mov.u64 %r59,%r61; setp.ne.u32 %r63,%r51,0; @ %r63 bra $L2; mov.u64 %r60,0; bra $L1; $L5: .loc 1 45 0 cvt.u16.u32 %r64,%r50; setp.ne.u16 %r66,%r64,%r75; @ %r66 bra $L4; sub.u64 %r60,%r61,%r59; bra $L1; $L8: mov.u64 %r52,%r62; cvt.u16.u32 %r75,%r51; $L4: .loc 1 43 0 add.u64 %r52,%r52,1; ld.s8 %r50,[%r52]; setp.ne.u32 %r67,%r50,0; @ %r67 bra $L5; bra $L6; $L2: ld.s8 %r49,[%r62]; setp.eq.u32 %r74,%r49,0; .loc 1 45 0 cvt.u16.u32 %r76,%r49; $L7: .loc 1 43 0 @ %r74 bra $L6; .loc 1 45 0 cvt.u16.u32 %r70,%r51; setp.ne.u16 %r71,%r76,%r70; @ %r71 bra $L8; sub.u64 %r60,%r61,%r59; .loc 1 53 0 bra $L1; $L6: .loc 1 50 0 add.u64 %r61,%r61,1; .loc 1 41 0 ld.s8 %r51,[%r61]; setp.ne.u32 %r73,%r51,0; @ %r73 bra $L7; sub.u64 %r60,%r61,%r59; $L1: .loc 1 54 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } lib_a-strdup.o/ 0 0 0 644 1034 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strdup .visible .func (.param .u64 %value_out) strdup (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/string/strdup.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strdup_r .extern .func (.param .u64 %value_out) _strdup_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strdup .visible .func (.param .u64 %value_out) strdup (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r24; .reg .u64 %r27; .reg .u64 %r28; mov.u64 %r24,%ar0; .loc 1 10 0 ld.global.u64 %r27,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),_strdup_r,(%out_arg1,%out_arg2); ld.param.u64 %r28,[%value_in]; } .loc 1 11 0 mov.u64 %value,%r28; st.param.u64 [%value_out],%value; ret; } /637 0 0 0 644 1886 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strdup_r .visible .func (.param .u64 %value_out) _strdup_r (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strdup_r.c" // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: _strdup_r .visible .func (.param .u64 %value_out) _strdup_r (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r28; .reg .u64 %r31; .reg .pred %r32; .reg .u64 %r36; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; .loc 1 10 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r28,[%value_in]; } add.u64 %r23,%r28,1; .loc 1 11 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r23; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r31,[%value_in]; } .loc 1 12 0 setp.eq.u64 %r32,%r31,0; @ %r32 bra $L1; .loc 1 14 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r23; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r36,[%value_in]; } $L1: .loc 1 17 0 mov.u64 %value,%r31; st.param.u64 [%value_out],%value; ret; } /655 0 0 0 644 23233 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _strerror_r .visible .func (.param .u64 %value_out) _strerror_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/string/strerror.c" // BEGIN GLOBAL FUNCTION DECL: strerror .visible .func (.param .u64 %value_out) strerror (.param .u32 %in_ar0); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _user_strerror .extern .func (.param .u64 %value_out) _user_strerror (.param .u32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[16] = {66,97,100,32,102,105,108,101,32,110,117,109,98,101,114,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[12] = {78,111,32,99,104,105,108,100,114,101,110,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[29] = {68,101,115,116,105,110,97,116,105,111,110,32,97,100,100,114,101,115,115,32,114,101,113,117,105,114,101,100,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[18] = {78,111,32,109,111,114,101,32,112,114,111,99,101,115,115,101,115,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[17] = {78,111,116,32,101,110,111,117,103,104,32,115,112,97,99,101,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[18] = {80,101,114,109,105,115,115,105,111,110,32,100,101,110,105,101,100,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[12] = {66,97,100,32,97,100,100,114,101,115,115,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[24] = {68,101,118,105,99,101,32,111,114,32,114,101,115,111,117,114,99,101,32,98,117,115,121,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[12] = {70,105,108,101,32,101,120,105,115,116,115,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[18] = {67,114,111,115,115,45,100,101,118,105,99,101,32,108,105,110,107,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[15] = {78,111,32,115,117,99,104,32,100,101,118,105,99,101,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[16] = {78,111,116,32,97,32,100,105,114,101,99,116,111,114,121,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[13] = {72,111,115,116,32,105,115,32,100,111,119,110,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[31] = {67,111,110,110,101,99,116,105,111,110,32,97,108,114,101,97,100,121,32,105,110,32,112,114,111,103,114,101,115,115,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[15] = {73,115,32,97,32,100,105,114,101,99,116,111,114,121,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[17] = {73,110,118,97,108,105,100,32,97,114,103,117,109,101,110,116,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[36] = {78,101,116,119,111,114,107,32,105,110,116,101,114,102,97,99,101,32,105,115,32,110,111,116,32,99,111,110,102,105,103,117,114,101,100,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[30] = {84,111,111,32,109,97,110,121,32,111,112,101,110,32,102,105,108,101,115,32,105,110,32,115,121,115,116,101,109,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[20] = {84,111,111,32,109,97,110,121,32,111,112,101,110,32,102,105,108,101,115,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[23] = {78,111,116,32,97,32,99,104,97,114,97,99,116,101,114,32,100,101,118,105,99,101,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[15] = {84,101,120,116,32,102,105,108,101,32,98,117,115,121,0 }; // BEGIN VAR DEF: $LC31 .const .align 1 .u8 $LC31[15] = {70,105,108,101,32,116,111,111,32,108,97,114,103,101,0 }; // BEGIN VAR DEF: $LC32 .const .align 1 .u8 $LC32[20] = {72,111,115,116,32,105,115,32,117,110,114,101,97,99,104,97,98,108,101,0 }; // BEGIN VAR DEF: $LC33 .const .align 1 .u8 $LC33[24] = {78,111,32,115,112,97,99,101,32,108,101,102,116,32,111,110,32,100,101,118,105,99,101,0 }; // BEGIN VAR DEF: $LC34 .const .align 1 .u8 $LC34[14] = {78,111,116,32,115,117,112,112,111,114,116,101,100,0 }; // BEGIN VAR DEF: $LC35 .const .align 1 .u8 $LC35[13] = {73,108,108,101,103,97,108,32,115,101,101,107,0 }; // BEGIN VAR DEF: $LC36 .const .align 1 .u8 $LC36[22] = {82,101,97,100,45,111,110,108,121,32,102,105,108,101,32,115,121,115,116,101,109,0 }; // BEGIN VAR DEF: $LC37 .const .align 1 .u8 $LC37[15] = {84,111,111,32,109,97,110,121,32,108,105,110,107,115,0 }; // BEGIN VAR DEF: $LC38 .const .align 1 .u8 $LC38[12] = {66,114,111,107,101,110,32,112,105,112,101,0 }; // BEGIN VAR DEF: $LC39 .const .align 1 .u8 $LC39[14] = {77,97,116,104,32,97,114,103,117,109,101,110,116,0 }; // BEGIN VAR DEF: $LC40 .const .align 1 .u8 $LC40[17] = {82,101,115,117,108,116,32,116,111,111,32,108,97,114,103,101,0 }; // BEGIN VAR DEF: $LC41 .const .align 1 .u8 $LC41[27] = {78,111,32,109,101,115,115,97,103,101,32,111,102,32,100,101,115,105,114,101,100,32,116,121,112,101,0 }; // BEGIN VAR DEF: $LC42 .const .align 1 .u8 $LC42[19] = {73,100,101,110,116,105,102,105,101,114,32,114,101,109,111,118,101,100,0 }; // BEGIN VAR DEF: $LC43 .const .align 1 .u8 $LC43[9] = {68,101,97,100,108,111,99,107,0 }; // BEGIN VAR DEF: $LC44 .const .align 1 .u8 $LC44[23] = {78,101,116,119,111,114,107,32,105,115,32,117,110,114,101,97,99,104,97,98,108,101,0 }; // BEGIN VAR DEF: $LC45 .const .align 1 .u8 $LC45[8] = {78,111,32,108,111,99,107,0 }; // BEGIN VAR DEF: $LC46 .const .align 1 .u8 $LC46[13] = {78,111,116,32,97,32,115,116,114,101,97,109,0 }; // BEGIN VAR DEF: $LC47 .const .align 1 .u8 $LC47[21] = {83,116,114,101,97,109,32,105,111,99,116,108,32,116,105,109,101,111,117,116,0 }; // BEGIN VAR DEF: $LC48 .const .align 1 .u8 $LC48[20] = {78,111,32,115,116,114,101,97,109,32,114,101,115,111,117,114,99,101,115,0 }; // BEGIN VAR DEF: $LC49 .const .align 1 .u8 $LC49[24] = {86,105,114,116,117,97,108,32,99,105,114,99,117,105,116,32,105,115,32,103,111,110,101,0 }; // BEGIN VAR DEF: $LC50 .const .align 1 .u8 $LC50[15] = {80,114,111,116,111,99,111,108,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC51 .const .align 1 .u8 $LC51[17] = {85,110,107,110,111,119,110,32,112,114,111,116,111,99,111,108,0 }; // BEGIN VAR DEF: $LC52 .const .align 1 .u8 $LC52[19] = {77,117,108,116,105,104,111,112,32,97,116,116,101,109,112,116,101,100,0 }; // BEGIN VAR DEF: $LC53 .const .align 1 .u8 $LC53[12] = {66,97,100,32,109,101,115,115,97,103,101,0 }; // BEGIN VAR DEF: $LC54 .const .align 1 .u8 $LC54[25] = {70,117,110,99,116,105,111,110,32,110,111,116,32,105,109,112,108,101,109,101,110,116,101,100,0 }; // BEGIN VAR DEF: $LC55 .const .align 1 .u8 $LC55[20] = {68,105,114,101,99,116,111,114,121,32,110,111,116,32,101,109,112,116,121,0 }; // BEGIN VAR DEF: $LC56 .const .align 1 .u8 $LC56[27] = {70,105,108,101,32,111,114,32,112,97,116,104,32,110,97,109,101,32,116,111,111,32,108,111,110,103,0 }; // BEGIN VAR DEF: $LC57 .const .align 1 .u8 $LC57[24] = {84,111,111,32,109,97,110,121,32,115,121,109,98,111,108,105,99,32,108,105,110,107,115,0 }; // BEGIN VAR DEF: $LC58 .const .align 1 .u8 $LC58[26] = {78,111,32,98,117,102,102,101,114,32,115,112,97,99,101,32,97,118,97,105,108,97,98,108,101,0 }; // BEGIN VAR DEF: $LC59 .const .align 1 .u8 $LC59[48] = {65,100,100,114,101,115,115,32,102,97,109,105,108,121,32,110,111,116,32,115,117,112,112,111,114,116,101,100,32,98,121,32,112,114,111,116,111,99,111,108,32,102,97,109,105,108,121,0 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {83,117,99,99,101,115,115,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[10] = {78,111,116,32,111,119,110,101,114,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[26] = {78,111,32,115,117,99,104,32,102,105,108,101,32,111,114,32,100,105,114,101,99,116,111,114,121,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[16] = {78,111,32,115,117,99,104,32,112,114,111,99,101,115,115,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[24] = {73,110,116,101,114,114,117,112,116,101,100,32,115,121,115,116,101,109,32,99,97,108,108,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[10] = {73,47,79,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[26] = {78,111,32,115,117,99,104,32,100,101,118,105,99,101,32,111,114,32,97,100,100,114,101,115,115,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[18] = {65,114,103,32,108,105,115,116,32,116,111,111,32,108,111,110,103,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[18] = {69,120,101,99,32,102,111,114,109,97,116,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[25] = {83,111,99,107,101,116,32,97,108,114,101,97,100,121,32,99,111,110,110,101,99,116,101,100,0 }; // BEGIN VAR DEF: $LC60 .const .align 1 .u8 $LC60[31] = {80,114,111,116,111,99,111,108,32,119,114,111,110,103,32,116,121,112,101,32,102,111,114,32,115,111,99,107,101,116,0 }; // BEGIN VAR DEF: $LC61 .const .align 1 .u8 $LC61[31] = {83,111,99,107,101,116,32,111,112,101,114,97,116,105,111,110,32,111,110,32,110,111,110,45,115,111,99,107,101,116,0 }; // BEGIN VAR DEF: $LC62 .const .align 1 .u8 $LC62[23] = {80,114,111,116,111,99,111,108,32,110,111,116,32,97,118,97,105,108,97,98,108,101,0 }; // BEGIN VAR DEF: $LC63 .const .align 1 .u8 $LC63[19] = {67,111,110,110,101,99,116,105,111,110,32,114,101,102,117,115,101,100,0 }; // BEGIN VAR DEF: $LC64 .const .align 1 .u8 $LC64[23] = {65,100,100,114,101,115,115,32,97,108,114,101,97,100,121,32,105,110,32,117,115,101,0 }; // BEGIN VAR DEF: $LC65 .const .align 1 .u8 $LC65[33] = {83,111,102,116,119,97,114,101,32,99,97,117,115,101,100,32,99,111,110,110,101,99,116,105,111,110,32,97,98,111,114,116,0 }; // BEGIN VAR DEF: $LC66 .const .align 1 .u8 $LC66[24] = {83,111,99,107,101,116,32,105,115,32,110,111,116,32,99,111,110,110,101,99,116,101,100,0 }; // BEGIN VAR DEF: $LC67 .const .align 1 .u8 $LC67[28] = {83,111,99,107,101,116,32,105,115,32,97,108,114,101,97,100,121,32,99,111,110,110,101,99,116,101,100,0 }; // BEGIN VAR DEF: $LC68 .const .align 1 .u8 $LC68[19] = {79,112,101,114,97,116,105,111,110,32,99,97,110,99,101,108,101,100,0 }; // BEGIN VAR DEF: $LC69 .const .align 1 .u8 $LC69[22] = {83,116,97,116,101,32,110,111,116,32,114,101,99,111,118,101,114,97,98,108,101,0 }; // BEGIN VAR DEF: $LC70 .const .align 1 .u8 $LC70[20] = {80,114,101,118,105,111,117,115,32,111,119,110,101,114,32,100,105,101,100,0 }; // BEGIN VAR DEF: $LC71 .const .align 1 .u8 $LC71[34] = {79,112,101,114,97,116,105,111,110,32,110,111,116,32,115,117,112,112,111,114,116,101,100,32,111,110,32,115,111,99,107,101,116,0 }; // BEGIN VAR DEF: $LC72 .const .align 1 .u8 $LC72[17] = {77,101,115,115,97,103,101,32,116,111,111,32,108,111,110,103,0 }; // BEGIN VAR DEF: $LC73 .const .align 1 .u8 $LC73[21] = {67,111,110,110,101,99,116,105,111,110,32,116,105,109,101,100,32,111,117,116,0 }; // BEGIN VAR DEF: $LC74 .const .align 1 .u8 $LC74[1] = {0 }; // BEGIN GLOBAL FUNCTION DEF: _strerror_r .visible .func (.param .u64 %value_out) _strerror_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r22; .reg .u64 %r23; .reg .u32 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; .reg .pred %r30; .reg .pred %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; .reg .pred %r35; .reg .pred %r36; .reg .pred %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .pred %r41; .reg .pred %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .pred %r57; .reg .pred %r58; .reg .pred %r59; .reg .pred %r60; .reg .pred %r61; .reg .pred %r62; .reg .pred %r63; .reg .pred %r64; .reg .pred %r65; .reg .pred %r66; .reg .pred %r67; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .pred %r73; .reg .pred %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .pred %r78; .reg .pred %r79; .reg .pred %r80; .reg .pred %r81; .reg .pred %r82; .reg .pred %r83; .reg .pred %r84; .reg .pred %r85; .reg .pred %r86; .reg .pred %r87; .reg .pred %r88; .reg .pred %r89; .reg .pred %r90; .reg .pred %r91; .reg .pred %r92; .reg .pred %r93; .reg .pred %r94; .reg .pred %r95; .reg .pred %r96; .reg .pred %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .pred %r102; .reg .pred %r103; .reg .pred %r104; .reg .pred %r105; .reg .pred %r106; .reg .pred %r107; .reg .pred %r108; .reg .pred %r109; .reg .pred %r110; .reg .pred %r111; .reg .pred %r112; .reg .pred %r113; .reg .pred %r114; .reg .pred %r115; .reg .pred %r116; .reg .u64 %r120; .reg .pred %r121; mov.u64 %r23,%ar0; mov.u32 %r24,%ar1; mov.u32 %r25,%ar2; mov.u64 %r26,%ar3; .loc 1 365 0 setp.eq.u32 %r27,%r24,45; @ %r27 bra $L3; setp.gt.s32 %r28,%r24,45; @ %r28 bra $L4; setp.eq.u32 %r29,%r24,18; @ %r29 bra $L5; setp.gt.s32 %r30,%r24,18; @ %r30 bra $L6; setp.eq.u32 %r31,%r24,8; @ %r31 bra $L7; setp.gt.s32 %r32,%r24,8; @ %r32 bra $L8; setp.eq.u32 %r33,%r24,3; @ %r33 bra $L9; setp.gt.s32 %r34,%r24,3; @ %r34 bra $L10; setp.eq.u32 %r35,%r24,1; @ %r35 bra $L11; setp.gt.s32 %r36,%r24,1; @ %r36 bra $L12; setp.eq.u32 %r37,%r24,0; @ %r37 bra $L96; bra $L2; $L10: setp.eq.u32 %r38,%r24,5; @ %r38 bra $L14; setp.lt.s32 %r39,%r24,5; @ %r39 bra $L15; setp.eq.u32 %r40,%r24,6; @ %r40 bra $L16; setp.eq.u32 %r41,%r24,7; @ %r41 bra $L17; bra $L2; $L8: setp.eq.u32 %r42,%r24,12; @ %r42 bra $L18; setp.gt.s32 %r43,%r24,12; @ %r43 bra $L19; setp.eq.u32 %r44,%r24,10; @ %r44 bra $L20; setp.gt.s32 %r45,%r24,10; @ ! %r45 bra $L97; bra $L21; $L19: setp.eq.u32 %r46,%r24,14; @ %r46 bra $L23; setp.lt.s32 %r47,%r24,14; @ %r47 bra $L24; setp.eq.u32 %r48,%r24,16; @ %r48 bra $L25; setp.eq.u32 %r49,%r24,17; @ %r49 bra $L26; bra $L2; $L6: setp.eq.u32 %r50,%r24,27; @ %r50 bra $L27; setp.gt.s32 %r51,%r24,27; @ %r51 bra $L28; setp.eq.u32 %r52,%r24,22; @ %r52 bra $L29; setp.gt.s32 %r53,%r24,22; @ %r53 bra $L30; setp.eq.u32 %r54,%r24,20; @ %r54 bra $L31; setp.gt.s32 %r55,%r24,20; @ ! %r55 bra $L98; bra $L32; $L30: setp.eq.u32 %r56,%r24,24; @ %r56 bra $L34; setp.lt.s32 %r57,%r24,24; @ %r57 bra $L35; setp.eq.u32 %r58,%r24,25; @ %r58 bra $L36; setp.eq.u32 %r59,%r24,26; @ %r59 bra $L37; bra $L2; $L28: setp.eq.u32 %r60,%r24,32; @ %r60 bra $L38; setp.gt.s32 %r61,%r24,32; @ %r61 bra $L39; setp.eq.u32 %r62,%r24,29; @ %r62 bra $L40; setp.lt.s32 %r63,%r24,29; @ %r63 bra $L41; setp.eq.u32 %r64,%r24,30; @ %r64 bra $L42; setp.eq.u32 %r65,%r24,31; @ %r65 bra $L43; bra $L2; $L39: setp.eq.u32 %r66,%r24,34; @ %r66 bra $L44; setp.lt.s32 %r67,%r24,34; @ %r67 bra $L45; setp.eq.u32 %r68,%r24,35; @ %r68 bra $L46; setp.eq.u32 %r69,%r24,36; @ %r69 bra $L47; bra $L2; $L4: setp.eq.u32 %r70,%r24,111; @ %r70 bra $L48; setp.gt.s32 %r71,%r24,111; @ %r71 bra $L49; setp.eq.u32 %r72,%r24,88; @ %r72 bra $L50; setp.gt.s32 %r73,%r24,88; @ %r73 bra $L51; setp.eq.u32 %r74,%r24,63; @ %r74 bra $L52; setp.gt.s32 %r75,%r24,63; @ %r75 bra $L53; setp.eq.u32 %r76,%r24,60; @ %r76 bra $L54; setp.eq.u32 %r77,%r24,62; @ %r77 bra $L55; setp.eq.u32 %r78,%r24,46; @ ! %r78 bra $L2; bra $L56; $L53: setp.eq.u32 %r79,%r24,71; @ %r79 bra $L57; setp.gt.s32 %r80,%r24,71; @ %r80 bra $L58; setp.eq.u32 %r81,%r24,67; @ %r81 bra $L59; bra $L2; $L58: setp.eq.u32 %r82,%r24,74; @ %r82 bra $L60; setp.eq.u32 %r83,%r24,77; @ %r83 bra $L61; bra $L2; $L51: setp.eq.u32 %r84,%r24,105; @ %r84 bra $L62; setp.gt.s32 %r85,%r24,105; @ %r85 bra $L63; setp.eq.u32 %r86,%r24,91; @ %r86 bra $L64; setp.gt.s32 %r87,%r24,91; @ %r87 bra $L65; setp.eq.u32 %r88,%r24,90; @ %r88 bra $L66; bra $L2; $L65: setp.eq.u32 %r89,%r24,92; @ %r89 bra $L67; setp.eq.u32 %r90,%r24,95; @ %r90 bra $L68; bra $L2; $L63: setp.eq.u32 %r91,%r24,107; @ %r91 bra $L69; setp.lt.s32 %r92,%r24,107; @ %r92 bra $L70; setp.eq.u32 %r93,%r24,108; @ %r93 bra $L71; setp.eq.u32 %r94,%r24,109; @ %r94 bra $L72; bra $L2; $L49: setp.eq.u32 %r95,%r24,120; @ %r95 bra $L73; setp.gt.s32 %r96,%r24,120; @ %r96 bra $L74; setp.eq.u32 %r97,%r24,115; @ %r97 bra $L75; setp.gt.s32 %r98,%r24,115; @ %r98 bra $L76; setp.eq.u32 %r99,%r24,113; @ %r99 bra $L77; setp.gt.s32 %r100,%r24,113; @ ! %r100 bra $L99; bra $L78; $L76: setp.eq.u32 %r101,%r24,117; @ %r101 bra $L80; setp.lt.s32 %r102,%r24,117; @ %r102 bra $L81; setp.eq.u32 %r103,%r24,118; @ %r103 bra $L82; setp.eq.u32 %r104,%r24,119; @ %r104 bra $L83; bra $L2; $L74: setp.eq.u32 %r105,%r24,128; @ %r105 bra $L84; setp.gt.s32 %r106,%r24,128; @ %r106 bra $L85; setp.eq.u32 %r107,%r24,122; @ %r107 bra $L86; setp.lt.s32 %r108,%r24,122; @ %r108 bra $L87; setp.eq.u32 %r109,%r24,123; @ %r109 bra $L88; setp.eq.u32 %r110,%r24,127; @ %r110 bra $L89; bra $L2; $L85: setp.eq.u32 %r111,%r24,140; @ %r111 bra $L90; setp.gt.s32 %r112,%r24,140; @ %r112 bra $L91; setp.eq.u32 %r113,%r24,134; @ %r113 bra $L92; bra $L2; $L91: setp.eq.u32 %r114,%r24,141; @ %r114 bra $L93; setp.eq.u32 %r115,%r24,142; @ %r115 bra $L94; bra $L2; $L11: .loc 1 373 0 cvta.const.u64 %r22,$LC1; bra $L1; $L12: .loc 1 378 0 cvta.const.u64 %r22,$LC2; .loc 1 379 0 bra $L1; $L9: .loc 1 383 0 cvta.const.u64 %r22,$LC3; .loc 1 384 0 bra $L1; $L15: .loc 1 388 0 cvta.const.u64 %r22,$LC4; .loc 1 389 0 bra $L1; $L14: .loc 1 393 0 cvta.const.u64 %r22,$LC5; .loc 1 394 0 bra $L1; $L16: .loc 1 399 0 cvta.const.u64 %r22,$LC6; .loc 1 400 0 bra $L1; $L17: .loc 1 404 0 cvta.const.u64 %r22,$LC7; .loc 1 405 0 bra $L1; $L7: .loc 1 409 0 cvta.const.u64 %r22,$LC8; .loc 1 410 0 bra $L1; $L73: .loc 1 414 0 cvta.const.u64 %r22,$LC9; .loc 1 415 0 bra $L1; $L97: .loc 1 419 0 cvta.const.u64 %r22,$LC10; .loc 1 420 0 bra $L1; $L20: .loc 1 424 0 cvta.const.u64 %r22,$LC11; .loc 1 425 0 bra $L1; $L87: .loc 1 429 0 cvta.const.u64 %r22,$LC12; .loc 1 430 0 bra $L1; $L21: .loc 1 434 0 cvta.const.u64 %r22,$LC13; .loc 1 435 0 bra $L1; $L18: .loc 1 439 0 cvta.const.u64 %r22,$LC14; .loc 1 440 0 bra $L1; $L24: .loc 1 444 0 cvta.const.u64 %r22,$LC15; .loc 1 445 0 bra $L1; $L23: .loc 1 449 0 cvta.const.u64 %r22,$LC16; .loc 1 450 0 bra $L1; $L25: .loc 1 459 0 cvta.const.u64 %r22,$LC17; .loc 1 460 0 bra $L1; $L26: .loc 1 464 0 cvta.const.u64 %r22,$LC18; .loc 1 465 0 bra $L1; $L5: .loc 1 469 0 cvta.const.u64 %r22,$LC19; .loc 1 470 0 bra $L1; $L98: .loc 1 474 0 cvta.const.u64 %r22,$LC20; .loc 1 475 0 bra $L1; $L31: .loc 1 479 0 cvta.const.u64 %r22,$LC21; .loc 1 480 0 bra $L1; $L80: .loc 1 484 0 cvta.const.u64 %r22,$LC22; .loc 1 485 0 bra $L1; $L83: .loc 1 489 0 cvta.const.u64 %r22,$LC23; .loc 1 490 0 bra $L1; $L32: .loc 1 494 0 cvta.const.u64 %r22,$LC24; .loc 1 495 0 bra $L1; $L29: .loc 1 499 0 cvta.const.u64 %r22,$LC25; .loc 1 500 0 bra $L1; $L75: .loc 1 504 0 cvta.const.u64 %r22,$LC26; .loc 1 505 0 bra $L1; $L35: .loc 1 509 0 cvta.const.u64 %r22,$LC27; .loc 1 510 0 bra $L1; $L34: .loc 1 514 0 cvta.const.u64 %r22,$LC28; .loc 1 515 0 bra $L1; $L36: .loc 1 519 0 cvta.const.u64 %r22,$LC29; .loc 1 520 0 bra $L1; $L37: .loc 1 524 0 cvta.const.u64 %r22,$LC30; .loc 1 525 0 bra $L1; $L27: .loc 1 529 0 cvta.const.u64 %r22,$LC31; .loc 1 530 0 bra $L1; $L82: .loc 1 534 0 cvta.const.u64 %r22,$LC32; .loc 1 535 0 bra $L1; $L41: .loc 1 539 0 cvta.const.u64 %r22,$LC33; .loc 1 540 0 bra $L1; $L92: .loc 1 544 0 cvta.const.u64 %r22,$LC34; .loc 1 545 0 bra $L1; $L40: .loc 1 549 0 cvta.const.u64 %r22,$LC35; .loc 1 550 0 bra $L1; $L42: .loc 1 554 0 cvta.const.u64 %r22,$LC36; .loc 1 555 0 bra $L1; $L43: .loc 1 559 0 cvta.const.u64 %r22,$LC37; .loc 1 560 0 bra $L1; $L38: .loc 1 564 0 cvta.const.u64 %r22,$LC38; .loc 1 565 0 bra $L1; $L45: .loc 1 569 0 cvta.const.u64 %r22,$LC39; .loc 1 570 0 bra $L1; $L44: .loc 1 574 0 cvta.const.u64 %r22,$LC40; .loc 1 575 0 bra $L1; $L46: .loc 1 579 0 cvta.const.u64 %r22,$LC41; .loc 1 580 0 bra $L1; $L47: .loc 1 584 0 cvta.const.u64 %r22,$LC42; .loc 1 585 0 bra $L1; $L3: .loc 1 589 0 cvta.const.u64 %r22,$LC43; .loc 1 590 0 bra $L1; $L78: .loc 1 594 0 cvta.const.u64 %r22,$LC44; .loc 1 595 0 bra $L1; $L56: .loc 1 599 0 cvta.const.u64 %r22,$LC45; .loc 1 600 0 bra $L1; $L54: .loc 1 604 0 cvta.const.u64 %r22,$LC46; .loc 1 605 0 bra $L1; $L55: .loc 1 609 0 cvta.const.u64 %r22,$LC47; .loc 1 610 0 bra $L1; $L52: .loc 1 614 0 cvta.const.u64 %r22,$LC48; .loc 1 615 0 bra $L1; $L59: .loc 1 634 0 cvta.const.u64 %r22,$LC49; .loc 1 635 0 bra $L1; $L57: .loc 1 654 0 cvta.const.u64 %r22,$LC50; .loc 1 655 0 bra $L1; $L88: .loc 1 659 0 cvta.const.u64 %r22,$LC51; .loc 1 660 0 bra $L1; $L60: .loc 1 664 0 cvta.const.u64 %r22,$LC52; .loc 1 665 0 bra $L1; $L61: .loc 1 669 0 cvta.const.u64 %r22,$LC53; .loc 1 670 0 bra $L1; $L50: .loc 1 699 0 cvta.const.u64 %r22,$LC54; .loc 1 700 0 bra $L1; $L66: .loc 1 709 0 cvta.const.u64 %r22,$LC55; .loc 1 710 0 bra $L1; $L64: .loc 1 714 0 cvta.const.u64 %r22,$LC56; .loc 1 715 0 bra $L1; $L67: .loc 1 719 0 cvta.const.u64 %r22,$LC57; .loc 1 720 0 bra $L1; $L62: .loc 1 724 0 cvta.const.u64 %r22,$LC58; .loc 1 725 0 bra $L1; $L70: .loc 1 729 0 cvta.const.u64 %r22,$LC59; .loc 1 730 0 bra $L1; $L69: .loc 1 734 0 cvta.const.u64 %r22,$LC60; .loc 1 735 0 bra $L1; $L71: .loc 1 739 0 cvta.const.u64 %r22,$LC61; .loc 1 740 0 bra $L1; $L72: .loc 1 744 0 cvta.const.u64 %r22,$LC62; .loc 1 745 0 bra $L1; $L48: .loc 1 754 0 cvta.const.u64 %r22,$LC63; .loc 1 755 0 bra $L1; $L99: .loc 1 759 0 cvta.const.u64 %r22,$LC64; .loc 1 760 0 bra $L1; $L77: .loc 1 764 0 cvta.const.u64 %r22,$LC65; .loc 1 765 0 bra $L1; $L84: .loc 1 774 0 cvta.const.u64 %r22,$LC66; .loc 1 775 0 bra $L1; $L89: .loc 1 784 0 cvta.const.u64 %r22,$LC67; .loc 1 785 0 bra $L1; $L90: .loc 1 789 0 cvta.const.u64 %r22,$LC68; .loc 1 790 0 bra $L1; $L93: .loc 1 794 0 cvta.const.u64 %r22,$LC69; .loc 1 795 0 bra $L1; $L94: .loc 1 799 0 cvta.const.u64 %r22,$LC70; .loc 1 800 0 bra $L1; $L68: .loc 1 809 0 cvta.const.u64 %r22,$LC71; .loc 1 810 0 bra $L1; $L86: .loc 1 814 0 cvta.const.u64 %r22,$LC72; .loc 1 815 0 bra $L1; $L81: .loc 1 819 0 cvta.const.u64 %r22,$LC73; .loc 1 820 0 bra $L1; $L2: .loc 1 823 0 setp.ne.u64 %r116,%r26,0; .loc 1 824 0 selp.u64 %r26,%r26,%r23,%r116; .loc 1 825 0 { .param .u64 %value_in; .param .u32 %out_arg1; st.param.u32 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; call (%value_in),_user_strerror,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r120,[%value_in]; } mov.u64 %r22,%r120; setp.ne.u64 %r121,%r22,0; @ %r121 bra $L1; .loc 1 826 0 cvta.const.u64 %r22,$LC74; bra $L1; $L96: .loc 1 368 0 cvta.const.u64 %r22,$LC0; $L1: .loc 1 831 0 mov.u64 %value,%r22; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strerror .visible .func (.param .u64 %value_out) strerror (.param .u32 %in_ar0) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r24; .reg .u32 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; mov.u32 %r24,%ar0; .loc 1 837 0 ld.global.u64 %r29,[_impure_ptr]; mov.u64 %r28,0; cvt.u32.u64 %r27,%r28; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r24; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r28; call (%value_in),_strerror_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 838 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } /673 0 0 0 644 2311 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strerror_r .visible .func (.param .u64 %value_out) strerror_r (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strerror_r.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strerror_r .extern .func (.param .u64 %value_out) _strerror_r (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u32 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strcpy .extern .func (.param .u64 %value_out) strcpy (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strerror_r .visible .func (.param .u64 %value_out) strerror_r (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r35; .reg .pred %r36; .reg .u64 %r39; mov.u32 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; .loc 1 80 0 ld.global.u64 %r32,[_impure_ptr]; mov.u64 %r31,0; mov.u32 %r30,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r32; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r31; call (%value_in),_strerror_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r33,[%value_in]; } mov.u64 %r24,%r33; .loc 1 82 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r35,[%value_in]; } setp.ge.u64 %r36,%r35,%r27; @ %r36 bra $L1; .loc 1 84 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),strcpy,(%out_arg1,%out_arg2); ld.param.u64 %r39,[%value_in]; } mov.u64 %r24,%r39; $L1: .loc 1 85 0 mov.u64 %value,%r24; st.param.u64 [%value_out],%value; ret; } lib_a-strlcat.o/0 0 0 644 2530 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlcat .visible .func (.param .u64 %value_out) strlcat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strlcat.c" // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DEF: strlcat .visible .func (.param .u64 %value_out) strlcat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r51; .reg .u64 %r54; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .u16 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r72; .reg .u16 %r73; .reg .u32 %r74; .reg .pred %r75; .reg .pred %r76; .reg .pred %r77; .reg .u64 %r79; .reg .pred %r80; .reg .u32 %r81; .reg .pred %r82; .reg .u64 %r83; .reg .u32 %r84; mov.u64 %r65,%ar0; mov.u64 %r66,%ar1; mov.u64 %r67,%ar2; mov.u64 %r62,%r65; .loc 1 56 0 setp.eq.u64 %r68,%r67,0; @ %r68 bra $L11; ld.s8 %r70,[%r65]; cvt.u16.u32 %r69,%r70; setp.eq.u16 %r71,%r69,0; @ %r71 bra $L12; add.u64 %r54,%r65,%r67; $L6: .loc 1 57 0 add.u64 %r65,%r65,1; .loc 1 56 0 setp.ne.u64 %r72,%r65,%r54; @ %r72 bra $L4; sub.u64 %r64,%r65,%r62; sub.u64 %r67,%r67,%r64; bra $L5; $L4: ld.s8 %r74,[%r65]; cvt.u16.u32 %r73,%r74; setp.ne.u16 %r75,%r73,0; @ %r75 bra $L6; sub.u64 %r64,%r65,%r62; sub.u64 %r67,%r67,%r64; $L5: .loc 1 61 0 setp.eq.u64 %r76,%r67,0; @ ! %r76 bra $L3; bra $L2; $L12: .loc 1 56 0 mov.u64 %r64,0; $L3: .loc 1 63 0 ld.s8 %r51,[%r66]; mov.u64 %r63,%r66; setp.ne.u32 %r77,%r51,0; @ %r77 bra $L7; bra $L8; $L11: .loc 1 56 0 mov.u64 %r64,%r67; $L2: .loc 1 62 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r66; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r79,[%value_in]; } add.u64 %r64,%r64,%r79; bra $L1; $L7: .loc 1 64 0 setp.eq.u64 %r80,%r67,1; @ %r80 bra $L10; .loc 1 65 0 cvt.u32.u32 %r81,%r51; st.u8 [%r65],%r81; .loc 1 66 0 add.u64 %r67,%r67,-1; .loc 1 65 0 add.u64 %r65,%r65,1; $L10: .loc 1 68 0 add.u64 %r66,%r66,1; .loc 1 63 0 ld.s8 %r51,[%r66]; setp.ne.u32 %r82,%r51,0; @ %r82 bra $L7; sub.u64 %r83,%r66,%r63; add.u64 %r64,%r64,%r83; $L8: .loc 1 70 0 mov.u32 %r84,0; st.u8 [%r65],%r84; $L1: .loc 1 73 0 mov.u64 %value,%r64; st.param.u64 [%value_out],%value; ret; } lib_a-strlcpy.o/0 0 0 644 1813 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlcpy .visible .func (.param .u64 %value_out) strlcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strlcpy.c" // BEGIN GLOBAL FUNCTION DEF: strlcpy .visible .func (.param .u64 %value_out) strlcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r49; .reg .u64 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .pred %r68; .reg .pred %r69; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r72; .reg .u32 %r73; .reg .u16 %r74; .reg .u32 %r75; .reg .pred %r76; .reg .u64 %r78; mov.u64 %r65,%ar0; mov.u64 %r66,%ar1; mov.u64 %r67,%ar2; .loc 1 53 0 setp.eq.u64 %r68,%r67,0; @ %r68 bra $L7; add.u64 %r56,%r67,-1; setp.eq.u64 %r69,%r56,0; @ %r69 bra $L8; mov.u64 %r57,%r65; mov.u64 %r62,%r66; $L5: add.u64 %r55,%r62,1; add.u64 %r65,%r65,1; .loc 1 55 0 ld.s8 %r49,[%r62]; cvt.u32.u32 %r70,%r49; st.u8 [%r57],%r70; setp.eq.u32 %r71,%r49,0; @ %r71 bra $L4; .loc 1 57 0 add.u64 %r56,%r56,-1; mov.u64 %r57,%r65; mov.u64 %r62,%r55; setp.ne.u64 %r72,%r56,0; @ %r72 bra $L5; bra $L3; $L8: .loc 1 49 0 mov.u64 %r55,%r66; $L3: .loc 1 63 0 mov.u32 %r73,0; st.u8 [%r65],%r73; bra $L2; $L7: .loc 1 49 0 mov.u64 %r55,%r66; $L2: mov.u64 %r63,%r55; $L6: add.u64 %r63,%r63,1; mov.u64 %r55,%r63; .loc 1 64 0 ld.s8 %r75,[%r63+-1]; cvt.u16.u32 %r74,%r75; setp.ne.u16 %r76,%r74,0; @ %r76 bra $L6; $L4: .loc 1 68 0 sub.u64 %r78,%r55,%r66; add.u64 %value,%r78,-1; .loc 1 69 0 st.param.u64 [%value_out],%value; ret; } lib_a-strlen.o/ 0 0 0 644 2295 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlen .visible .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/string/strlen.c" // BEGIN GLOBAL FUNCTION DEF: strlen .visible .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %r79; .reg .u64 %r87; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u16 %r103; .reg .u32 %r104; .reg .pred %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u64 %r109; .reg .pred %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .pred %r115; .reg .u64 %r116; .reg .u64 %r117; .reg .u64 %r118; .reg .u64 %r119; .reg .pred %r120; .reg .u16 %r121; .reg .u32 %r122; .reg .pred %r123; .reg .u16 %r124; .reg .u32 %r125; .reg .pred %r126; mov.u64 %r100,%ar0; mov.u64 %r98,%r100; .loc 1 66 0 and.b64 %r101,%r100,7; setp.eq.u64 %r102,%r101,0; @ %r102 bra $L2; .loc 1 68 0 ld.s8 %r104,[%r100]; cvt.u16.u32 %r103,%r104; setp.eq.u16 %r105,%r103,0; @ ! %r105 bra $L4; bra $L11; $L6: ld.s8 %r107,[%r100]; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L4; sub.u64 %r99,%r100,%r98; bra $L1; $L11: mov.u64 %r99,0; .loc 1 69 0 bra $L1; $L4: .loc 1 70 0 add.u64 %r100,%r100,1; .loc 1 66 0 and.b64 %r109,%r100,7; setp.ne.u64 %r110,%r109,0; @ %r110 bra $L6; $L2: .loc 1 76 0 ld.u64 %r87,[%r100]; add.u64 %r111,%r87,-72340172838076673; not.b64 %r112,%r87; and.b64 %r113,%r111,%r112; and.b64 %r114,%r113,-9187201950435737472; setp.ne.u64 %r115,%r114,0; @ %r115 bra $L7; $L8: .loc 1 77 0 add.u64 %r100,%r100,8; .loc 1 76 0 ld.u64 %r79,[%r100]; add.u64 %r116,%r79,-72340172838076673; not.b64 %r117,%r79; and.b64 %r118,%r116,%r117; and.b64 %r119,%r118,-9187201950435737472; setp.eq.u64 %r120,%r119,0; @ %r120 bra $L8; $L7: .loc 1 85 0 ld.s8 %r122,[%r100]; cvt.u16.u32 %r121,%r122; setp.eq.u16 %r123,%r121,0; @ %r123 bra $L9; $L10: .loc 1 86 0 add.u64 %r100,%r100,1; .loc 1 85 0 ld.s8 %r125,[%r100]; cvt.u16.u32 %r124,%r125; setp.ne.u16 %r126,%r124,0; @ %r126 bra $L10; $L9: .loc 1 87 0 sub.u64 %r99,%r100,%r98; $L1: .loc 1 88 0 mov.u64 %value,%r99; st.param.u64 [%value_out],%value; ret; } lib_a-strlwr.o/ 0 0 0 644 1415 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strlwr .visible .func (.param .u64 %value_out) strlwr (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/string/strlwr.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strlwr .visible .func (.param .u64 %value_out) strlwr (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r58; .reg .u64 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u16 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r76; mov.u64 %r60,%ar0; .loc 1 41 0 ld.u8 %r55,[%r60]; setp.eq.u32 %r61,%r55,0; @ %r61 bra $L2; mov.u64 %r58,%r60; $L4: mov.u32 %r56,%r55; .loc 1 43 0 cvt.u32.u32 %r63,%r56; cvt.u64.u8 %r62,%r63; ld.global.u64 %r64,[__ctype_ptr__]; add.u64 %r65,%r64,%r62; ld.u8 %r76,[%r65+1]; mov.u16 %r69,%r76; and.b16 %r68,%r69,3; cvt.u32.u16 %r72,%r68; cvt.s32.s8 %r71,%r72; cvt.u16.u32 %r70,%r71; setp.ne.u16 %r73,%r70,1; @ %r73 bra $L3; add.u32 %r56,%r56,32; $L3: st.u8 [%r58],%r56; .loc 1 41 0 add.u64 %r58,%r58,1; ld.u8 %r55,[%r58]; setp.ne.u32 %r74,%r55,0; @ %r74 bra $L4; $L2: .loc 1 46 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } /693 0 0 0 644 2514 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncasecmp .visible .func (.param .u32 %value_out) strncasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strncasecmp.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strncasecmp .visible .func (.param .u32 %value_out) strncasecmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r49; .reg .u32 %r58; .reg .u32 %r62; .reg .u64 %r65; .reg .u64 %r67; .reg .u64 %r68; .reg .u32 %r70; .reg .u64 %r71; .reg .u64 %r72; .reg .u64 %r73; .reg .pred %r74; .reg .u64 %r75; .reg .u32 %r76; .reg .u64 %r77; .reg .u16 %r80; .reg .u16 %r81; .reg .u16 %r82; .reg .u32 %r83; .reg .u32 %r84; .reg .pred %r85; .reg .u64 %r86; .reg .u32 %r87; .reg .u64 %r88; .reg .u16 %r91; .reg .u16 %r92; .reg .u16 %r93; .reg .u32 %r94; .reg .u32 %r95; .reg .pred %r96; .reg .u32 %r97; .reg .pred %r98; .reg .pred %r99; .reg .pred %r100; .reg .pred %r101; .reg .u16 %r103; mov.u64 %r71,%ar0; mov.u64 %r72,%ar1; mov.u64 %r73,%ar2; .loc 1 55 0 setp.eq.u64 %r74,%r73,0; @ %r74 bra $L7; .loc 1 57 0 ld.global.u64 %r49,[__ctype_ptr__]; mov.u64 %r68,%r71; mov.u64 %r67,%r72; add.u64 %r65,%r68,%r73; $L6: ld.u8 %r58,[%r68]; cvt.u32.u32 %r76,%r58; cvt.u64.u8 %r75,%r76; add.u64 %r77,%r49,%r75; ld.u8 %r103,[%r77+1]; mov.u16 %r81,%r103; and.b16 %r80,%r81,3; cvt.u32.u16 %r84,%r80; cvt.s32.s8 %r83,%r84; cvt.u16.u32 %r82,%r83; setp.ne.u16 %r85,%r82,1; @ %r85 bra $L3; add.u32 %r58,%r58,32; $L3: .loc 1 58 0 ld.u8 %r62,[%r67]; cvt.u32.u32 %r87,%r62; cvt.u64.u8 %r86,%r87; add.u64 %r88,%r49,%r86; ld.u8 %r103,[%r88+1]; mov.u16 %r92,%r103; and.b16 %r91,%r92,3; cvt.u32.u16 %r95,%r91; cvt.s32.s8 %r94,%r95; cvt.u16.u32 %r93,%r94; setp.ne.u16 %r96,%r93,1; @ %r96 bra $L4; add.u32 %r97,%r62,32; .loc 1 59 0 sub.u32 %r70,%r58,%r97; setp.ne.u32 %r98,%r70,0; @ ! %r98 bra $L5; bra $L1; $L4: sub.u32 %r70,%r58,%r62; setp.ne.u32 %r99,%r70,0; @ %r99 bra $L1; setp.eq.u32 %r100,%r62,0; @ %r100 bra $L1; $L5: add.u64 %r68,%r68,1; add.u64 %r67,%r67,1; .loc 1 55 0 setp.ne.u64 %r101,%r65,%r68; @ %r101 bra $L6; mov.u32 %r70,0; bra $L1; $L7: cvt.u32.u64 %r70,%r73; $L1: .loc 1 63 0 mov.u32 %value,%r70; st.param.u32 [%value_out],%value; ret; } lib_a-strncat.o/0 0 0 644 2650 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncat .visible .func (.param .u64 %value_out) strncat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strncat.c" // BEGIN GLOBAL FUNCTION DEF: strncat .visible .func (.param .u64 %value_out) strncat (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r78; .reg .u64 %r84; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r89; .reg .u64 %r91; .reg .u64 %r96; .reg .u64 %r98; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r101; .reg .pred %r102; .reg .u64 %r103; .reg .u64 %r104; .reg .u64 %r105; .reg .u64 %r106; .reg .pred %r107; .reg .u16 %r108; .reg .u32 %r109; .reg .pred %r110; .reg .u64 %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .u64 %r114; .reg .pred %r115; .reg .u16 %r116; .reg .u32 %r117; .reg .pred %r118; .reg .pred %r119; .reg .u32 %r120; .reg .pred %r121; .reg .u32 %r122; .reg .pred %r123; mov.u64 %r98,%ar0; mov.u64 %r99,%ar1; mov.u64 %r100,%ar2; .loc 1 89 0 and.b64 %r101,%r98,7; setp.ne.u64 %r102,%r101,0; @ %r102 bra $L11; .loc 1 92 0 ld.u64 %r85,[%r98]; not.b64 %r103,%r85; add.u64 %r104,%r85,-72340172838076673; and.b64 %r105,%r103,%r104; and.b64 %r106,%r105,-9187201950435737472; setp.eq.u64 %r107,%r106,0; @ %r107 bra $L12; mov.u64 %r89,%r98; bra $L2; $L11: mov.u64 %r89,%r98; $L2: .loc 1 98 0 ld.s8 %r109,[%r89]; cvt.u16.u32 %r108,%r109; setp.ne.u16 %r110,%r108,0; @ %r110 bra $L4; bra $L5; $L12: .loc 1 92 0 mov.u64 %r89,%r98; $L3: .loc 1 93 0 add.u64 %r89,%r89,8; .loc 1 92 0 ld.u64 %r78,[%r89]; add.u64 %r111,%r78,-72340172838076673; not.b64 %r112,%r78; and.b64 %r113,%r111,%r112; and.b64 %r114,%r113,-9187201950435737472; setp.eq.u64 %r115,%r114,0; @ %r115 bra $L3; bra $L2; $L4: .loc 1 99 0 add.u64 %r89,%r89,1; .loc 1 98 0 ld.s8 %r117,[%r89]; cvt.u16.u32 %r116,%r117; setp.ne.u16 %r118,%r116,0; @ %r118 bra $L4; bra $L5; $L9: add.u64 %r91,%r91,1; add.u64 %r84,%r84,1; .loc 1 109 0 setp.ne.u64 %r119,%r100,0; @ %r119 bra $L6; .loc 1 110 0 cvt.u32.u64 %r120,%r100; st.u8 [%r87+1],%r120; bra $L7; $L5: mov.u64 %r91,%r89; mov.u64 %r84,%r99; add.u64 %r96,%r91,%r100; $L6: mov.u64 %r87,%r91; .loc 1 107 0 add.u64 %r100,%r100,-1; setp.ne.u64 %r121,%r91,%r96; @ ! %r121 bra $L7; ld.s8 %r86,[%r84]; cvt.u32.u32 %r122,%r86; st.u8 [%r91],%r122; setp.ne.u32 %r123,%r86,0; @ %r123 bra $L9; $L7: .loc 1 115 0 mov.u64 %value,%r98; st.param.u64 [%value_out],%value; ret; } lib_a-strncmp.o/0 0 0 644 4216 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncmp .visible .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strncmp.c" // BEGIN GLOBAL FUNCTION DEF: strncmp .visible .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r84; .reg .u32 %r86; .reg .u64 %r92; .reg .u32 %r98; .reg .u64 %r101; .reg .u32 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u64 %r110; .reg .pred %r111; .reg .u64 %r112; .reg .u64 %r113; .reg .pred %r114; .reg .pred %r115; .reg .u64 %r116; .reg .pred %r117; .reg .pred %r118; .reg .u64 %r119; .reg .u64 %r120; .reg .u64 %r121; .reg .u64 %r122; .reg .pred %r123; .reg .pred %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .pred %r129; .reg .pred %r130; .reg .u64 %r131; .reg .pred %r132; .reg .u16 %r133; .reg .u32 %r134; .reg .u16 %r135; .reg .pred %r136; .reg .u32 %r139; .reg .u32 %r140; .reg .u32 %r142; .reg .u32 %r143; .reg .u16 %r144; .reg .u16 %r145; .reg .u16 %r146; .reg .u32 %r147; .reg .u16 %r148; .reg .pred %r149; .reg .u32 %r151; .reg .u32 %r152; .reg .u32 %r155; .reg .u32 %r156; .reg .u16 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u32 %r160; .reg .u16 %r161; .reg .pred %r162; .reg .u16 %r163; .reg .u32 %r164; .reg .u16 %r165; .reg .pred %r166; .reg .u32 %r167; .reg .u32 %r168; mov.u64 %r108,%ar0; mov.u64 %r109,%ar1; mov.u64 %r110,%ar2; .loc 1 84 0 setp.eq.u64 %r111,%r110,0; @ %r111 bra $L9; .loc 1 88 0 or.b64 %r112,%r108,%r109; and.b64 %r113,%r112,7; setp.ne.u64 %r114,%r113,0; @ %r114 bra $L3; .loc 1 93 0 setp.le.u64 %r115,%r110,7; @ %r115 bra $L3; ld.u64 %r101,[%r108]; ld.u64 %r116,[%r109]; setp.ne.u64 %r117,%r101,%r116; @ %r117 bra $L3; .loc 1 95 0 add.u64 %r110,%r110,-8; .loc 1 99 0 setp.eq.u64 %r118,%r110,0; @ %r118 bra $L10; add.u64 %r119,%r101,-72340172838076673; not.b64 %r120,%r101; and.b64 %r121,%r119,%r120; and.b64 %r122,%r121,-9187201950435737472; setp.ne.u64 %r123,%r122,0; @ ! %r123 bra $L4; bra $L11; $L5: .loc 1 95 0 add.u64 %r110,%r110,-8; .loc 1 99 0 setp.eq.u64 %r124,%r110,0; @ %r124 bra $L12; add.u64 %r125,%r84,-72340172838076673; not.b64 %r126,%r84; and.b64 %r127,%r125,%r126; and.b64 %r128,%r127,-9187201950435737472; setp.ne.u64 %r129,%r128,0; @ %r129 bra $L13; $L4: .loc 1 102 0 add.u64 %r108,%r108,8; .loc 1 103 0 add.u64 %r109,%r109,8; .loc 1 93 0 setp.le.u64 %r130,%r110,7; @ %r130 bra $L3; ld.u64 %r84,[%r108]; ld.u64 %r131,[%r109]; setp.eq.u64 %r132,%r84,%r131; @ %r132 bra $L5; $L3: .loc 1 111 0 add.u64 %r92,%r110,-1; ld.s8 %r98,[%r109]; ld.s8 %r134,[%r108]; cvt.u16.u32 %r133,%r134; cvt.u16.u32 %r135,%r98; setp.ne.u16 %r136,%r133,%r135; @ %r136 bra $L6; .loc 1 115 0 set.u32.eq.u16 %r139,%r133,0; neg.s32 %r140,%r139; set.u32.eq.u64 %r142,%r92,0; neg.s32 %r143,%r142; cvt.u16.u32 %r145,%r140; cvt.u16.u32 %r146,%r143; or.b16 %r144,%r145,%r146; cvt.u32.u16 %r147,%r144; cvt.u16.u8 %r148,%r147; setp.ne.u16 %r149,%r148,0; @ ! %r149 bra $L7; bra $L14; $L8: set.u32.eq.u64 %r151,%r92,0; neg.s32 %r152,%r151; set.u32.eq.u16 %r155,%r163,0; neg.s32 %r156,%r155; cvt.u16.u32 %r158,%r152; cvt.u16.u32 %r159,%r156; or.b16 %r157,%r158,%r159; cvt.u32.u16 %r160,%r157; cvt.u16.u8 %r161,%r160; setp.ne.u16 %r162,%r161,0; @ %r162 bra $L15; $L7: .loc 1 117 0 add.u64 %r108,%r108,1; .loc 1 118 0 add.u64 %r109,%r109,1; .loc 1 111 0 add.u64 %r92,%r92,-1; ld.s8 %r86,[%r108]; ld.s8 %r164,[%r109]; cvt.u16.u32 %r163,%r164; cvt.u16.u32 %r165,%r86; setp.eq.u16 %r166,%r163,%r165; @ %r166 bra $L8; $L6: .loc 1 120 0 ld.u8 %r167,[%r108]; ld.u8 %r168,[%r109]; sub.u32 %r107,%r167,%r168; bra $L1; $L9: .loc 1 85 0 cvt.u32.u64 %r107,%r110; bra $L1; $L10: cvt.u32.u64 %r107,%r110; bra $L1; $L11: cvt.u32.u64 %r107,%r113; bra $L1; $L12: cvt.u32.u64 %r107,%r110; bra $L1; $L13: mov.u32 %r107,0; bra $L1; $L14: mov.u32 %r107,0; bra $L1; $L15: mov.u32 %r107,0; $L1: .loc 1 122 0 mov.u32 %value,%r107; st.param.u32 [%value_out],%value; ret; } lib_a-strncpy.o/0 0 0 644 3164 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strncpy .visible .func (.param .u64 %value_out) strncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strncpy.c" // BEGIN GLOBAL FUNCTION DEF: strncpy .visible .func (.param .u64 %value_out) strncpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r79; .reg .u32 %r85; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r88; .reg .u64 %r90; .reg .u64 %r91; .reg .u64 %r92; .reg .u64 %r93; .reg .u32 %r95; .reg .u64 %r96; .reg .u64 %r100; .reg .u64 %r103; .reg .u64 %r105; .reg .u64 %r106; .reg .u64 %r107; .reg .u64 %r108; .reg .u64 %r109; .reg .u32 %r111; .reg .u32 %r112; .reg .u32 %r114; .reg .u32 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u16 %r118; .reg .u32 %r119; .reg .u16 %r120; .reg .pred %r121; .reg .pred %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r126; .reg .pred %r127; .reg .u32 %r128; .reg .pred %r129; .reg .pred %r130; .reg .pred %r131; .reg .pred %r132; .reg .u32 %r133; .reg .pred %r134; .reg .u32 %r135; .reg .pred %r136; mov.u64 %r105,%ar0; mov.u64 %r106,%ar1; mov.u64 %r107,%ar2; .loc 1 97 0 mov.u64 %r103,%r105; or.b64 %r108,%r106,%r105; and.b64 %r109,%r108,7; set.u32.eq.u64 %r111,%r109,0; neg.s32 %r112,%r111; set.u32.gt.u64 %r114,%r107,7; neg.s32 %r115,%r114; cvt.u16.u32 %r117,%r112; cvt.u16.u32 %r118,%r115; and.b16 %r116,%r117,%r118; cvt.u32.u16 %r119,%r116; cvt.u16.u8 %r120,%r119; setp.ne.u16 %r121,%r120,0; @ %r121 bra $L2; .loc 1 91 0 mov.u64 %r92,%r105; bra $L3; $L4: .loc 1 106 0 add.u64 %r107,%r107,-8; .loc 1 107 0 add.u64 %r106,%r106,8; add.u64 %r103,%r103,8; mov.u64 %r92,%r103; st.u64 [%r100],%r79; .loc 1 104 0 setp.le.u64 %r122,%r107,7; @ %r122 bra $L3; $L2: mov.u64 %r100,%r103; ld.u64 %r79,[%r106]; add.u64 %r123,%r79,-72340172838076673; not.b64 %r124,%r79; and.b64 %r125,%r123,%r124; and.b64 %r126,%r125,-9187201950435737472; setp.eq.u64 %r127,%r126,0; @ %r127 bra $L4; mov.u64 %r92,%r103; bra $L5; $L7: .loc 1 116 0 add.u64 %r90,%r90,-1; add.u64 %r93,%r93,1; .loc 1 117 0 ld.s8 %r85,[%r87]; cvt.u32.u32 %r128,%r85; st.u8 [%r86],%r128; add.u64 %r87,%r87,1; mov.u64 %r86,%r93; setp.eq.u32 %r129,%r85,0; @ %r129 bra $L6; $L10: .loc 1 114 0 setp.ne.u64 %r130,%r90,0; @ %r130 bra $L7; bra $L8; $L6: .loc 1 121 0 setp.ne.u64 %r131,%r90,0; @ %r131 bra $L9; bra $L8; $L3: .loc 1 114 0 setp.eq.u64 %r132,%r107,0; @ %r132 bra $L8; $L5: .loc 1 116 0 add.u64 %r90,%r107,-1; .loc 1 117 0 add.u64 %r96,%r106,1; add.u64 %r93,%r92,1; ld.s8 %r95,[%r106]; cvt.u32.u32 %r133,%r95; st.u8 [%r92],%r133; setp.eq.u32 %r134,%r95,0; @ %r134 bra $L6; mov.u64 %r87,%r96; mov.u64 %r86,%r93; bra $L10; $L9: mov.u64 %r91,%r93; add.u64 %r88,%r91,%r90; .loc 1 122 0 mov.u32 %r135,0; $L11: st.u8 [%r91],%r135; add.u64 %r91,%r91,1; .loc 1 121 0 setp.ne.u64 %r136,%r88,%r91; @ %r136 bra $L11; $L8: .loc 1 126 0 mov.u64 %value,%r105; st.param.u64 [%value_out],%value; ret; } lib_a-strndup.o/0 0 0 644 1249 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strndup .visible .func (.param .u64 %value_out) strndup (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strndup.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strndup_r .extern .func (.param .u64 %value_out) _strndup_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: strndup .visible .func (.param .u64 %value_out) strndup (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r29; .reg .u64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 13 0 ld.global.u64 %r29,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),_strndup_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r30,[%value_in]; } .loc 1 14 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } /714 0 0 0 644 2516 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strndup_r .visible .func (.param .u64 %value_out) _strndup_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strndup_r.c" // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: _strndup_r .visible .func (.param .u64 %value_out) _strndup_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r51; .reg .u64 %r53; .reg .u64 %r58; .reg .u64 %r61; .reg .u64 %r62; .reg .u64 %r63; .reg .pred %r64; .reg .u16 %r65; .reg .u32 %r66; .reg .pred %r67; .reg .pred %r68; .reg .u16 %r69; .reg .u32 %r70; .reg .pred %r71; .reg .u64 %r74; .reg .pred %r75; .reg .u64 %r79; .reg .u64 %r80; .reg .u32 %r81; mov.u64 %r61,%ar0; mov.u64 %r62,%ar1; mov.u64 %r63,%ar2; .loc 1 15 0 setp.eq.u64 %r64,%r63,0; @ %r64 bra $L6; ld.s8 %r66,[%r62]; cvt.u16.u32 %r65,%r66; setp.eq.u16 %r67,%r65,0; @ %r67 bra $L7; add.u64 %r53,%r62,%r63; mov.u64 %r51,%r62; $L4: .loc 1 16 0 add.u64 %r51,%r51,1; .loc 1 15 0 setp.ne.u64 %r68,%r51,%r53; @ %r68 bra $L3; sub.u64 %r63,%r51,%r62; add.u64 %r58,%r63,1; bra $L2; $L3: ld.s8 %r70,[%r51]; cvt.u16.u32 %r69,%r70; setp.ne.u16 %r71,%r69,0; @ %r71 bra $L4; sub.u64 %r63,%r51,%r62; add.u64 %r58,%r63,1; bra $L2; $L6: mov.u64 %r58,1; bra $L2; $L7: mov.u64 %r63,0; mov.u64 %r58,1; $L2: .loc 1 20 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r61; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r58; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r74,[%value_in]; } .loc 1 21 0 setp.eq.u64 %r75,%r74,0; @ %r75 bra $L1; .loc 1 23 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r74; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r62; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r63; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r79,[%value_in]; } .loc 1 24 0 add.u64 %r80,%r74,%r63; mov.u32 %r81,0; st.u8 [%r80],%r81; $L1: .loc 1 27 0 mov.u64 %value,%r74; st.param.u64 [%value_out],%value; ret; } lib_a-strnlen.o/0 0 0 644 1315 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strnlen .visible .func (.param .u64 %value_out) strnlen (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strnlen.c" // BEGIN GLOBAL FUNCTION DEF: strnlen .visible .func (.param .u64 %value_out) strnlen (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r51; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r59; .reg .pred %r60; .reg .u16 %r61; .reg .u32 %r62; .reg .pred %r63; .reg .pred %r64; .reg .u16 %r65; .reg .u32 %r66; .reg .pred %r67; mov.u64 %r58,%ar0; mov.u64 %r59,%ar1; mov.u64 %r56,%r58; .loc 1 45 0 setp.eq.u64 %r60,%r59,0; @ %r60 bra $L5; ld.s8 %r62,[%r58]; cvt.u16.u32 %r61,%r62; setp.eq.u16 %r63,%r61,0; @ %r63 bra $L6; add.u64 %r51,%r58,%r59; $L4: .loc 1 46 0 add.u64 %r58,%r58,1; .loc 1 45 0 setp.ne.u64 %r64,%r58,%r51; @ %r64 bra $L3; sub.u64 %r57,%r58,%r56; bra $L1; $L3: ld.s8 %r66,[%r58]; cvt.u16.u32 %r65,%r66; setp.ne.u16 %r67,%r65,0; @ %r67 bra $L4; sub.u64 %r57,%r58,%r56; bra $L1; $L5: mov.u64 %r57,%r59; bra $L1; $L6: mov.u64 %r57,0; $L1: .loc 1 49 0 mov.u64 %value,%r57; st.param.u64 [%value_out],%value; ret; } lib_a-strpbrk.o/0 0 0 644 1812 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strpbrk .visible .func (.param .u64 %value_out) strpbrk (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strpbrk.c" // BEGIN GLOBAL FUNCTION DEF: strpbrk .visible .func (.param .u64 %value_out) strpbrk (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u32 %r50; .reg .u64 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .pred %r57; .reg .u16 %r59; .reg .pred %r60; .reg .pred %r61; .reg .u16 %r63; .reg .pred %r65; .reg .u16 %r66; .reg .u32 %r67; .reg .pred %r68; .reg .pred %r70; .reg .pred %r71; .reg .u16 %r72; .reg .u16 %r73; mov.u64 %r55,%ar0; mov.u64 %r56,%ar1; .loc 1 39 0 ld.s8 %r49,[%r55]; setp.eq.u32 %r57,%r49,0; @ ! %r57 bra $L13; bra $L9; $L4: .loc 1 46 0 cvt.u16.u32 %r59,%r50; setp.eq.u16 %r60,%r72,%r59; @ %r60 bra $L1; $L6: .loc 1 44 0 add.u64 %r52,%r52,1; ld.s8 %r50,[%r52]; setp.ne.u32 %r61,%r50,0; @ %r61 bra $L4; bra $L5; $L13: ld.s8 %r53,[%r56]; mov.u64 %r54,%r55; setp.eq.u32 %r71,%r53,0; .loc 1 46 0 cvt.u16.u32 %r73,%r53; $L7: .loc 1 44 0 @ %r71 bra $L10; .loc 1 46 0 cvt.u16.u32 %r63,%r49; setp.eq.u16 %r65,%r63,%r73; @ %r65 bra $L1; mov.u64 %r52,%r56; cvt.u16.u32 %r72,%r49; bra $L6; $L14: .loc 1 54 0 ld.s8 %r67,[%r52]; cvt.u16.u32 %r66,%r67; setp.eq.u16 %r68,%r66,0; .loc 1 55 0 selp.u64 %r54,0,%r54,%r68; bra $L1; $L9: mov.u64 %r54,0; bra $L1; $L10: .loc 1 44 0 mov.u64 %r52,%r56; $L5: .loc 1 51 0 add.u64 %r54,%r54,1; .loc 1 42 0 ld.s8 %r49,[%r54]; setp.ne.u32 %r70,%r49,0; @ %r70 bra $L7; bra $L14; $L1: .loc 1 58 0 mov.u64 %value,%r54; st.param.u64 [%value_out],%value; ret; } lib_a-strrchr.o/0 0 0 644 1554 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strrchr .visible .func (.param .u64 %value_out) strrchr (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strrchr.c" // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strrchr .visible .func (.param .u64 %value_out) strrchr (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .u32 %r25; .reg .pred %r26; .reg .u64 %r29; .reg .pred %r30; .reg .u64 %r33; mov.u64 %r24,%ar0; mov.u32 %r25,%ar1; .loc 1 45 0 setp.ne.u32 %r26,%r25,0; @ %r26 bra $L6; bra $L7; $L4: .loc 1 50 0 add.u64 %r24,%r29,1; mov.u64 %r23,%r29; bra $L2; $L6: .loc 1 43 0 mov.u64 %r23,0; $L2: .loc 1 47 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r29,[%value_in]; } setp.ne.u64 %r30,%r29,0; @ %r30 bra $L4; bra $L1; $L7: .loc 1 55 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r25; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r33,[%value_in]; } mov.u64 %r23,%r33; $L1: .loc 1 59 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } lib_a-strsep.o/ 0 0 0 644 1263 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strsep .visible .func (.param .u64 %value_out) strsep (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strsep.c" // BEGIN GLOBAL FUNCTION DECL: __strtok_r .extern .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strsep .visible .func (.param .u64 %value_out) strsep (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u32 %r29; .reg .u64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 18 0 mov.u32 %r29,0; ld.u64 %r26,[%r24]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r24; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r29; call (%value_in),__strtok_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 19 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } /733 0 0 0 644 9385 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: strsignal .visible .func (.param .u64 %value_out) strsignal (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/string/strsignal.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: siprintf .extern .func (.param .u32 %value_out) siprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[7] = {72,97,110,103,117,112,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[10] = {73,110,116,101,114,114,117,112,116,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[5] = {81,117,105,116,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[20] = {73,108,108,101,103,97,108,32,105,110,115,116,114,117,99,116,105,111,110,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[22] = {84,114,97,99,101,47,98,114,101,97,107,112,111,105,110,116,32,116,114,97,112,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[9] = {73,79,84,32,116,114,97,112,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[9] = {69,77,84,32,116,114,97,112,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[25] = {70,108,111,97,116,105,110,103,32,112,111,105,110,116,32,101,120,99,101,112,116,105,111,110,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[7] = {75,105,108,108,101,100,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[10] = {66,117,115,32,101,114,114,111,114,0 }; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[19] = {83,101,103,109,101,110,116,97,116,105,111,110,32,102,97,117,108,116,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[16] = {66,97,100,32,115,121,115,116,101,109,32,99,97,108,108,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[12] = {66,114,111,107,101,110,32,112,105,112,101,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[12] = {65,108,97,114,109,32,99,108,111,99,107,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[11] = {84,101,114,109,105,110,97,116,101,100,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[21] = {85,114,103,101,110,116,32,73,47,79,32,99,111,110,100,105,116,105,111,110,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[17] = {83,116,111,112,112,101,100,32,40,115,105,103,110,97,108,41,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[8] = {83,116,111,112,112,101,100,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[10] = {67,111,110,116,105,110,117,101,100,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[13] = {67,104,105,108,100,32,101,120,105,116,101,100,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[18] = {85,110,107,110,111,119,110,32,115,105,103,110,97,108,32,37,100,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[20] = {83,116,111,112,112,101,100,32,40,116,116,121,32,105,110,112,117,116,41,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[13] = {73,47,79,32,112,111,115,115,105,98,108,101,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[15] = {87,105,110,100,111,119,32,99,104,97,110,103,101,100,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[22] = {85,115,101,114,32,100,101,102,105,110,101,100,32,115,105,103,110,97,108,32,49,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[22] = {85,115,101,114,32,100,101,102,105,110,101,100,32,115,105,103,110,97,108,32,50,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[24] = {67,80,85,32,116,105,109,101,32,108,105,109,105,116,32,101,120,99,101,101,100,101,100,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[25] = {70,105,108,101,32,115,105,122,101,32,108,105,109,105,116,32,101,120,99,101,101,100,101,100,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[22] = {86,105,114,116,117,97,108,32,116,105,109,101,114,32,101,120,112,105,114,101,100,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[24] = {80,114,111,102,105,108,105,110,103,32,116,105,109,101,114,32,101,120,112,105,114,101,100,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[14] = {82,101,115,111,117,114,99,101,32,108,111,115,116,0 }; // BEGIN GLOBAL FUNCTION DEF: strsignal .visible .func (.param .u64 %value_out) strsignal (.param .u32 %in_ar0) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,0; sub.u64 %stack,%frame,8; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .reg .pred %r26; .reg .pred %r27; .reg .pred %r28; .reg .pred %r29; .reg .pred %r30; .reg .pred %r31; .reg .pred %r32; .reg .pred %r33; .reg .pred %r34; .reg .pred %r35; .reg .pred %r36; .reg .pred %r37; .reg .pred %r38; .reg .pred %r39; .reg .pred %r40; .reg .pred %r41; .reg .pred %r42; .reg .pred %r43; .reg .pred %r44; .reg .pred %r45; .reg .pred %r46; .reg .pred %r47; .reg .pred %r48; .reg .pred %r49; .reg .pred %r50; .reg .pred %r51; .reg .pred %r52; .reg .pred %r53; .reg .pred %r54; .reg .pred %r55; .reg .pred %r56; .reg .u64 %r57; .reg .u64 %r59; .reg .u32 %r60; mov.u32 %r24,%ar0; .loc 1 80 0 setp.eq.u32 %r25,%r24,15; @ %r25 bra $L3; setp.gt.s32 %r26,%r24,15; @ %r26 bra $L4; setp.eq.u32 %r27,%r24,7; @ %r27 bra $L5; setp.gt.s32 %r28,%r24,7; @ %r28 bra $L6; setp.eq.u32 %r29,%r24,3; @ %r29 bra $L7; setp.gt.s32 %r30,%r24,3; @ %r30 bra $L8; setp.eq.u32 %r31,%r24,1; @ %r31 bra $L40; setp.eq.u32 %r32,%r24,2; @ %r32 bra $L10; bra $L2; $L8: setp.eq.u32 %r33,%r24,5; @ %r33 bra $L11; setp.gt.s32 %r34,%r24,5; @ ! %r34 bra $L41; bra $L12; $L6: setp.eq.u32 %r35,%r24,11; @ %r35 bra $L14; setp.gt.s32 %r36,%r24,11; @ %r36 bra $L15; setp.eq.u32 %r37,%r24,9; @ %r37 bra $L16; setp.gt.s32 %r38,%r24,9; @ ! %r38 bra $L42; bra $L17; $L15: setp.eq.u32 %r39,%r24,13; @ %r39 bra $L19; setp.gt.s32 %r40,%r24,13; @ ! %r40 bra $L43; bra $L20; $L4: setp.eq.u32 %r41,%r24,24; @ %r41 bra $L22; setp.gt.s32 %r42,%r24,24; @ %r42 bra $L23; setp.eq.u32 %r43,%r24,19; @ %r43 bra $L24; setp.gt.s32 %r44,%r24,19; @ %r44 bra $L25; setp.eq.u32 %r45,%r24,17; @ %r45 bra $L26; setp.gt.s32 %r46,%r24,17; @ ! %r46 bra $L44; bra $L27; $L25: setp.eq.u32 %r47,%r24,21; @ %r47 bra $L29; setp.lt.s32 %r48,%r24,21; @ %r48 bra $L30; setp.eq.u32 %r49,%r24,23; @ %r49 bra $L31; bra $L2; $L23: setp.eq.u32 %r50,%r24,28; @ %r50 bra $L32; setp.gt.s32 %r51,%r24,28; @ %r51 bra $L33; setp.eq.u32 %r52,%r24,26; @ %r52 bra $L34; setp.gt.s32 %r53,%r24,26; @ ! %r53 bra $L45; bra $L35; $L33: setp.eq.u32 %r54,%r24,30; @ %r54 bra $L37; setp.lt.s32 %r55,%r24,30; @ %r55 bra $L38; setp.eq.u32 %r56,%r24,31; @ %r56 bra $L39; bra $L2; $L10: .loc 1 88 0 cvta.const.u64 %r23,$LC1; bra $L1; $L7: .loc 1 93 0 cvta.const.u64 %r23,$LC2; .loc 1 94 0 bra $L1; $L41: .loc 1 98 0 cvta.const.u64 %r23,$LC3; .loc 1 99 0 bra $L1; $L11: .loc 1 103 0 cvta.const.u64 %r23,$LC4; .loc 1 104 0 bra $L1; $L12: .loc 1 111 0 cvta.const.u64 %r23,$LC5; .loc 1 112 0 bra $L1; $L5: .loc 1 116 0 cvta.const.u64 %r23,$LC6; .loc 1 117 0 bra $L1; $L42: .loc 1 121 0 cvta.const.u64 %r23,$LC7; .loc 1 122 0 bra $L1; $L16: .loc 1 126 0 cvta.const.u64 %r23,$LC8; .loc 1 127 0 bra $L1; $L17: .loc 1 131 0 cvta.const.u64 %r23,$LC9; .loc 1 132 0 bra $L1; $L14: .loc 1 136 0 cvta.const.u64 %r23,$LC10; .loc 1 137 0 bra $L1; $L43: .loc 1 141 0 cvta.const.u64 %r23,$LC11; .loc 1 142 0 bra $L1; $L19: .loc 1 146 0 cvta.const.u64 %r23,$LC12; .loc 1 147 0 bra $L1; $L20: .loc 1 151 0 cvta.const.u64 %r23,$LC13; .loc 1 152 0 bra $L1; $L3: .loc 1 156 0 cvta.const.u64 %r23,$LC14; .loc 1 157 0 bra $L1; $L44: .loc 1 161 0 cvta.const.u64 %r23,$LC15; .loc 1 162 0 bra $L1; $L26: .loc 1 166 0 cvta.const.u64 %r23,$LC16; .loc 1 167 0 bra $L1; $L27: .loc 1 171 0 cvta.const.u64 %r23,$LC17; .loc 1 172 0 bra $L1; $L24: .loc 1 176 0 cvta.const.u64 %r23,$LC18; .loc 1 177 0 bra $L1; $L30: .loc 1 184 0 cvta.const.u64 %r23,$LC19; .loc 1 185 0 bra $L1; $L29: .loc 1 189 0 cvta.const.u64 %r23,$LC20; .loc 1 190 0 bra $L1; $L31: .loc 1 202 0 cvta.const.u64 %r23,$LC21; .loc 1 203 0 bra $L1; $L32: .loc 1 207 0 cvta.const.u64 %r23,$LC22; .loc 1 208 0 bra $L1; $L37: .loc 1 212 0 cvta.const.u64 %r23,$LC23; .loc 1 213 0 bra $L1; $L39: .loc 1 217 0 cvta.const.u64 %r23,$LC24; .loc 1 218 0 bra $L1; $L22: .loc 1 227 0 cvta.const.u64 %r23,$LC25; .loc 1 228 0 bra $L1; $L45: .loc 1 232 0 cvta.const.u64 %r23,$LC26; .loc 1 233 0 bra $L1; $L34: .loc 1 237 0 cvta.const.u64 %r23,$LC27; .loc 1 238 0 bra $L1; $L35: .loc 1 242 0 cvta.const.u64 %r23,$LC28; .loc 1 243 0 bra $L1; $L38: .loc 1 247 0 cvta.const.u64 %r23,$LC29; .loc 1 248 0 bra $L1; $L2: .loc 1 71 0 ld.global.u64 %r57,[_impure_ptr]; add.u64 %r23,%r57,288; .loc 1 251 0 st.u32 [%stack],%r24; cvta.const.u64 %r59,$LC30; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r59; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%stack; call (%value_in),siprintf,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r60,[%value_in]; } .loc 1 252 0 bra $L1; $L40: .loc 1 83 0 cvta.const.u64 %r23,$LC0; $L1: .loc 1 256 0 mov.u64 %value,%r23; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } lib_a-strspn.o/ 0 0 0 644 1661 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strspn .visible .func (.param .u64 %value_out) strspn (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strspn.c" // BEGIN GLOBAL FUNCTION DEF: strspn .visible .func (.param .u64 %value_out) strspn (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %r49; .reg .u32 %r50; .reg .u32 %r51; .reg .u64 %r52; .reg .u64 %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .pred %r63; .reg .u16 %r64; .reg .pred %r66; .reg .pred %r67; .reg .u16 %r70; .reg .pred %r71; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r75; .reg .u16 %r76; mov.u64 %r61,%ar0; mov.u64 %r62,%ar1; .loc 1 46 0 ld.s8 %r51,[%r61]; mov.u64 %r59,%r61; setp.ne.u32 %r63,%r51,0; @ %r63 bra $L2; mov.u64 %r60,0; bra $L1; $L5: .loc 1 50 0 cvt.u16.u32 %r64,%r50; setp.eq.u16 %r66,%r64,%r75; @ %r66 bra $L4; $L7: .loc 1 48 0 add.u64 %r52,%r52,1; ld.s8 %r50,[%r52]; setp.ne.u32 %r67,%r50,0; @ %r67 bra $L5; sub.u64 %r60,%r61,%r59; bra $L1; $L2: ld.s8 %r49,[%r62]; setp.ne.u32 %r74,%r49,0; .loc 1 50 0 cvt.u16.u32 %r76,%r49; $L8: .loc 1 48 0 @ %r74 bra $L6; sub.u64 %r60,%r61,%r59; bra $L1; $L6: .loc 1 50 0 cvt.u16.u32 %r70,%r51; setp.eq.u16 %r71,%r76,%r70; @ %r71 bra $L4; mov.u64 %r52,%r62; cvt.u16.u32 %r75,%r51; bra $L7; $L4: .loc 1 55 0 add.u64 %r61,%r61,1; .loc 1 46 0 ld.s8 %r51,[%r61]; setp.ne.u32 %r73,%r51,0; @ %r73 bra $L8; sub.u64 %r60,%r61,%r59; $L1: .loc 1 59 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } lib_a-strstr.o/ 0 0 0 644 28010 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/str-two-way.h" // BEGIN FUNCTION DECL: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: strstr .visible .func (.param .u64 %value_out) strstr (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 2 "../../../../../../newlib/libc/string/strstr.c" // BEGIN GLOBAL FUNCTION DECL: memcmp .extern .func (.param .u32 %value_out) memcmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strchr .extern .func (.param .u64 %value_out) strchr (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN FUNCTION DEF: critical_factorization .func (.param .u64 %value_out) critical_factorization (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r22; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r32; .reg .u64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u64 %r38; .reg .u64 %r45; .reg .u64 %r46; .reg .u64 %r47; .reg .u64 %r48; .reg .u64 %r49; .reg .u64 %r50; .reg .u64 %r51; .reg .u16 %r52; .reg .u16 %r53; .reg .pred %r54; .reg .pred %r57; .reg .pred %r58; .reg .pred %r59; .reg .u64 %r60; .reg .u64 %r61; .reg .u64 %r62; .reg .u16 %r63; .reg .u16 %r64; .reg .pred %r65; .reg .pred %r68; .reg .pred %r69; .reg .pred %r70; .reg .pred %r71; .reg .u64 %r73; .reg .u64 %r74; mov.u64 %r46,%ar0; mov.u64 %r47,%ar1; mov.u64 %r48,%ar2; .loc 1 113 0 mov.u64 %r37,1; mov.u64 %r35,%r37; .loc 1 112 0 mov.u64 %r28,0; .loc 1 111 0 mov.u64 %r32,-1; .loc 1 140 0 mov.u64 %r74,%r37; .loc 1 114 0 bra $L2; $L7: .loc 1 116 0 add.u64 %r49,%r46,%r27; .loc 1 117 0 add.u64 %r50,%r46,%r32; add.u64 %r51,%r50,%r35; .loc 1 118 0 ld.u8 %r52,[%r49]; ld.u8 %r53,[%r51]; setp.ge.u16 %r54,%r52,%r53; @ %r54 bra $L3; .loc 1 123 0 sub.u64 %r37,%r27,%r32; mov.u64 %r28,%r27; .loc 1 122 0 mov.u64 %r35,1; bra $L2; $L3: .loc 1 125 0 setp.ne.u16 %r57,%r52,%r53; @ %r57 bra $L5; .loc 1 128 0 setp.eq.u64 %r58,%r35,%r37; @ %r58 bra $L6; .loc 1 129 0 add.u64 %r35,%r35,1; bra $L2; $L6: .loc 1 132 0 mov.u64 %r28,%r27; .loc 1 133 0 mov.u64 %r35,1; bra $L2; $L5: .loc 1 139 0 mov.u64 %r32,%r28; add.u64 %r28,%r28,1; .loc 1 140 0 mov.u64 %r37,%r74; mov.u64 %r35,1; $L2: .loc 1 114 0 add.u64 %r27,%r28,%r35; setp.lt.u64 %r59,%r27,%r47; @ %r59 bra $L7; .loc 1 143 0 st.u64 [%r48],%r37; .loc 1 148 0 mov.u64 %r38,1; mov.u64 %r36,%r38; .loc 1 147 0 mov.u64 %r22,0; .loc 1 146 0 mov.u64 %r26,-1; .loc 1 175 0 mov.u64 %r73,%r38; .loc 1 149 0 bra $L8; $L13: .loc 1 151 0 add.u64 %r60,%r46,%r33; .loc 1 152 0 add.u64 %r61,%r46,%r26; add.u64 %r62,%r61,%r36; .loc 1 153 0 ld.u8 %r63,[%r60]; ld.u8 %r64,[%r62]; setp.le.u16 %r65,%r63,%r64; @ %r65 bra $L9; .loc 1 158 0 sub.u64 %r38,%r33,%r26; mov.u64 %r22,%r33; .loc 1 157 0 mov.u64 %r36,1; bra $L8; $L9: .loc 1 160 0 setp.ne.u16 %r68,%r63,%r64; @ %r68 bra $L11; .loc 1 163 0 setp.eq.u64 %r69,%r36,%r38; @ %r69 bra $L12; .loc 1 164 0 add.u64 %r36,%r36,1; bra $L8; $L12: .loc 1 167 0 mov.u64 %r22,%r33; .loc 1 168 0 mov.u64 %r36,1; bra $L8; $L11: .loc 1 174 0 mov.u64 %r26,%r22; add.u64 %r22,%r22,1; .loc 1 175 0 mov.u64 %r38,%r73; mov.u64 %r36,1; $L8: .loc 1 149 0 add.u64 %r33,%r22,%r36; setp.lt.u64 %r70,%r33,%r47; @ %r70 bra $L13; .loc 1 181 0 add.u64 %r34,%r26,1; add.u64 %r45,%r32,1; setp.lt.u64 %r71,%r34,%r45; @ %r71 bra $L1; .loc 1 183 0 st.u64 [%r48],%r38; .loc 1 184 0 mov.u64 %r45,%r34; $L1: .loc 1 185 0 mov.u64 %value,%r45; st.param.u64 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: two_way_long_needle .func (.param .u64 %value_out) two_way_long_needle (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,2056; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r76; .reg .u64 %r79; .reg .u64 %r80; .reg .u64 %r86; .reg .u32 %r88; .reg .u32 %r89; .reg .u32 %r92; .reg .u32 %r93; .reg .u64 %r96; .reg .u64 %r99; .reg .u64 %r100; .reg .u64 %r107; .reg .u32 %r113; .reg .u32 %r114; .reg .u64 %r115; .reg .u32 %r116; .reg .u32 %r117; .reg .u64 %r123; .reg .u64 %r125; .reg .u64 %r126; .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r134; .reg .u64 %r136; .reg .u64 %r140; .reg .u64 %r141; .reg .u64 %r151; .reg .u64 %r159; .reg .u64 %r172; .reg .u64 %r175; .reg .u64 %r176; .reg .u64 %r179; .reg .u64 %r186; .reg .u64 %r189; .reg .u64 %r194; .reg .u64 %r195; .reg .u64 %r197; .reg .u64 %r200; .reg .u64 %r201; .reg .u64 %r202; .reg .u64 %r203; .reg .u64 %r204; .reg .u64 %r208; .reg .u64 %r209; .reg .pred %r210; .reg .u64 %r211; .reg .pred %r212; .reg .u64 %r214; .reg .u64 %r215; .reg .u64 %r216; .reg .pred %r217; .reg .u32 %r221; .reg .pred %r222; .reg .u64 %r223; .reg .u64 %r226; .reg .u64 %r227; .reg .u64 %r228; .reg .pred %r229; .reg .pred %r230; .reg .pred %r231; .reg .pred %r232; .reg .u64 %r233; .reg .u64 %r234; .reg .u64 %r235; .reg .u16 %r236; .reg .u16 %r237; .reg .pred %r238; .reg .u64 %r240; .reg .u64 %r241; .reg .pred %r242; .reg .u16 %r243; .reg .u16 %r244; .reg .pred %r245; .reg .pred %r246; .reg .u64 %r247; .reg .u64 %r248; .reg .u64 %r249; .reg .u16 %r250; .reg .u16 %r251; .reg .pred %r252; .reg .u64 %r253; .reg .pred %r254; .reg .u16 %r255; .reg .u16 %r256; .reg .pred %r257; .reg .u64 %r258; .reg .pred %r259; .reg .u32 %r261; .reg .u64 %r263; .reg .u64 %r264; .reg .u64 %r265; .reg .u32 %r267; .reg .u32 %r268; .reg .u32 %r270; .reg .u32 %r271; .reg .u16 %r272; .reg .u16 %r273; .reg .u16 %r274; .reg .u32 %r275; .reg .u16 %r276; .reg .pred %r277; .reg .u64 %r278; .reg .u64 %r279; .reg .u64 %r280; .reg .u64 %r281; .reg .u64 %r284; .reg .u64 %r285; .reg .u64 %r286; .reg .pred %r287; .reg .pred %r288; .reg .u64 %r289; .reg .u64 %r291; .reg .u16 %r292; .reg .u16 %r293; .reg .pred %r294; .reg .u64 %r295; .reg .pred %r296; .reg .u16 %r297; .reg .u16 %r298; .reg .pred %r299; .reg .u64 %r301; .reg .u64 %r303; .reg .u16 %r304; .reg .u16 %r305; .reg .pred %r306; .reg .u64 %r307; .reg .pred %r308; .reg .u16 %r309; .reg .u16 %r310; .reg .pred %r311; .reg .u32 %r313; .reg .u64 %r315; .reg .u64 %r316; .reg .u64 %r317; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r322; .reg .u32 %r323; .reg .u16 %r324; .reg .u16 %r325; .reg .u16 %r326; .reg .u32 %r327; .reg .u16 %r328; .reg .pred %r329; .reg .u64 %r331; .reg .u64 %r335; .reg .u64 %r336; .reg .u64 %r337; .reg .u32 %r341; .reg .pred %r342; .reg .u64 %r343; .reg .u64 %r345; .reg .u64 %r347; .reg .u64 %r348; .reg .u64 %r349; .reg .u64 %r350; .reg .u64 %r351; .reg .u64 %r352; .reg .pred %r353; .reg .u64 %r354; .reg .u64 %r355; .reg .u64 %r356; mov.u64 %r201,%ar0; mov.u64 %r202,%ar1; mov.u64 %r203,%ar2; mov.u64 %r204,%ar3; .loc 1 304 0 add.u64 %r208,%frame,2048; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r203; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r204; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r208; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r209,[%value_in]; } mov.u64 %r197,%frame; $L16: .loc 1 311 0 st.u64 [%r197],%r204; add.u64 %r197,%r197,8; .loc 1 310 0 setp.ne.u64 %r210,%r208,%r197; @ %r210 bra $L16; ld.u64 %r211,[%frame+2048]; add.u64 %r172,%r203,%r211; .loc 1 312 0 setp.eq.u64 %r212,%r204,0; @ %r212 bra $L17; add.u64 %r175,%r204,-1; mov.u64 %r194,%r203; mov.u64 %r195,%r175; $L18: .loc 1 313 0 ld.u8 %r214,[%r194]; shl.b64 %r215,%r214,3; add.u64 %r216,%frame,%r215; st.u64 [%r216],%r195; add.u64 %r194,%r194,1; add.u64 %r195,%r195,-1; .loc 1 312 0 setp.ne.u64 %r217,%r195,-1; @ %r217 bra $L18; .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r203; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r172; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r209; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r221,[%value_in]; } setp.eq.u32 %r222,%r221,0; @ %r222 bra $L45; bra $L20; $L31: .loc 1 329 0 add.u64 %r223,%r201,%r100; ld.u8 %r226,[%r223+-1]; shl.b64 %r227,%r226,3; add.u64 %r228,%frame,%r227; ld.u64 %r128,[%r228]; .loc 1 330 0 setp.eq.u64 %r229,%r128,0; @ %r229 bra $L21; .loc 1 332 0 setp.eq.u64 %r230,%r127,0; @ %r230 bra $L22; ld.u64 %r86,[%frame+2048]; setp.le.u64 %r231,%r86,%r128; @ %r231 bra $L22; .loc 1 337 0 sub.u64 %r128,%r204,%r86; $L22: .loc 1 340 0 add.u64 %r115,%r115,%r128; .loc 1 339 0 mov.u64 %r127,0; .loc 1 341 0 bra $L23; $L21: .loc 1 345 0 max.u64 %r140,%r127,%r209; .loc 1 346 0 setp.ge.u64 %r232,%r140,%r175; @ %r232 bra $L24; add.u64 %r233,%r203,%r140; .loc 1 347 0 add.u64 %r234,%r201,%r115; add.u64 %r235,%r234,%r140; .loc 1 346 0 ld.u8 %r236,[%r233]; ld.u8 %r237,[%r235]; setp.ne.u16 %r238,%r236,%r237; @ %r238 bra $L25; add.u64 %r347,%r140,1; add.u64 %r76,%r203,%r347; add.u64 %r240,%r115,1; add.u64 %r241,%r240,%r140; add.u64 %r179,%r201,%r241; $L26: .loc 1 348 0 mov.u64 %r140,%r347; .loc 1 346 0 setp.eq.u64 %r242,%r347,%r175; @ %r242 bra $L24; ld.u8 %r88,[%r76]; .loc 1 347 0 ld.u8 %r89,[%r179]; add.u64 %r76,%r76,1; add.u64 %r179,%r179,1; .loc 1 346 0 cvt.u16.u32 %r243,%r88; cvt.u16.u32 %r244,%r89; setp.eq.u16 %r245,%r243,%r244; @ ! %r245 bra $L25; add.u64 %r347,%r347,1; bra $L26; $L24: .loc 1 352 0 mov.u64 %r159,%r349; .loc 1 353 0 setp.ge.u64 %r246,%r127,%r209; @ %r246 bra $L46; .loc 1 354 0 add.u64 %r247,%r201,%r115; add.u64 %r248,%r247,%r349; .loc 1 353 0 add.u64 %r249,%r203,%r349; ld.u8 %r250,[%r248]; ld.u8 %r251,[%r249]; setp.ne.u16 %r252,%r250,%r251; @ %r252 bra $L47; add.u64 %r151,%r203,%r350; add.u64 %r253,%r115,%r350; add.u64 %r126,%r201,%r253; add.u64 %r99,%r127,-1; bra $L28; $L48: mov.u64 %r159,%r141; $L28: .loc 1 355 0 add.u64 %r141,%r159,-1; .loc 1 353 0 setp.eq.u64 %r254,%r99,%r141; @ %r254 bra $L27; ld.u8 %r92,[%r151]; .loc 1 354 0 ld.u8 %r93,[%r126]; add.u64 %r151,%r151,-1; add.u64 %r126,%r126,-1; .loc 1 353 0 cvt.u16.u32 %r255,%r92; cvt.u16.u32 %r256,%r93; setp.eq.u16 %r257,%r255,%r256; @ %r257 bra $L48; bra $L27; $L46: mov.u64 %r159,%r209; bra $L27; $L47: mov.u64 %r159,%r209; $L27: .loc 1 356 0 add.u64 %r258,%r127,1; setp.le.u64 %r259,%r258,%r159; @ %r259 bra $L29; .loc 1 357 0 add.u64 %r200,%r201,%r115; bra $L15; $L29: .loc 1 360 0 ld.u64 %r96,[%frame+2048]; add.u64 %r115,%r115,%r96; .loc 1 361 0 sub.u64 %r127,%r204,%r96; $L23: .loc 1 339 0 mov.u64 %r202,%r100; bra $L19; $L45: .loc 1 322 0 mov.u64 %r127,0; .loc 1 324 0 mov.u64 %r115,%r127; .loc 1 352 0 add.u64 %r349,%r209,-1; add.u64 %r350,%r209,-2; $L19: .loc 1 325 0 add.u64 %r100,%r115,%r204; sub.u64 %r263,%r100,%r202; add.u64 %r264,%r201,%r202; mov.u32 %r261,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r264; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r261; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r263; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r265,[%value_in]; } set.u32.eq.u64 %r267,%r265,0; neg.s32 %r268,%r267; set.u32.ne.u64 %r270,%r100,0; neg.s32 %r271,%r270; cvt.u16.u32 %r273,%r268; cvt.u16.u32 %r274,%r271; and.b16 %r272,%r273,%r274; cvt.u32.u16 %r275,%r272; cvt.u16.u8 %r276,%r275; setp.ne.u16 %r277,%r276,0; @ %r277 bra $L31; $L43: .loc 1 408 0 mov.u64 %r200,0; bra $L15; $L20: .loc 1 375 0 sub.u64 %r279,%r204,%r209; max.u64 %r278,%r279,%r209; add.u64 %r280,%r278,1; st.u64 [%frame+2048],%r280; .loc 1 376 0 mov.u64 %r123,0; .loc 1 390 0 add.u64 %r351,%r204,-1; .loc 1 396 0 add.u64 %r352,%r209,-1; .loc 1 397 0 setp.eq.u64 %r353,%r352,-1; add.u64 %r354,%r209,-2; add.u64 %r355,%r203,-1; add.u64 %r356,%r209,1; .loc 1 377 0 bra $L32; $L42: .loc 1 381 0 add.u64 %r281,%r201,%r79; ld.u8 %r284,[%r281+-1]; shl.b64 %r285,%r284,3; add.u64 %r286,%frame,%r285; ld.u64 %r134,[%r286]; .loc 1 382 0 setp.ne.u64 %r287,%r134,0; @ %r287 bra $L33; .loc 1 390 0 setp.ge.u64 %r288,%r209,%r351; @ ! %r288 bra $L60; add.u64 %r348,%r201,%r123; bra $L34; $L60: add.u64 %r289,%r203,%r209; .loc 1 391 0 add.u64 %r348,%r201,%r123; add.u64 %r291,%r348,%r209; .loc 1 390 0 ld.u8 %r292,[%r289]; ld.u8 %r293,[%r291]; setp.eq.u16 %r294,%r292,%r293; @ %r294 bra $L35; mov.u64 %r136,%r209; bra $L36; $L33: .loc 1 384 0 add.u64 %r123,%r123,%r134; .loc 1 385 0 bra $L37; $L35: add.u64 %r186,%r203,%r356; add.u64 %r295,%r123,%r356; add.u64 %r189,%r201,%r295; .loc 1 390 0 mov.u64 %r136,%r209; $L38: .loc 1 392 0 add.u64 %r136,%r136,1; .loc 1 390 0 setp.ge.u64 %r296,%r136,%r351; @ %r296 bra $L34; ld.u8 %r113,[%r186]; .loc 1 391 0 ld.u8 %r114,[%r189]; add.u64 %r186,%r186,1; add.u64 %r189,%r189,1; .loc 1 390 0 cvt.u16.u32 %r297,%r113; cvt.u16.u32 %r298,%r114; setp.eq.u16 %r299,%r297,%r298; @ %r299 bra $L38; bra $L36; $L34: .loc 1 397 0 @ %r353 bra $L39; add.u64 %r301,%r203,%r352; .loc 1 398 0 add.u64 %r303,%r348,%r352; .loc 1 397 0 ld.u8 %r304,[%r301]; ld.u8 %r305,[%r303]; setp.ne.u16 %r306,%r304,%r305; @ %r306 bra $L40; add.u64 %r176,%r203,%r354; add.u64 %r307,%r354,%r123; add.u64 %r80,%r201,%r307; $L41: setp.eq.u64 %r308,%r176,%r355; @ %r308 bra $L39; ld.u8 %r116,[%r176]; .loc 1 398 0 ld.u8 %r117,[%r80]; add.u64 %r176,%r176,-1; add.u64 %r80,%r80,-1; .loc 1 397 0 cvt.u16.u32 %r309,%r116; cvt.u16.u32 %r310,%r117; setp.eq.u16 %r311,%r309,%r310; @ %r311 bra $L41; bra $L40; $L37: .loc 1 390 0 mov.u64 %r202,%r79; $L32: .loc 1 377 0 add.u64 %r79,%r123,%r204; sub.u64 %r315,%r79,%r202; add.u64 %r316,%r201,%r202; mov.u32 %r313,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r316; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r313; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r315; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r317,[%value_in]; } set.u32.ne.u64 %r319,%r79,0; neg.s32 %r320,%r319; set.u32.eq.u64 %r322,%r317,0; neg.s32 %r323,%r322; cvt.u16.u32 %r325,%r320; cvt.u16.u32 %r326,%r323; and.b16 %r324,%r325,%r326; cvt.u32.u16 %r327,%r324; cvt.u16.u8 %r328,%r327; setp.ne.u16 %r329,%r328,0; @ %r329 bra $L42; bra $L43; $L40: .loc 1 402 0 ld.u64 %r331,[%frame+2048]; add.u64 %r123,%r123,%r331; bra $L37; $L39: .loc 1 401 0 mov.u64 %r200,%r348; bra $L15; $L44: .loc 1 325 0 neg.s64 %r335,%r202; add.u64 %r336,%r201,%r202; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r336; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r341; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r335; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r337,[%value_in]; } .loc 1 408 0 mov.u64 %r200,%r204; bra $L15; $L17: .loc 1 317 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r203; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r172; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r209; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r341,[%value_in]; } setp.eq.u32 %r342,%r341,0; @ %r342 bra $L44; bra $L20; $L25: sub.u64 %r343,%r115,%r209; add.u64 %r125,%r343,1; .loc 1 365 0 add.u64 %r115,%r125,%r140; .loc 1 366 0 mov.u64 %r127,%r128; bra $L23; $L36: sub.u64 %r345,%r123,%r209; add.u64 %r107,%r345,1; .loc 1 405 0 add.u64 %r123,%r107,%r136; bra $L37; $L15: .loc 1 409 0 mov.u64 %value,%r200; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strstr .visible .func (.param .u64 %value_out) strstr (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,8; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r25; .reg .u64 %r37; .reg .u64 %r43; .reg .u64 %r44; .reg .u64 %r45; .reg .u32 %r47; .reg .u64 %r48; .reg .u64 %r50; .reg .u64 %r56; .reg .u64 %r57; .reg .u32 %r58; .reg .u64 %r59; .reg .u32 %r60; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r66; .reg .u64 %r70; .reg .u64 %r71; .reg .u64 %r78; .reg .u32 %r79; .reg .u64 %r80; .reg .u32 %r81; .reg .u32 %r83; .reg .u32 %r85; .reg .u64 %r88; .reg .u32 %r95; .reg .u32 %r96; .reg .u64 %r108; .reg .u64 %r115; .reg .u64 %r116; .reg .u64 %r119; .reg .u64 %r122; .reg .u64 %r127; .reg .u64 %r130; .reg .u64 %r137; .reg .u64 %r140; .reg .u64 %r146; .reg .u64 %r147; .reg .pred %r148; .reg .pred %r149; .reg .u16 %r151; .reg .u16 %r152; .reg .u32 %r153; .reg .u32 %r154; .reg .pred %r155; .reg .pred %r156; .reg .pred %r157; .reg .pred %r158; .reg .pred %r159; .reg .u64 %r162; .reg .u64 %r163; .reg .u32 %r165; .reg .u32 %r166; .reg .u32 %r168; .reg .u32 %r169; .reg .u16 %r170; .reg .u16 %r171; .reg .u16 %r172; .reg .u32 %r173; .reg .u16 %r174; .reg .pred %r175; .reg .pred %r176; .reg .pred %r177; .reg .u64 %r181; .reg .u64 %r185; .reg .u64 %r186; .reg .u32 %r187; .reg .pred %r188; .reg .pred %r189; .reg .u64 %r190; .reg .u64 %r191; .reg .u64 %r192; .reg .u16 %r193; .reg .u16 %r194; .reg .pred %r195; .reg .u64 %r197; .reg .u64 %r198; .reg .pred %r199; .reg .u16 %r200; .reg .u16 %r201; .reg .pred %r202; .reg .pred %r203; .reg .u64 %r204; .reg .u64 %r205; .reg .u64 %r206; .reg .u16 %r207; .reg .u16 %r208; .reg .pred %r209; .reg .u64 %r210; .reg .pred %r211; .reg .u16 %r212; .reg .u16 %r213; .reg .pred %r214; .reg .u64 %r215; .reg .pred %r216; .reg .u32 %r218; .reg .u64 %r220; .reg .u64 %r221; .reg .u64 %r222; .reg .u32 %r224; .reg .u32 %r225; .reg .u32 %r227; .reg .u32 %r228; .reg .u16 %r229; .reg .u16 %r230; .reg .u16 %r231; .reg .u32 %r232; .reg .u16 %r233; .reg .pred %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .u64 %r237; .reg .u64 %r238; .reg .pred %r239; .reg .u16 %r240; .reg .u16 %r241; .reg .pred %r242; .reg .u64 %r244; .reg .u64 %r245; .reg .u16 %r246; .reg .u16 %r247; .reg .pred %r248; .reg .u64 %r249; .reg .pred %r250; .reg .u16 %r251; .reg .u16 %r252; .reg .pred %r253; .reg .u32 %r255; .reg .u64 %r257; .reg .u64 %r258; .reg .u64 %r259; .reg .u32 %r261; .reg .u32 %r262; .reg .u32 %r264; .reg .u32 %r265; .reg .u16 %r266; .reg .u16 %r267; .reg .u16 %r268; .reg .u32 %r269; .reg .u16 %r270; .reg .pred %r271; .reg .pred %r272; .reg .u64 %r273; .reg .u64 %r274; .reg .u64 %r275; .reg .u16 %r276; .reg .u16 %r277; .reg .pred %r278; .reg .u64 %r283; .reg .u64 %r285; .reg .u64 %r286; .reg .u64 %r289; .reg .u64 %r291; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r294; .reg .u64 %r295; .reg .pred %r296; .reg .u64 %r297; .reg .u64 %r298; .reg .u64 %r299; mov.u64 %r146,%ar0; mov.u64 %r147,%ar1; .loc 2 97 0 ld.s8 %r25,[%r146]; ld.s8 %r96,[%r147]; setp.eq.u32 %r148,%r25,0; @ %r148 bra $L62; setp.eq.u32 %r149,%r96,0; @ %r149 bra $L101; mov.u64 %r45,%r147; mov.u64 %r44,%r146; mov.u32 %r95,%r96; .loc 2 92 0 mov.u32 %r47,1; $L65: .loc 2 98 0 add.u64 %r44,%r44,1; add.u64 %r45,%r45,1; cvt.u16.u32 %r151,%r95; cvt.u16.u32 %r152,%r25; set.u32.eq.u16 %r153,%r151,%r152; neg.s32 %r154,%r153; and.b32 %r47,%r47,%r154; .loc 2 97 0 ld.s8 %r25,[%r44]; ld.s8 %r95,[%r45]; setp.eq.u32 %r155,%r25,0; @ %r155 bra $L64; setp.ne.u32 %r156,%r95,0; @ %r156 bra $L65; bra $L66; $L62: .loc 2 99 0 setp.eq.u32 %r157,%r96,0; .loc 2 100 0 selp.u64 %r146,%r146,0,%r157; bra $L101; $L64: .loc 2 99 0 setp.ne.u32 %r158,%r95,0; @ %r158 bra $L91; $L66: .loc 2 101 0 setp.ne.u32 %r159,%r47,0; @ %r159 bra $L101; .loc 2 106 0 sub.u64 %r48,%r45,%r147; .loc 2 107 0 add.u64 %r162,%r146,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r162; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r96; call (%value_in),strchr,(%out_arg1,%out_arg2); ld.param.u64 %r163,[%value_in]; } .loc 2 108 0 set.u32.eq.u64 %r165,%r163,0; neg.s32 %r166,%r165; set.u32.eq.u64 %r168,%r48,1; neg.s32 %r169,%r168; cvt.u16.u32 %r171,%r166; cvt.u16.u32 %r172,%r169; or.b16 %r170,%r171,%r172; cvt.u32.u16 %r173,%r170; cvt.u16.u8 %r174,%r173; setp.ne.u16 %r175,%r174,0; @ %r175 bra $L92; .loc 2 110 0 add.u64 %r37,%r146,%r48; .loc 2 111 0 setp.lt.u64 %r176,%r37,%r163; @ %r176 bra $L93; sub.u64 %r43,%r37,%r163; bra $L67; $L93: mov.u64 %r43,1; $L67: .loc 2 114 0 setp.gt.u64 %r177,%r48,31; @ %r177 bra $L68; .loc 1 209 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r147; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r48; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),critical_factorization,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r181,[%value_in]; } .loc 1 213 0 ld.u64 %r186,[%frame]; add.u64 %r185,%r147,%r186; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r147; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r185; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r181; call (%value_in),memcmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r187,[%value_in]; } setp.eq.u32 %r188,%r187,0; @ %r188 bra $L94; bra $L111; $L78: .loc 1 223 0 max.u64 %r57,%r181,%r56; .loc 1 224 0 setp.le.u64 %r189,%r48,%r57; @ %r189 bra $L71; .loc 1 225 0 add.u64 %r190,%r163,%r57; add.u64 %r191,%r190,%r59; .loc 1 224 0 add.u64 %r192,%r147,%r57; ld.u8 %r193,[%r191]; ld.u8 %r194,[%r192]; setp.ne.u16 %r195,%r193,%r194; @ %r195 bra $L72; add.u64 %r291,%r57,1; add.u64 %r119,%r147,%r291; add.u64 %r197,%r59,1; add.u64 %r198,%r197,%r57; add.u64 %r122,%r163,%r198; $L73: .loc 1 226 0 mov.u64 %r57,%r291; .loc 1 224 0 setp.eq.u64 %r199,%r48,%r291; @ %r199 bra $L71; ld.u8 %r58,[%r119]; .loc 1 225 0 ld.u8 %r60,[%r122]; add.u64 %r119,%r119,1; add.u64 %r122,%r122,1; .loc 1 224 0 cvt.u16.u32 %r200,%r58; cvt.u16.u32 %r201,%r60; setp.eq.u16 %r202,%r200,%r201; @ ! %r202 bra $L72; add.u64 %r291,%r291,1; bra $L73; $L71: .loc 1 230 0 mov.u64 %r115,%r293; .loc 1 231 0 setp.le.u64 %r203,%r181,%r56; @ %r203 bra $L95; add.u64 %r204,%r147,%r293; .loc 1 232 0 add.u64 %r205,%r163,%r59; add.u64 %r206,%r205,%r293; .loc 1 231 0 ld.u8 %r207,[%r204]; ld.u8 %r208,[%r206]; setp.ne.u16 %r209,%r207,%r208; @ %r209 bra $L96; add.u64 %r62,%r147,%r294; add.u64 %r210,%r294,%r59; add.u64 %r116,%r163,%r210; add.u64 %r64,%r56,-1; bra $L75; $L97: mov.u64 %r115,%r63; $L75: .loc 1 233 0 add.u64 %r63,%r115,-1; .loc 1 231 0 setp.eq.u64 %r211,%r63,%r64; @ %r211 bra $L74; ld.u8 %r65,[%r62]; .loc 1 232 0 ld.u8 %r66,[%r116]; add.u64 %r62,%r62,-1; add.u64 %r116,%r116,-1; .loc 1 231 0 cvt.u16.u32 %r212,%r65; cvt.u16.u32 %r213,%r66; setp.eq.u16 %r214,%r212,%r213; @ %r214 bra $L97; bra $L74; $L95: mov.u64 %r115,%r181; bra $L74; $L96: mov.u64 %r115,%r181; $L74: .loc 1 234 0 add.u64 %r215,%r56,1; setp.le.u64 %r216,%r215,%r115; @ %r216 bra $L76; .loc 1 235 0 add.u64 %r146,%r163,%r59; bra $L101; $L76: .loc 1 238 0 ld.u64 %r70,[%frame]; add.u64 %r59,%r59,%r70; .loc 1 239 0 sub.u64 %r56,%r48,%r70; $L89: .loc 1 244 0 mov.u64 %r43,%r71; bra $L69; $L94: .loc 1 218 0 mov.u64 %r56,0; .loc 1 219 0 mov.u64 %r59,%r56; .loc 1 230 0 add.u64 %r293,%r181,-1; add.u64 %r294,%r181,-2; $L69: .loc 1 220 0 add.u64 %r71,%r48,%r59; sub.u64 %r220,%r71,%r43; add.u64 %r221,%r163,%r43; mov.u32 %r218,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r221; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r218; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r220; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r222,[%value_in]; } set.u32.eq.u64 %r224,%r222,0; neg.s32 %r225,%r224; set.u32.ne.u64 %r227,%r71,0; neg.s32 %r228,%r227; cvt.u16.u32 %r230,%r225; cvt.u16.u32 %r231,%r228; and.b16 %r229,%r230,%r231; cvt.u32.u16 %r232,%r229; cvt.u16.u8 %r233,%r232; setp.ne.u16 %r234,%r233,0; @ %r234 bra $L78; bra $L79; $L111: .loc 1 252 0 sub.u64 %r236,%r48,%r181; max.u64 %r235,%r236,%r181; add.u64 %r237,%r235,1; st.u64 [%frame],%r237; .loc 1 253 0 mov.u64 %r80,0; .loc 1 264 0 add.u64 %r295,%r181,-1; .loc 1 265 0 setp.ne.u64 %r296,%r295,-1; add.u64 %r297,%r181,-2; add.u64 %r298,%r147,-1; add.u64 %r299,%r181,1; bra $L80; $L87: add.u64 %r137,%r147,%r299; add.u64 %r238,%r80,%r299; add.u64 %r140,%r163,%r238; .loc 1 258 0 mov.u64 %r78,%r181; $L82: .loc 1 260 0 add.u64 %r78,%r78,1; .loc 1 258 0 setp.eq.u64 %r239,%r48,%r78; @ %r239 bra $L81; ld.u8 %r79,[%r137]; .loc 1 259 0 ld.u8 %r81,[%r140]; add.u64 %r137,%r137,1; add.u64 %r140,%r140,1; .loc 1 258 0 cvt.u16.u32 %r240,%r79; cvt.u16.u32 %r241,%r81; setp.eq.u16 %r242,%r240,%r241; @ %r242 bra $L82; bra $L83; $L90: .loc 1 266 0 add.u64 %r292,%r163,%r80; add.u64 %r244,%r292,%r295; .loc 1 265 0 add.u64 %r245,%r147,%r295; ld.u8 %r246,[%r244]; ld.u8 %r247,[%r245]; setp.ne.u16 %r248,%r246,%r247; @ %r248 bra $L84; add.u64 %r127,%r147,%r297; add.u64 %r249,%r80,%r297; add.u64 %r130,%r163,%r249; $L86: setp.eq.u64 %r250,%r127,%r298; @ %r250 bra $L85; ld.u8 %r83,[%r127]; .loc 1 266 0 ld.u8 %r85,[%r130]; add.u64 %r127,%r127,-1; add.u64 %r130,%r130,-1; .loc 1 265 0 cvt.u16.u32 %r251,%r83; cvt.u16.u32 %r252,%r85; setp.eq.u16 %r253,%r251,%r252; @ %r253 bra $L86; bra $L84; $L88: .loc 1 258 0 mov.u64 %r43,%r88; $L80: .loc 1 254 0 add.u64 %r88,%r48,%r80; sub.u64 %r257,%r88,%r43; add.u64 %r258,%r163,%r43; mov.u32 %r255,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r258; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r255; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r257; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r259,[%value_in]; } set.u32.ne.u64 %r261,%r88,0; neg.s32 %r262,%r261; set.u32.eq.u64 %r264,%r259,0; neg.s32 %r265,%r264; cvt.u16.u32 %r267,%r262; cvt.u16.u32 %r268,%r265; and.b16 %r266,%r267,%r268; cvt.u32.u16 %r269,%r266; cvt.u16.u8 %r270,%r269; setp.eq.u16 %r271,%r270,0; @ %r271 bra $L79; .loc 1 258 0 setp.le.u64 %r272,%r48,%r181; @ %r272 bra $L81; add.u64 %r273,%r147,%r181; .loc 1 259 0 add.u64 %r274,%r163,%r181; add.u64 %r275,%r274,%r80; .loc 1 258 0 ld.u8 %r276,[%r273]; ld.u8 %r277,[%r275]; setp.eq.u16 %r278,%r276,%r277; @ %r278 bra $L87; mov.u64 %r78,%r181; bra $L83; $L79: .loc 1 276 0 mov.u64 %r146,0; .loc 2 115 0 bra $L101; $L68: .loc 2 118 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r163; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r43; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r147; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r48; call (%value_in),two_way_long_needle,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r283,[%value_in]; } mov.u64 %r146,%r283; bra $L101; $L91: .loc 2 100 0 mov.u64 %r146,0; bra $L101; $L92: .loc 2 107 0 mov.u64 %r146,%r163; bra $L101; $L85: .loc 1 269 0 mov.u64 %r146,%r292; bra $L101; $L84: .loc 1 270 0 ld.u64 %r285,[%frame]; add.u64 %r80,%r80,%r285; bra $L88; $L72: sub.u64 %r286,%r59,%r181; add.u64 %r50,%r286,1; .loc 1 243 0 add.u64 %r59,%r57,%r50; .loc 1 244 0 mov.u64 %r56,0; bra $L89; $L81: .loc 1 265 0 @ %r296 bra $L90; add.u64 %r292,%r163,%r80; bra $L85; $L83: sub.u64 %r289,%r80,%r181; add.u64 %r108,%r289,1; .loc 1 273 0 add.u64 %r80,%r78,%r108; bra $L88; $L101: .loc 2 121 0 mov.u64 %value,%r146; st.shared.u64 [%sspslot],%sspprev; st.param.u64 [%value_out],%value; ret; } lib_a-strtod.o/ 0 0 0 644 59843 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN FUNCTION DECL: sulp .func (.param .f64 %value_out) sulp (.param .u64 %in_ar0, .param .u32 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/strtod.c" // BEGIN GLOBAL FUNCTION DECL: _strtod_r .visible .func (.param .f64 %value_out) _strtod_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strtod .visible .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: strtof .visible .func (.param .f32 %value_out) strtof (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __mprec_bigtens .extern .const .align 8 .u64 __mprec_bigtens[5]; // BEGIN GLOBAL VAR DECL: __mprec_tens .extern .const .align 8 .u64 __mprec_tens[25]; // BEGIN GLOBAL FUNCTION DECL: __ulp .extern .func (.param .f64 %value_out) __ulp (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __gethex .extern .func (.param .u32 %value_out) __gethex (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4, .param .u32 %in_ar5); // BEGIN GLOBAL FUNCTION DECL: __copybits .extern .func __copybits (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _Bfree .extern .func _Bfree (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strncmp .extern .func (.param .u32 %value_out) strncmp (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __hexnan .extern .func (.param .u32 %value_out) __hexnan (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __s2b .extern .func (.param .u64 %value_out) __s2b (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u32 %in_ar4); // BEGIN GLOBAL FUNCTION DECL: _Balloc .extern .func (.param .u64 %value_out) _Balloc (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __d2b .extern .func (.param .u64 %value_out) __d2b (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __i2b .extern .func (.param .u64 %value_out) __i2b (.param .u64 %in_ar0, .param .u32 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __pow5mult .extern .func (.param .u64 %value_out) __pow5mult (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __multiply .extern .func (.param .u64 %value_out) __multiply (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __lshift .extern .func (.param .u64 %value_out) __lshift (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mdiff .extern .func (.param .u64 %value_out) __mdiff (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __mcmp .extern .func (.param .u32 %value_out) __mcmp (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ratio .extern .func (.param .f64 %value_out) __ratio (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: nanf .extern .func (.param .f32 %value_out) nanf (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: fpinan$2587 .const .align 4 .u32 fpinan$2587[5] = {52,4294966222,971,1,0 }; // BEGIN VAR DEF: fpi$2551 .const .align 4 .u32 fpi$2551[5] = {53,4294966222,971,1,0 }; // BEGIN VAR DEF: tinytens .const .align 8 .u64 tinytens[5] = {4367597403136100796,4128101167230658355,3649340653511681853,2691949749288605597,1254259266780163907 }; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {110,102,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[6] = {105,110,105,116,121,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[3] = {97,110,0 }; // BEGIN FUNCTION DEF: sulp .func (.param .f64 %value_out) sulp (.param .u64 %in_ar0, .param .u32 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u32 %r31; .reg .f64 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u32 %r36; .reg .f64 %r37; .reg .f64 %r38; .reg .pred %r39; .reg .u64 %r40; .reg .u32 %r41; .reg .u32 %r42; .reg .u32 %r43; .reg .u32 %r44; .reg .pred %r45; .reg .u32 %r46; .reg .u32 %r47; .reg .u64 %r48; .reg .u64 %r52; .reg .f64 %r53; mov.u64 %r34,%ar0; ld.u64 %r35,[%r34]; mov.u32 %r36,%ar1; .loc 1 163 0 mov.b64 %r37,%r35; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r37; call (%value_in),__ulp,(%out_arg1); ld.param.f64 %r38,[%value_in]; } mov.f64 %r33,%r38; .loc 1 164 0 setp.eq.u32 %r39,%r36,0; @ %r39 bra $L1; shr.u64 %r40,%r35,32; cvt.u32.u64 %r42,%r40; shr.u32 %r41,%r42,20; and.b32 %r43,%r41,2047; mov.u32 %r44,107; sub.u32 %r31,%r44,%r43; setp.le.s32 %r45,%r31,0; @ %r45 bra $L1; .loc 1 166 0 shl.b32 %r46,%r31,20; add.u32 %r47,%r46,1072693248; cvt.u64.u32 %r48,%r47; .loc 1 168 0 shl.b64 %r52,%r48,32; .loc 1 170 0 mov.b64 %r53,%r52; mul.f64 %r33,%r33,%r53; $L1: .loc 1 171 0 mov.f64 %value,%r33; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _strtod_r .visible .func (.param .f64 %value_out) _strtod_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,40; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r127; .reg .u64 %r128; .reg .u64 %r129; .reg .f64 %r131; .reg .u32 %r132; .reg .u64 %r133; .reg .u32 %r136; .reg .u32 %r146; .reg .u64 %r157; .reg .u32 %r168; .reg .u32 %r170; .reg .f64 %r174; .reg .u32 %r181; .reg .u32 %r191; .reg .u32 %r192; .reg .u64 %r193; .reg .f64 %r208; .reg .f64 %r233; .reg .u32 %r240; .reg .f64 %r258; .reg .u32 %r259; .reg .u32 %r260; .reg .u32 %r273; .reg .u32 %r275; .reg .u64 %r289; .reg .u32 %r290; .reg .u32 %r292; .reg .u32 %r293; .reg .f64 %r295; .reg .f64 %r296; .reg .u64 %r298; .reg .f64 %r299; .reg .f64 %r306; .reg .f64 %r309; .reg .f64 %r314; .reg .u32 %r316; .reg .u32 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r327; .reg .u32 %r328; .reg .u32 %r329; .reg .f64 %r331; .reg .u32 %r332; .reg .u32 %r333; .reg .u64 %r335; .reg .u64 %r336; .reg .u64 %r337; .reg .u64 %r338; .reg .u32 %r339; .reg .u32 %r340; .reg .u32 %r341; .reg .f64 %r342; .reg .f64 %r343; .reg .u64 %r344; .reg .u32 %r345; .reg .u32 %r351; .reg .u64 %r354; .reg .u32 %r355; .reg .u32 %r356; .reg .u64 %r357; .reg .u64 %r358; .reg .u64 %r360; .reg .u32 %r361; .reg .u32 %r362; .reg .u32 %r363; .reg .u32 %r364; .reg .u32 %r366; .reg .u32 %r367; .reg .u32 %r368; .reg .u32 %r369; .reg .u32 %r370; .reg .u32 %r371; .reg .u32 %r372; .reg .u32 %r373; .reg .u64 %r374; .reg .u64 %r375; .reg .u32 %r376; .reg .u32 %r377; .reg .u32 %r381; .reg .u32 %r382; .reg .u32 %r383; .reg .u32 %r385; .reg .u32 %r388; .reg .u32 %r389; .reg .u64 %r390; .reg .f64 %r393; .reg .u32 %r394; .reg .u64 %r398; .reg .u32 %r400; .reg .u32 %r401; .reg .u32 %r405; .reg .u32 %r406; .reg .u64 %r409; .reg .u32 %r411; .reg .u32 %r412; .reg .u32 %r415; .reg .u32 %r416; .reg .u64 %r435; .reg .u32 %r441; .reg .u32 %r445; .reg .u32 %r446; .reg .f64 %r447; .reg .u64 %r452; .reg .u64 %r454; .reg .u32 %r455; .reg .u64 %r456; .reg .u32 %r457; .reg .u64 %r458; .reg .u64 %r467; .reg .u64 %r468; .reg .f64 %r470; .reg .u64 %r471; .reg .u64 %r472; .reg .u64 %r473; .reg .u64 %r474; .reg .u16 %r475; .reg .pred %r476; .reg .pred %r478; .reg .pred %r480; .reg .pred %r482; .reg .pred %r484; .reg .pred %r486; .reg .pred %r487; .reg .u16 %r488; .reg .pred %r489; .reg .u16 %r490; .reg .u32 %r491; .reg .pred %r492; .reg .pred %r493; .reg .u64 %r496; .reg .u64 %r500; .reg .u64 %r501; .reg .u64 %r502; .reg .u32 %r503; .reg .pred %r504; .reg .pred %r505; .reg .pred %r506; .reg .pred %r507; .reg .u32 %r509; .reg .u64 %r513; .reg .pred %r514; .reg .pred %r515; .reg .pred %r516; .reg .pred %r517; .reg .pred %r518; .reg .pred %r519; .reg .u64 %r523; .reg .u64 %r524; .reg .u64 %r525; .reg .u32 %r530; .reg .u32 %r531; .reg .u32 %r532; .reg .u32 %r533; .reg .u32 %r534; .reg .u64 %r535; .reg .u64 %r536; .reg .u64 %r537; .reg .u32 %r541; .reg .pred %r542; .reg .u64 %r543; .reg .u32 %r544; .reg .u32 %r545; .reg .u64 %r546; .reg .u64 %r547; .reg .u64 %r548; .reg .u16 %r550; .reg .pred %r551; .reg .pred %r552; .reg .pred %r554; .reg .pred %r555; .reg .u32 %r557; .reg .u32 %r558; .reg .u32 %r559; .reg .u32 %r562; .reg .u32 %r563; .reg .u32 %r564; .reg .pred %r567; .reg .u64 %r569; .reg .u64 %r570; .reg .u64 %r571; .reg .u64 %r573; .reg .u64 %r575; .reg .u64 %r577; .reg .u32 %r578; .reg .pred %r579; .reg .u64 %r581; .reg .u64 %r582; .reg .u64 %r583; .reg .u64 %r584; .reg .pred %r585; .reg .pred %r586; .reg .pred %r587; .reg .pred %r588; .reg .pred %r589; .reg .pred %r590; .reg .u32 %r592; .reg .u32 %r593; .reg .pred %r596; .reg .u32 %r598; .reg .u32 %r599; .reg .pred %r601; .reg .pred %r602; .reg .u32 %r604; .reg .u32 %r605; .reg .u32 %r606; .reg .pred %r607; .reg .u32 %r609; .reg .u32 %r610; .reg .u32 %r611; .reg .u64 %r612; .reg .u32 %r613; .reg .pred %r614; .reg .u32 %r615; .reg .pred %r616; .reg .u32 %r617; .reg .u32 %r618; .reg .pred %r619; .reg .u64 %r620; .reg .u16 %r621; .reg .pred %r622; .reg .pred %r624; .reg .u64 %r625; .reg .u32 %r626; .reg .pred %r627; .reg .pred %r628; .reg .u64 %r629; .reg .pred %r630; .reg .u32 %r631; .reg .pred %r632; .reg .u32 %r633; .reg .pred %r634; .reg .u32 %r636; .reg .u32 %r637; .reg .u32 %r638; .reg .u32 %r639; .reg .pred %r640; .reg .u64 %r641; .reg .u32 %r643; .reg .u32 %r644; .reg .u32 %r646; .reg .u32 %r647; .reg .u16 %r648; .reg .u16 %r649; .reg .u16 %r650; .reg .u32 %r651; .reg .u16 %r652; .reg .pred %r653; .reg .pred %r654; .reg .pred %r655; .reg .u32 %r656; .reg .pred %r657; .reg .pred %r658; .reg .pred %r659; .reg .pred %r660; .reg .pred %r661; .reg .pred %r662; .reg .pred %r663; .reg .u32 %r664; .reg .pred %r665; .reg .pred %r666; .reg .pred %r667; .reg .u32 %r668; .reg .pred %r669; .reg .pred %r670; .reg .pred %r671; .reg .u64 %r672; .reg .u64 %r673; .reg .u32 %r674; .reg .pred %r675; .reg .pred %r676; .reg .pred %r677; .reg .u64 %r678; .reg .u16 %r679; .reg .u32 %r680; .reg .pred %r681; .reg .u64 %r683; .reg .u64 %r685; .reg .u32 %r686; .reg .pred %r687; .reg .u32 %r688; .reg .u32 %r689; .reg .u64 %r690; .reg .u64 %r694; .reg .u64 %r695; .reg .pred %r697; .reg .pred %r698; .reg .pred %r699; .reg .pred %r700; .reg .f64 %r701; .reg .u64 %r702; .reg .u32 %r703; .reg .u64 %r704; .reg .u64 %r705; .reg .u64 %r706; .reg .f64 %r707; .reg .f64 %r708; .reg .pred %r709; .reg .pred %r710; .reg .pred %r711; .reg .u64 %r712; .reg .u64 %r713; .reg .u64 %r714; .reg .u64 %r715; .reg .f64 %r716; .reg .f64 %r717; .reg .u32 %r718; .reg .u32 %r719; .reg .pred %r720; .reg .u32 %r721; .reg .u64 %r722; .reg .u64 %r723; .reg .u64 %r724; .reg .u64 %r725; .reg .f64 %r726; .reg .f64 %r727; .reg .f64 %r728; .reg .u32 %r730; .reg .u64 %r731; .reg .u64 %r732; .reg .u64 %r733; .reg .f64 %r734; .reg .pred %r735; .reg .u64 %r736; .reg .u32 %r737; .reg .u64 %r738; .reg .u64 %r739; .reg .u64 %r740; .reg .f64 %r741; .reg .f64 %r742; .reg .u32 %r743; .reg .pred %r744; .reg .pred %r745; .reg .u64 %r746; .reg .u64 %r747; .reg .u64 %r748; .reg .u64 %r749; .reg .f64 %r750; .reg .f64 %r751; .reg .f64 %r752; .reg .pred %r753; .reg .pred %r754; .reg .u32 %r755; .reg .u32 %r756; .reg .pred %r757; .reg .u32 %r758; .reg .pred %r759; .reg .f64 %r760; .reg .pred %r761; .reg .pred %r762; .reg .u64 %r763; .reg .u32 %r764; .reg .u32 %r765; .reg .u64 %r766; .reg .u64 %r767; .reg .u64 %r768; .reg .u64 %r771; .reg .u64 %r772; .reg .u64 %r773; .reg .f64 %r774; .reg .f64 %r775; .reg .u64 %r777; .reg .pred %r778; .reg .pred %r779; .reg .u32 %r780; .reg .u64 %r781; .reg .u64 %r782; .reg .u64 %r783; .reg .pred %r785; .reg .pred %r786; .reg .u64 %r787; .reg .u64 %r788; .reg .u64 %r789; .reg .u64 %r790; .reg .f64 %r791; .reg .f64 %r792; .reg .f64 %r793; .reg .pred %r794; .reg .pred %r795; .reg .pred %r796; .reg .pred %r797; .reg .pred %r798; .reg .u32 %r799; .reg .pred %r800; .reg .f64 %r801; .reg .pred %r802; .reg .pred %r803; .reg .pred %r804; .reg .u32 %r806; .reg .u32 %r807; .reg .u32 %r808; .reg .pred %r809; .reg .pred %r810; .reg .pred %r812; .reg .u32 %r815; .reg .u32 %r816; .reg .u32 %r817; .reg .u32 %r818; .reg .u64 %r819; .reg .u64 %r820; .reg .u64 %r821; .reg .u32 %r823; .reg .u32 %r824; .reg .u32 %r825; .reg .u32 %r826; .reg .u64 %r827; .reg .u64 %r828; .reg .f64 %r830; .reg .pred %r831; .reg .u32 %r832; .reg .u64 %r838; .reg .pred %r839; .reg .u32 %r840; .reg .pred %r841; .reg .u32 %r844; .reg .u64 %r845; .reg .pred %r846; .reg .u64 %r850; .reg .u64 %r851; .reg .u64 %r852; .reg .u64 %r854; .reg .u64 %r855; .reg .u64 %r861; .reg .pred %r862; .reg .u32 %r864; .reg .u64 %r865; .reg .pred %r866; .reg .pred %r867; .reg .u32 %r868; .reg .u32 %r869; .reg .u32 %r870; .reg .pred %r871; .reg .u32 %r872; .reg .pred %r873; .reg .u32 %r874; .reg .u32 %r875; .reg .u32 %r876; .reg .u32 %r877; .reg .u32 %r878; .reg .pred %r879; .reg .u64 %r884; .reg .pred %r885; .reg .u64 %r889; .reg .u64 %r890; .reg .pred %r891; .reg .u64 %r894; .reg .pred %r895; .reg .u64 %r900; .reg .u64 %r901; .reg .pred %r902; .reg .u64 %r906; .reg .pred %r907; .reg .pred %r908; .reg .u64 %r912; .reg .pred %r913; .reg .pred %r914; .reg .u64 %r918; .reg .pred %r919; .reg .u64 %r923; .reg .u64 %r924; .reg .pred %r925; .reg .u32 %r926; .reg .u32 %r929; .reg .pred %r930; .reg .pred %r931; .reg .u64 %r932; .reg .u64 %r933; .reg .pred %r934; .reg .u32 %r936; .reg .u32 %r937; .reg .pred %r938; .reg .u32 %r939; .reg .pred %r940; .reg .u32 %r941; .reg .pred %r942; .reg .u32 %r945; .reg .u64 %r946; .reg .u32 %r949; .reg .pred %r950; .reg .pred %r951; .reg .u64 %r953; .reg .u32 %r954; .reg .pred %r955; .reg .pred %r956; .reg .pred %r957; .reg .u32 %r958; .reg .u32 %r959; .reg .u32 %r960; .reg .u32 %r961; .reg .pred %r962; .reg .u64 %r963; .reg .pred %r964; .reg .u32 %r965; .reg .u32 %r966; .reg .u64 %r967; .reg .u64 %r972; .reg .u64 %r973; .reg .pred %r974; .reg .pred %r976; .reg .pred %r977; .reg .pred %r978; .reg .u32 %r980; .reg .u32 %r981; .reg .u64 %r982; .reg .u64 %r983; .reg .pred %r987; .reg .u64 %r988; .reg .u32 %r989; .reg .u32 %r990; .reg .pred %r991; .reg .u32 %r992; .reg .u32 %r993; .reg .pred %r994; .reg .u64 %r998; .reg .f64 %r999; .reg .u64 %r1002; .reg .f64 %r1003; .reg .pred %r1004; .reg .f64 %r1007; .reg .pred %r1008; .reg .pred %r1009; .reg .u64 %r1010; .reg .pred %r1011; .reg .pred %r1012; .reg .pred %r1013; .reg .pred %r1014; .reg .u64 %r1015; .reg .pred %r1016; .reg .u32 %r1017; .reg .u64 %r1018; .reg .u64 %r1019; .reg .u64 %r1020; .reg .f64 %r1023; .reg .u64 %r1025; .reg .u32 %r1026; .reg .pred %r1027; .reg .u64 %r1028; .reg .pred %r1029; .reg .u64 %r1030; .reg .u64 %r1031; .reg .u64 %r1032; .reg .u32 %r1038; .reg .u32 %r1039; .reg .u16 %r1040; .reg .u16 %r1042; .reg .u32 %r1043; .reg .u16 %r1044; .reg .pred %r1045; .reg .pred %r1046; .reg .pred %r1047; .reg .pred %r1048; .reg .u64 %r1049; .reg .u32 %r1050; .reg .u32 %r1051; .reg .u32 %r1052; .reg .u64 %r1053; .reg .u64 %r1054; .reg .u64 %r1055; .reg .f64 %r1058; .reg .f64 %r1059; .reg .u32 %r1061; .reg .u32 %r1063; .reg .u32 %r1064; .reg .u16 %r1068; .reg .u16 %r1069; .reg .u32 %r1071; .reg .u16 %r1072; .reg .pred %r1073; .reg .u32 %r1074; .reg .pred %r1075; .reg .u64 %r1076; .reg .pred %r1077; .reg .pred %r1078; .reg .pred %r1079; .reg .pred %r1080; .reg .u64 %r1083; .reg .pred %r1090; .reg .pred %r1093; .reg .u32 %r1094; .reg .pred %r1105; .reg .u64 %r1106; .reg .pred %r1107; .reg .u32 %r1109; .reg .u32 %r1110; .reg .u32 %r1111; .reg .u32 %r1112; .reg .pred %r1113; .reg .u64 %r1114; .reg .u64 %r1115; .reg .u32 %r1116; .reg .u32 %r1117; .reg .pred %r1118; .reg .u32 %r1119; .reg .u64 %r1120; .reg .u64 %r1121; .reg .pred %r1122; .reg .pred %r1123; .reg .u32 %r1124; .reg .u32 %r1125; .reg .u16 %r1126; .reg .u32 %r1127; .reg .u32 %r1128; .reg .u16 %r1129; .reg .u32 %r1130; .reg .u32 %r1131; mov.u64 %r471,%ar0; mov.u64 %r472,%ar1; mov.u64 %r473,%ar2; .loc 1 252 0 mov.u64 %r474,0; st.u64 [%frame+8],%r474; .loc 1 265 0 mov.u64 %r468,%r474; .loc 1 266 0 st.u64 [%frame+16],%r472; mov.u64 %r128,%r472; $L13: ld.s8 %r457,[%r128]; cvt.u16.u32 %r475,%r457; setp.gt.s16 %r476,%r475,13; @ %r476 bra $L8; setp.ge.s16 %r478,%r475,9; @ %r478 bra $L9; setp.eq.u16 %r480,%r475,0; @ %r480 bra $L10; bra $L173; $L8: setp.eq.u16 %r482,%r475,43; @ %r482 bra $L174; setp.eq.u16 %r484,%r475,45; @ %r484 bra $L12; setp.eq.u16 %r486,%r475,32; @ ! %r486 bra $L173; bra $L9; $L12: .loc 1 268 0 mov.u32 %r329,1; bra $L11; $L174: .loc 1 264 0 mov.u32 %r329,0; $L11: .loc 1 271 0 add.u64 %r458,%r128,1; st.u64 [%frame+16],%r458; ld.s8 %r457,[%r128+1]; setp.ne.u32 %r487,%r457,0; @ %r487 bra $L7; bra $L10; $L9: .loc 1 266 0 add.u64 %r128,%r128,1; st.u64 [%frame+16],%r128; bra $L13; $L173: mov.u64 %r458,%r128; .loc 1 264 0 mov.u32 %r329,0; $L7: .loc 1 287 0 cvt.u16.u32 %r488,%r457; setp.ne.u16 %r489,%r488,48; @ %r489 bra $L175; .loc 1 293 0 ld.s8 %r491,[%r458+1]; cvt.u16.u32 %r490,%r491; setp.eq.u16 %r492,%r490,88; @ %r492 bra $L16; setp.eq.u16 %r493,%r490,120; @ ! %r493 bra $L317; $L16: .loc 1 310 0 add.u64 %r500,%frame,8; add.u64 %r501,%frame,24; add.u64 %r502,%frame,16; cvta.const.u64 %r496,fpi$2551; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r502; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r496; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r501; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r500; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r329; call (%value_in),__gethex,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6); ld.param.u32 %r503,[%value_in]; } and.b32 %r132,%r503,7; setp.eq.u32 %r504,%r132,0; @ %r504 bra $L176; setp.eq.u32 %r505,%r132,6; @ ! %r505 bra $L318; add.u64 %r435,%r458,1; .loc 1 1249 0 setp.eq.u64 %r506,%r473,0; @ %r506 bra $L177; .loc 1 1250 0 st.u64 [%r473],%r435; mov.f64 %r470,0d0000000000000000; bra $L6; $L318: .loc 1 318 0 ld.u64 %r133,[%frame+8]; setp.eq.u64 %r507,%r133,0; @ %r507 bra $L21; .loc 1 319 0 mov.u32 %r509,53; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%frame; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r509; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r133; call __copybits,(%out_arg1,%out_arg2,%out_arg3); } .loc 1 320 0 ld.u64 %r513,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r513; call _Bfree,(%out_arg1,%out_arg2); } $L21: .loc 1 184 0 setp.eq.u32 %r514,%r132,3; @ %r514 bra $L23; setp.gt.s32 %r515,%r132,3; @ %r515 bra $L24; setp.eq.u32 %r516,%r132,1; @ %r516 bra $L25; setp.eq.u32 %r517,%r132,2; @ %r517 bra $L26; bra $L22; $L24: setp.eq.u32 %r518,%r132,4; @ %r518 bra $L27; setp.eq.u32 %r519,%r132,5; @ ! %r519 bra $L22; bra $L25; $L26: .loc 1 192 0 ld.u32 %r523,[%frame+4]; shl.b64 %r524,%r523,32; ld.u32 %r525,[%frame]; or.b64 %r468,%r525,%r524; bra $L22; $L25: .loc 1 322 0 ld.u32 %r136,[%frame+24]; .loc 1 198 0 ld.u32 %r531,[%frame+4]; and.b32 %r530,%r531,-1048577; add.u32 %r532,%r136,1075; shl.b32 %r533,%r532,20; or.b32 %r534,%r530,%r533; cvt.u64.u32 %r535,%r534; shl.b64 %r536,%r535,32; ld.u32 %r537,[%frame]; or.b64 %r468,%r537,%r536; bra $L22; $L23: .loc 1 202 0 mov.u64 %r468,9218868437227405312; bra $L22; $L27: .loc 1 208 0 mov.u64 %r468,9223372036854775807; $L22: .loc 1 210 0 and.b32 %r541,%r503,8; setp.ne.u32 %r542,%r541,0; @ %r542 bra $L28; mov.b64 %r470,%r468; bra $L30; $L28: .loc 1 211 0 shr.u64 %r543,%r468,32; cvt.u32.u64 %r545,%r543; or.b32 %r544,%r545,-2147483648; cvt.u64.u32 %r546,%r544; shl.b64 %r547,%r546,32; and.b64 %r548,%r468,4294967295; or.b64 %r468,%r548,%r547; mov.b64 %r470,%r468; bra $L30; $L317: add.u64 %r452,%r458,1; .loc 1 329 0 bra $L29; $L176: .loc 1 310 0 mov.f64 %r470,0d0000000000000000; bra $L30; $L29: .loc 1 329 0 mov.u64 %r458,%r452; st.u64 [%frame+16],%r458; add.u64 %r452,%r458,1; ld.s8 %r457,[%r458]; cvt.u16.u32 %r550,%r457; setp.eq.u16 %r551,%r550,48; @ %r551 bra $L29; .loc 1 330 0 setp.eq.u32 %r552,%r457,0; @ %r552 bra $L178; .loc 1 328 0 mov.u32 %r328,1; bra $L14; $L175: .loc 1 264 0 mov.u32 %r328,0; $L14: .loc 1 335 0 add.u32 %r1117,%r457,-48; setp.gt.u32 %r554,%r1117,9; @ %r554 bra $L31; add.u64 %r357,%r458,1; .loc 1 334 0 mov.u32 %r333,0; mov.u32 %r332,%r333; .loc 1 335 0 mov.u32 %r290,%r333; $L34: .loc 1 336 0 setp.gt.s32 %r555,%r290,8; @ %r555 bra $L32; .loc 1 337 0 shl.b32 %r557,%r332,2; add.u32 %r558,%r557,%r332; add.u32 %r559,%r558,%r558; add.u32 %r332,%r1117,%r559; bra $L33; $L32: .loc 1 339 0 shl.b32 %r562,%r333,2; add.u32 %r563,%r562,%r333; add.u32 %r564,%r563,%r563; add.u32 %r333,%r1117,%r564; $L33: .loc 1 335 0 add.u32 %r290,%r290,1; st.u64 [%frame+16],%r357; ld.s8 %r457,[%r357]; add.u64 %r357,%r357,1; add.u32 %r1117,%r457,-48; setp.le.u32 %r567,%r1117,9; @ %r567 bra $L34; mov.u32 %r322,%r457; bra $L35; $L31: mov.u32 %r322,%r457; .loc 1 334 0 mov.u32 %r333,0; mov.u32 %r332,%r333; .loc 1 335 0 mov.u32 %r290,%r333; $L35: .loc 1 342 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r569,[%value_in]; } .loc 1 341 0 ld.u64 %r570,[%r569]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r570; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r571,[%value_in]; } { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r573,[%value_in]; } ld.u64 %r577,[%frame+16]; ld.u64 %r575,[%r573]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r577; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r575; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r571; call (%value_in),strncmp,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r578,[%value_in]; } setp.ne.u32 %r579,%r578,0; @ %r579 bra $L179; .loc 1 345 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r581,[%value_in]; } ld.u64 %r582,[%r581]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r582; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r583,[%value_in]; } ld.u64 %r584,[%frame+16]; add.u64 %r157,%r584,%r583; st.u64 [%frame+16],%r157; ld.s8 %r322,[%r157]; .loc 1 346 0 setp.ne.u32 %r585,%r290,0; @ %r585 bra $L180; .loc 1 347 0 setp.ne.u32 %r586,%r322,48; @ %r586 bra $L181; add.u64 %r336,%r157,1; .loc 1 264 0 mov.u32 %r345,%r290; $L39: .loc 1 348 0 add.u32 %r345,%r345,1; .loc 1 347 0 st.u64 [%frame+16],%r336; ld.s8 %r322,[%r336]; add.u64 %r336,%r336,1; setp.eq.u32 %r587,%r322,48; @ %r587 bra $L39; bra $L38; $L40: .loc 1 359 0 add.u32 %r356,%r345,1; .loc 1 360 0 mov.u32 %r192,%r613; ld.u64 %r358,[%frame+16]; setp.eq.u32 %r588,%r613,0; @ %r588 bra $L182; .loc 1 361 0 add.u32 %r327,%r327,%r356; .loc 1 362 0 setp.eq.u32 %r589,%r356,1; @ %r589 bra $L42; mov.u32 %r445,%r293; add.u32 %r441,%r345,%r445; $L45: .loc 1 363 0 setp.gt.s32 %r590,%r445,8; @ %r590 bra $L43; .loc 1 364 0 shl.b32 %r592,%r332,2; add.u32 %r593,%r592,%r332; add.u32 %r332,%r593,%r593; add.u32 %r1119,%r445,1; bra $L44; $L43: .loc 1 365 0 add.u32 %r1119,%r445,1; setp.gt.s32 %r596,%r1119,16; @ %r596 bra $L44; .loc 1 366 0 shl.b32 %r598,%r333,2; add.u32 %r599,%r598,%r333; add.u32 %r333,%r599,%r599; $L44: mov.u32 %r445,%r1119; .loc 1 362 0 setp.ne.u32 %r601,%r441,%r1119; @ %r601 bra $L45; mov.u32 %r416,%r441; add.u32 %r293,%r416,1; bra $L46; $L42: mov.u32 %r416,%r293; add.u32 %r293,%r293,1; $L46: .loc 1 367 0 setp.gt.s32 %r602,%r416,8; @ %r602 bra $L47; $L171: .loc 1 368 0 shl.b32 %r604,%r332,2; add.u32 %r605,%r604,%r332; add.u32 %r606,%r605,%r605; add.u32 %r332,%r192,%r606; .loc 1 371 0 mov.u32 %r345,%r578; bra $L41; $L47: mov.u32 %r345,%r578; .loc 1 369 0 setp.gt.s32 %r607,%r293,16; @ %r607 bra $L41; .loc 1 370 0 shl.b32 %r609,%r333,2; add.u32 %r610,%r609,%r333; add.u32 %r611,%r610,%r610; add.u32 %r333,%r613,%r611; .loc 1 371 0 mov.u32 %r345,%r578; bra $L41; $L182: .loc 1 359 0 mov.u32 %r345,%r356; $L41: .loc 1 357 0 add.u64 %r612,%r358,1; st.u64 [%frame+16],%r612; ld.s8 %r322,[%r358+1]; bra $L37; $L180: .loc 1 264 0 mov.u32 %r345,%r578; .loc 1 335 0 mov.u32 %r327,%r578; mov.u32 %r293,%r290; $L37: .loc 1 357 0 add.u32 %r613,%r322,-48; setp.le.u32 %r614,%r613,9; @ %r614 bra $L40; .loc 1 344 0 mov.u32 %r323,1; .loc 1 375 0 bra $L36; $L179: mov.u32 %r293,%r290; .loc 1 264 0 mov.u32 %r345,0; .loc 1 335 0 mov.u32 %r327,%r345; .loc 1 264 0 mov.u32 %r323,%r345; $L36: .loc 1 377 0 and.b32 %r615,%r322,-33; setp.ne.u32 %r616,%r615,69; @ %r616 bra $L183; .loc 1 378 0 or.b32 %r617,%r293,%r345; or.b32 %r618,%r617,%r328; setp.eq.u32 %r619,%r618,0; @ %r619 bra $L10; .loc 1 381 0 ld.u64 %r472,[%frame+16]; .loc 1 383 0 add.u64 %r620,%r472,1; st.u64 [%frame+16],%r620; ld.s8 %r181,[%r472+1]; cvt.u16.u32 %r621,%r181; setp.eq.u16 %r622,%r621,43; @ %r622 bra $L184; setp.eq.u16 %r624,%r621,45; @ %r624 bra $L52; mov.u32 %r322,%r181; .loc 1 382 0 mov.u32 %r325,0; bra $L53; $L52: .loc 1 385 0 mov.u32 %r325,1; bra $L51; $L184: .loc 1 382 0 mov.u32 %r325,0; $L51: .loc 1 387 0 add.u64 %r625,%r472,2; st.u64 [%frame+16],%r625; ld.s8 %r322,[%r472+2]; $L53: .loc 1 389 0 add.u32 %r626,%r322,-48; setp.gt.u32 %r627,%r626,9; @ %r627 bra $L54; .loc 1 390 0 setp.ne.u32 %r628,%r322,48; @ %r628 bra $L55; ld.u64 %r629,[%frame+16]; add.u64 %r129,%r629,1; $L56: .loc 1 391 0 st.u64 [%frame+16],%r129; ld.s8 %r322,[%r129]; add.u64 %r129,%r129,1; .loc 1 390 0 setp.eq.u32 %r630,%r322,48; @ %r630 bra $L56; $L55: .loc 1 392 0 add.u32 %r631,%r322,-49; setp.gt.u32 %r632,%r631,8; @ %r632 bra $L185; .loc 1 393 0 add.u32 %r361,%r322,-48; .loc 1 394 0 ld.u64 %r360,[%frame+16]; .loc 1 395 0 add.u64 %r193,%r360,1; st.u64 [%frame+16],%r193; ld.s8 %r322,[%r360+1]; add.u32 %r633,%r322,-48; setp.gt.u32 %r634,%r633,9; @ %r634 bra $L57; add.u64 %r127,%r360,2; $L58: .loc 1 396 0 shl.b32 %r636,%r361,2; add.u32 %r637,%r636,%r361; add.u32 %r638,%r637,%r637; add.u32 %r191,%r638,%r322; add.u32 %r361,%r191,-48; .loc 1 395 0 mov.u64 %r193,%r127; st.u64 [%frame+16],%r127; ld.s8 %r322,[%r127]; add.u64 %r127,%r127,1; add.u32 %r639,%r322,-48; setp.le.u32 %r640,%r639,9; @ %r640 bra $L58; $L57: .loc 1 397 0 sub.u64 %r641,%r193,%r360; set.u32.gt.s64 %r643,%r641,8; neg.s32 %r644,%r643; set.u32.gt.s32 %r646,%r361,19999; neg.s32 %r647,%r646; cvt.u16.u32 %r649,%r644; cvt.u16.u32 %r650,%r647; or.b16 %r648,%r649,%r650; cvt.u32.u16 %r651,%r648; cvt.u16.u8 %r652,%r651; setp.eq.u16 %r653,%r652,0; .loc 1 401 0 selp.u32 %r361,%r361,19999,%r653; .loc 1 404 0 setp.eq.u32 %r654,%r325,0; @ %r654 bra $L48; .loc 1 405 0 neg.s32 %r361,%r361; bra $L48; $L54: .loc 1 411 0 st.u64 [%frame+16],%r472; .loc 1 376 0 mov.u32 %r361,0; bra $L48; $L183: mov.u32 %r361,0; bra $L48; $L185: .loc 1 408 0 mov.u32 %r361,0; $L48: .loc 1 413 0 setp.ne.u32 %r655,%r293,0; @ %r655 bra $L60; .loc 1 414 0 or.b32 %r656,%r345,%r328; setp.eq.u32 %r657,%r656,0; @ %r657 bra $L61; mov.f64 %r470,0d0000000000000000; bra $L30; $L61: .loc 1 420 0 setp.ne.u32 %r658,%r323,0; @ %r658 bra $L10; .loc 1 421 0 setp.eq.u32 %r659,%r322,78; @ %r659 bra $L62; setp.gt.s32 %r660,%r322,78; @ %r660 bra $L63; setp.eq.u32 %r661,%r322,73; @ %r661 bra $L64; bra $L10; $L63: setp.eq.u32 %r662,%r322,105; @ %r662 bra $L64; setp.eq.u32 %r663,%r322,110; @ %r663 bra $L62; bra $L10; $L64: .loc 1 222 0 ld.u64 %r398,[%frame+16]; cvta.const.u64 %r344,$LC0+1; .loc 1 224 0 mov.u32 %r401,110; bra $L66; $L186: mov.u64 %r398,%r390; $L66: .loc 1 225 0 add.u64 %r390,%r398,1; ld.s8 %r400,[%r390]; add.u32 %r664,%r400,-65; setp.gt.u32 %r665,%r664,25; @ %r665 bra $L65; .loc 1 226 0 add.u32 %r400,%r400,32; $L65: .loc 1 227 0 setp.ne.u32 %r666,%r400,%r401; @ %r666 bra $L10; .loc 1 224 0 ld.s8 %r401,[%r344]; add.u64 %r344,%r344,1; setp.ne.u32 %r667,%r401,0; @ %r667 bra $L186; .loc 1 425 0 st.u64 [%frame+16],%r390; cvta.const.u64 %r375,$LC1+1; .loc 1 224 0 mov.u32 %r406,105; bra $L69; $L187: mov.u64 %r390,%r374; $L69: .loc 1 225 0 add.u64 %r374,%r390,1; ld.s8 %r405,[%r374]; add.u32 %r668,%r405,-65; setp.gt.u32 %r669,%r668,25; @ %r669 bra $L67; .loc 1 226 0 add.u32 %r405,%r405,32; $L67: .loc 1 227 0 setp.ne.u32 %r670,%r405,%r406; @ %r670 bra $L68; .loc 1 224 0 ld.s8 %r406,[%r375]; add.u64 %r375,%r375,1; setp.ne.u32 %r671,%r406,0; @ %r671 bra $L187; .loc 1 230 0 add.u64 %r672,%r390,2; st.u64 [%frame+16],%r672; bra $L70; $L68: add.u64 %r673,%r398,2; .loc 1 427 0 st.u64 [%frame+16],%r673; $L70: .loc 1 430 0 mov.u64 %r468,9218868437227405312; .loc 1 432 0 bra $L71; $L62: .loc 1 222 0 ld.u64 %r409,[%frame+16]; cvta.const.u64 %r324,$LC2+1; .loc 1 224 0 mov.u32 %r412,97; bra $L73; $L188: mov.u64 %r409,%r289; $L73: .loc 1 225 0 add.u64 %r289,%r409,1; ld.s8 %r411,[%r289]; add.u32 %r674,%r411,-65; setp.gt.u32 %r675,%r674,25; @ %r675 bra $L72; .loc 1 226 0 add.u32 %r411,%r411,32; $L72: .loc 1 227 0 setp.ne.u32 %r676,%r411,%r412; @ %r676 bra $L10; .loc 1 224 0 ld.s8 %r412,[%r324]; add.u64 %r324,%r324,1; setp.ne.u32 %r677,%r412,0; @ %r677 bra $L188; .loc 1 230 0 add.u64 %r678,%r409,2; st.u64 [%frame+16],%r678; .loc 1 439 0 ld.s8 %r680,[%r289+1]; cvt.u16.u32 %r679,%r680; setp.ne.u16 %r681,%r679,40; @ %r681 bra $L74; .loc 1 440 0 add.u64 %r685,%frame,16; cvta.const.u64 %r683,fpinan$2587; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r685; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r683; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%frame; call (%value_in),__hexnan,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r686,[%value_in]; } setp.ne.u32 %r687,%r686,5; @ %r687 bra $L74; .loc 1 442 0 ld.u32 %r689,[%frame+4]; or.b32 %r688,%r689,2146435072; cvt.u64.u32 %r690,%r688; .loc 1 444 0 ld.u32 %r694,[%frame]; shl.b64 %r695,%r690,32; or.b64 %r468,%r695,%r694; bra $L71; $L74: .loc 1 451 0 mov.u64 %r468,-2251799813685248; bra $L71; $L10: .loc 1 1249 0 setp.ne.u64 %r697,%r473,0; @ %r697 bra $L75; mov.f64 %r470,0d0000000000000000; bra $L6; $L75: .loc 1 1250 0 st.u64 [%r473],%r472; mov.f64 %r470,0d0000000000000000; bra $L6; $L71: mov.b64 %r470,%r468; bra $L30; $L60: .loc 1 466 0 sub.u32 %r362,%r361,%r327; .loc 1 473 0 setp.eq.u32 %r698,%r290,0; selp.u32 %r290,%r293,%r290,%r698; .loc 1 475 0 min.s32 %r363,%r293,16; .loc 1 476 0 cvt.rn.f64.u32 %r208,%r332; mov.b64 %r468,%r208; .loc 1 477 0 setp.gt.s32 %r699,%r293,9; @ %r699 bra $L77; $L80: .loc 1 492 0 setp.eq.u32 %r700,%r362,0; @ %r700 bra $L78; bra $L319; $L77: .loc 1 482 0 cvt.rn.f64.u32 %r701,%r333; cvta.const.u64 %r702,__mprec_tens; add.u32 %r703,%r363,-9; cvt.s64.s32 %r704,%r703; shl.b64 %r705,%r704,3; add.u64 %r706,%r702,%r705; ld.f64 %r708,[%r706]; fma.rn.f64 %r707,%r208,%r708,%r701; mov.b64 %r468,%r707; .loc 1 485 0 setp.le.s32 %r709,%r293,15; @ ! %r709 bra $L81; bra $L80; $L78: mov.b64 %r470,%r468; bra $L30; $L319: .loc 1 494 0 setp.le.s32 %r710,%r362,0; @ %r710 bra $L82; .loc 1 495 0 setp.gt.s32 %r711,%r362,22; @ %r711 bra $L83; .loc 1 506 0 cvta.const.u64 %r712,__mprec_tens; cvt.s64.s32 %r713,%r362; shl.b64 %r714,%r713,3; add.u64 %r715,%r712,%r714; ld.f64 %r716,[%r715]; mov.b64 %r717,%r468; mul.f64 %r470,%r716,%r717; .loc 1 507 0 bra $L30; $L83: .loc 1 511 0 mov.u32 %r719,37; sub.u32 %r718,%r719,%r293; setp.lt.s32 %r720,%r718,%r362; @ %r720 bra $L81; .loc 1 510 0 mov.u32 %r721,15; sub.u32 %r364,%r721,%r293; .loc 1 523 0 cvta.const.u64 %r722,__mprec_tens; cvt.s64.s32 %r723,%r364; shl.b64 %r724,%r723,3; add.u64 %r725,%r722,%r724; ld.f64 %r727,[%r725]; mov.b64 %r728,%r468; mul.f64 %r726,%r727,%r728; .loc 1 522 0 sub.u32 %r730,%r362,%r364; .loc 1 536 0 cvt.s64.s32 %r731,%r730; shl.b64 %r732,%r731,3; add.u64 %r733,%r722,%r732; ld.f64 %r734,[%r733]; mul.f64 %r470,%r726,%r734; .loc 1 538 0 bra $L30; $L82: .loc 1 542 0 setp.lt.s32 %r735,%r362,-22; @ %r735 bra $L81; .loc 1 550 0 cvta.const.u64 %r736,__mprec_tens; neg.s32 %r737,%r362; cvt.s64.s32 %r738,%r737; shl.b64 %r739,%r738,3; add.u64 %r740,%r736,%r739; mov.b64 %r741,%r468; ld.f64 %r742,[%r740]; div.rn.f64 %r470,%r741,%r742; .loc 1 551 0 bra $L30; $L81: .loc 1 555 0 sub.u32 %r743,%r293,%r363; add.u32 %r366,%r743,%r362; .loc 1 579 0 setp.le.s32 %r744,%r366,0; @ %r744 bra $L84; .loc 1 580 0 and.b32 %r371,%r366,15; setp.eq.u32 %r745,%r371,0; @ %r745 bra $L85; .loc 1 581 0 cvta.const.u64 %r746,__mprec_tens; cvt.s64.s32 %r747,%r371; shl.b64 %r748,%r747,3; add.u64 %r749,%r746,%r748; ld.f64 %r751,[%r749]; mov.b64 %r752,%r468; mul.f64 %r750,%r751,%r752; mov.b64 %r468,%r750; $L85: .loc 1 582 0 and.b32 %r372,%r366,-16; setp.eq.u32 %r753,%r372,0; @ %r753 bra $L86; .loc 1 583 0 setp.le.s32 %r754,%r372,308; @ %r754 bra $L87; .loc 1 586 0 mov.u32 %r755,34; st.u32 [%r471],%r755; mov.f64 %r470,0d7ff0000000000000; bra $L30; $L92: mov.u32 %r756,34; st.u32 [%r471],%r756; mov.f64 %r470,0d7ff0000000000000; bra $L30; $L87: .loc 1 626 0 shr.s32 %r377,%r372,4; .loc 1 627 0 setp.le.s32 %r757,%r377,1; @ %r757 bra $L190; mov.b64 %r131,%r468; cvta.const.u64 %r1115,__mprec_bigtens; mov.u64 %r298,%r1115; mov.u32 %r146,0; mov.u32 %r376,%r146; .loc 1 629 0 mov.u32 %r1130,1; $L90: .loc 1 628 0 and.b32 %r758,%r377,1; setp.eq.u32 %r759,%r758,0; @ %r759 bra $L89; .loc 1 629 0 ld.f64 %r760,[%r298]; mul.f64 %r131,%r131,%r760; mov.u32 %r146,%r1130; $L89: .loc 1 627 0 add.u32 %r376,%r376,1; shr.s32 %r377,%r377,1; add.u64 %r298,%r298,8; setp.ne.u32 %r761,%r377,1; @ %r761 bra $L90; setp.eq.u32 %r762,%r146,0; @ %r762 bra $L88; mov.b64 %r468,%r131; bra $L88; $L190: mov.u32 %r376,0; cvta.const.u64 %r1115,__mprec_bigtens; $L88: .loc 1 631 0 shr.u64 %r763,%r468,32; cvt.u32.u64 %r765,%r763; add.u32 %r764,%r765,-55574528; cvt.u64.u32 %r766,%r764; shl.b64 %r767,%r766,32; and.b64 %r768,%r468,4294967295; or.b64 %r468,%r768,%r767; .loc 1 632 0 cvt.s64.s32 %r771,%r376; shl.b64 %r772,%r771,3; add.u64 %r773,%r1115,%r772; ld.f64 %r774,[%r773]; mov.b64 %r775,%r468; mul.f64 %r233,%r774,%r775; mov.b64 %r468,%r233; shr.u64 %r777,%r468,32; cvt.u32.u64 %r351,%r777; .loc 1 633 0 and.b32 %r373,%r351,2146435072; setp.gt.u32 %r778,%r373,2090860544; @ %r778 bra $L92; .loc 1 636 0 setp.le.u32 %r779,%r373,2089811968; @ %r779 bra $L93; .loc 1 641 0 mov.u64 %r468,9218868437227405311; .loc 1 564 0 mov.u32 %r316,0; bra $L94; $L93: .loc 1 645 0 add.u32 %r780,%r351,55574528; cvt.u64.u32 %r781,%r780; shl.b64 %r782,%r781,32; and.b64 %r783,%r468,4294967295; or.b64 %r468,%r783,%r782; .loc 1 564 0 mov.u32 %r316,0; bra $L94; $L84: .loc 1 648 0 setp.eq.u32 %r785,%r366,0; @ %r785 bra $L86; .loc 1 649 0 neg.s32 %r367,%r366; .loc 1 650 0 and.b32 %r368,%r367,15; setp.eq.u32 %r786,%r368,0; @ %r786 bra $L95; .loc 1 651 0 cvta.const.u64 %r787,__mprec_tens; cvt.s64.s32 %r788,%r368; shl.b64 %r789,%r788,3; add.u64 %r790,%r787,%r789; mov.b64 %r792,%r468; ld.f64 %r793,[%r790]; div.rn.f64 %r791,%r792,%r793; mov.b64 %r468,%r791; $L95: .loc 1 652 0 shr.s32 %r370,%r367,4; setp.eq.u32 %r794,%r370,0; @ %r794 bra $L86; .loc 1 653 0 setp.gt.s32 %r795,%r370,31; @ %r795 bra $L96; .loc 1 656 0 and.b32 %r316,%r370,16; setp.ne.u32 %r796,%r316,0; @ %r796 bra $L97; .loc 1 658 0 setp.gt.s32 %r797,%r370,0; @ %r797 bra $L98; $L104: .loc 1 564 0 mov.u32 %r316,0; bra $L99; $L97: .loc 1 658 0 setp.le.s32 %r798,%r370,0; @ %r798 bra $L191; .loc 1 657 0 mov.u32 %r316,106; $L98: mov.b64 %r174,%r468; cvta.const.u64 %r454,tinytens; mov.u32 %r415,0; .loc 1 660 0 mov.u32 %r1131,1; $L102: .loc 1 659 0 and.b32 %r799,%r370,1; setp.eq.u32 %r800,%r799,0; @ %r800 bra $L101; .loc 1 660 0 ld.f64 %r801,[%r454]; mul.f64 %r174,%r174,%r801; mov.u32 %r415,%r1131; $L101: .loc 1 658 0 shr.s32 %r370,%r370,1; add.u64 %r454,%r454,8; setp.ne.u32 %r802,%r370,0; @ %r802 bra $L102; setp.eq.u32 %r803,%r415,0; @ %r803 bra $L103; mov.b64 %r468,%r174; $L103: .loc 1 661 0 setp.eq.u32 %r804,%r316,0; @ %r804 bra $L104; bra $L100; $L191: .loc 1 657 0 mov.u32 %r316,106; $L100: .loc 1 661 0 shr.u64 %r1114,%r468,32; cvt.u32.u64 %r240,%r1114; .loc 1 662 0 shr.u32 %r806,%r240,20; and.b32 %r807,%r806,2047; .loc 1 661 0 mov.u32 %r808,107; sub.u32 %r369,%r808,%r807; setp.le.s32 %r809,%r369,0; @ %r809 bra $L99; .loc 1 664 0 setp.le.s32 %r810,%r369,31; @ %r810 bra $L105; .loc 1 666 0 and.b64 %r468,%r468,-4294967296; .loc 1 668 0 setp.le.s32 %r812,%r369,52; @ %r812 bra $L106; .loc 1 669 0 mov.u64 %r468,247697979505377280; bra $L99; $L106: .loc 1 671 0 add.u32 %r815,%r369,-32; mov.u32 %r817,-1; shl.b32 %r816,%r817,%r815; and.b32 %r818,%r816,%r240; cvt.u64.u32 %r819,%r818; shl.b64 %r820,%r819,32; and.b64 %r821,%r468,4294967295; or.b64 %r468,%r821,%r820; bra $L99; $L105: .loc 1 675 0 mov.u32 %r824,-1; shl.b32 %r823,%r824,%r369; cvt.u32.u64 %r826,%r468; and.b32 %r825,%r823,%r826; cvt.u64.u32 %r827,%r825; and.b64 %r828,%r468,-4294967296; or.b64 %r468,%r828,%r827; $L99: .loc 1 689 0 mov.b64 %r830,%r468; setp.neu.f64 %r831,%r830,0d0000000000000000; @ %r831 bra $L94; $L96: .loc 1 693 0 mov.u32 %r832,34; st.u32 [%r471],%r832; mov.f64 %r470,0d0000000000000000; bra $L30; $L86: .loc 1 564 0 mov.u32 %r316,0; $L94: .loc 1 718 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r458; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r290; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r293; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r332; call (%value_in),__s2b,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u64 %r838,[%value_in]; } .loc 1 719 0 setp.eq.u64 %r839,%r838,0; @ %r839 bra $L107; setp.ge.s32 %r841,%r362,0; @ %r841 bra $L108; .loc 1 739 0 neg.s32 %r840,%r362; bra $L109; $L108: mov.u32 %r840,0; $L109: max.s32 %r168,%r362,0; .loc 1 263 0 mov.u64 %r338,0; mov.u64 %r337,%r338; .loc 1 726 0 add.u64 %r1120,%r838,16; .loc 1 727 0 add.u64 %r1121,%frame,24; .loc 1 794 0 setp.eq.u32 %r1122,%r840,0; .loc 1 809 0 setp.gt.s32 %r1123,%r362,0; .loc 1 1187 0 set.u32.eq.u32 %r1124,%r316,0; neg.s32 %r1125,%r1124; .loc 1 1189 0 cvt.u16.u32 %r1126,%r1125; .loc 1 1124 0 set.u32.ne.u32 %r1127,%r316,0; neg.s32 %r1128,%r1127; cvt.u16.u32 %r1129,%r1128; $L167: .loc 1 723 0 ld.u32 %r844,[%r838+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r844; call (%value_in),_Balloc,(%out_arg1,%out_arg2); ld.param.u64 %r845,[%value_in]; } mov.u64 %r335,%r845; .loc 1 724 0 setp.eq.u64 %r846,%r335,0; @ %r846 bra $L110; .loc 1 726 0 ld.s32 %r850,[%r838+20]; add.u64 %r851,%r850,2; shl.b64 %r852,%r851,2; add.u64 %r854,%r335,16; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r854; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1120; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r852; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r855,[%value_in]; } .loc 1 727 0 mov.b64 %r258,%r468; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r258; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1121; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%frame; call (%value_in),__d2b,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r861,[%value_in]; } mov.u64 %r456,%r861; st.u64 [%frame+8],%r456; .loc 1 728 0 setp.eq.u64 %r862,%r456,0; @ %r862 bra $L111; .loc 1 730 0 mov.u32 %r864,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r864; call (%value_in),__i2b,(%out_arg1,%out_arg2); ld.param.u64 %r865,[%value_in]; } mov.u64 %r337,%r865; .loc 1 731 0 setp.ne.u64 %r866,%r337,0; @ %r866 bra $L112; ld.u64 %r456,[%frame+8]; bra $L111; $L112: .loc 1 742 0 ld.u32 %r259,[%frame+24]; setp.lt.s32 %r867,%r259,0; @ %r867 bra $L113; .loc 1 743 0 add.u32 %r318,%r259,%r840; mov.u32 %r320,%r168; bra $L114; $L113: .loc 1 745 0 sub.u32 %r320,%r168,%r259; mov.u32 %r318,%r840; $L114: .loc 1 755 0 ld.u32 %r260,[%frame]; .loc 1 754 0 sub.u32 %r868,%r259,%r316; .loc 1 755 0 add.u32 %r869,%r868,%r260; add.u32 %r381,%r869,-1; .loc 1 756 0 mov.u32 %r870,54; sub.u32 %r326,%r870,%r260; .loc 1 757 0 setp.ge.s32 %r871,%r381,-1022; @ %r871 bra $L192; .loc 1 758 0 mov.u32 %r872,-1022; sub.u32 %r382,%r872,%r381; .loc 1 759 0 sub.u32 %r326,%r326,%r382; .loc 1 760 0 setp.gt.s32 %r873,%r382,31; @ %r873 bra $L116; .loc 1 761 0 mov.u32 %r874,1; shl.b32 %r339,%r874,%r382; .loc 1 753 0 mov.u32 %r340,0; bra $L115; $L116: .loc 1 763 0 mov.u32 %r876,-1054; sub.u32 %r875,%r876,%r381; mov.u32 %r877,1; shl.b32 %r340,%r877,%r875; .loc 1 752 0 mov.u32 %r339,%r877; bra $L115; $L192: .loc 1 753 0 mov.u32 %r340,0; .loc 1 752 0 mov.u32 %r339,1; $L115: .loc 1 781 0 add.u32 %r319,%r318,%r326; .loc 1 782 0 add.u32 %r383,%r320,%r326; .loc 1 784 0 add.u32 %r321,%r316,%r383; min.s32 %r878,%r318,%r319; min.s32 %r170,%r878,%r321; .loc 1 789 0 setp.le.s32 %r879,%r170,0; @ %r879 bra $L117; .loc 1 790 0 sub.u32 %r319,%r319,%r170; .loc 1 791 0 sub.u32 %r321,%r321,%r170; .loc 1 792 0 sub.u32 %r318,%r318,%r170; $L117: .loc 1 794 0 @ %r1122 bra $L118; .loc 1 795 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r865; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r840; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r884,[%value_in]; } mov.u64 %r337,%r884; .loc 1 796 0 setp.ne.u64 %r885,%r337,0; @ %r885 bra $L119; ld.u64 %r456,[%frame+8]; bra $L111; $L119: .loc 1 798 0 ld.u64 %r889,[%frame+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r889; call (%value_in),__multiply,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r890,[%value_in]; } .loc 1 799 0 setp.ne.u64 %r891,%r890,0; @ %r891 bra $L120; ld.u64 %r456,[%frame+8]; bra $L111; $L120: .loc 1 801 0 ld.u64 %r894,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r894; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 802 0 st.u64 [%frame+8],%r890; $L118: .loc 1 804 0 setp.gt.s32 %r895,%r319,0; @ %r895 bra $L121; $L124: .loc 1 809 0 @ ! %r1123 bra $L123; bra $L122; $L121: .loc 1 805 0 ld.u64 %r900,[%frame+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r900; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r319; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r901,[%value_in]; } mov.u64 %r456,%r901; st.u64 [%frame+8],%r456; .loc 1 806 0 setp.eq.u64 %r902,%r456,0; @ ! %r902 bra $L124; .loc 1 584 0 bra $L111; $L122: .loc 1 810 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r845; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r168; call (%value_in),__pow5mult,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r906,[%value_in]; } mov.u64 %r335,%r906; .loc 1 811 0 setp.ne.u64 %r907,%r335,0; @ %r907 bra $L123; ld.u64 %r456,[%frame+8]; bra $L111; $L123: .loc 1 814 0 setp.le.s32 %r908,%r321,0; @ %r908 bra $L125; .loc 1 815 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r335; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r321; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r912,[%value_in]; } mov.u64 %r335,%r912; .loc 1 816 0 setp.ne.u64 %r913,%r335,0; @ %r913 bra $L125; ld.u64 %r456,[%frame+8]; bra $L111; $L125: .loc 1 819 0 setp.le.s32 %r914,%r318,0; @ %r914 bra $L126; .loc 1 820 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r318; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r918,[%value_in]; } mov.u64 %r337,%r918; .loc 1 821 0 setp.ne.u64 %r919,%r337,0; @ %r919 bra $L126; ld.u64 %r456,[%frame+8]; bra $L111; $L126: .loc 1 824 0 ld.u64 %r923,[%frame+8]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r923; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r335; call (%value_in),__mdiff,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r924,[%value_in]; } mov.u64 %r338,%r924; .loc 1 825 0 setp.ne.u64 %r925,%r338,0; @ %r925 bra $L127; ld.u64 %r456,[%frame+8]; bra $L111; $L127: .loc 1 827 0 ld.u32 %r385,[%r924+16]; .loc 1 828 0 mov.u32 %r926,0; st.u32 [%r924+16],%r926; .loc 1 829 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r924; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r929,[%value_in]; } .loc 1 923 0 setp.ge.s32 %r930,%r929,0; @ %r930 bra $L128; .loc 1 927 0 setp.ne.u32 %r931,%r385,0; @ %r931 bra $L129; mov.b64 %r933,%r258; and.b64 %r932,%r933,4503599627370495; setp.ne.u64 %r934,%r932,0; @ %r934 bra $L129; .loc 1 930 0 shr.u64 %r1114,%r468,32; cvt.u32.u64 %r937,%r1114; and.b32 %r936,%r937,2146435072; setp.le.u32 %r938,%r936,112197632; @ %r938 bra $L129; .loc 1 942 0 ld.u32 %r939,[%r924+24]; setp.ne.u32 %r940,%r939,0; @ %r940 bra $L130; ld.u32 %r941,[%r924+20]; setp.le.s32 %r942,%r941,1; @ %r942 bra $L129; $L130: .loc 1 949 0 mov.u32 %r945,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r924; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r945; call (%value_in),__lshift,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r946,[%value_in]; } mov.u64 %r338,%r946; .loc 1 950 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r338; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call (%value_in),__mcmp,(%out_arg1,%out_arg2); ld.param.u32 %r949,[%value_in]; } setp.gt.s32 %r950,%r949,0; @ %r950 bra $L131; bra $L129; $L128: .loc 1 954 0 setp.ne.u32 %r951,%r929,0; @ %r951 bra $L132; .loc 1 956 0 setp.eq.u32 %r1118,%r385,0; @ %r1118 bra $L133; .loc 1 957 0 shr.u64 %r953,%r468,32; cvt.u32.u64 %r273,%r953; and.b32 %r954,%r273,1048575; setp.ne.u32 %r955,%r954,1048575; @ %r955 bra $L134; .loc 1 958 0 cvt.u32.u64 %r275,%r468; .loc 1 961 0 setp.eq.u32 %r956,%r316,0; @ %r956 bra $L193; .loc 1 960 0 and.b32 %r394,%r273,2146435072; setp.gt.u32 %r957,%r394,111149056; @ %r957 bra $L194; .loc 1 961 0 shr.u32 %r958,%r394,20; mov.u32 %r960,107; sub.u32 %r959,%r960,%r958; mov.u32 %r961,-1; shl.b32 %r341,%r961,%r959; bra $L135; $L193: mov.u32 %r341,-1; bra $L135; $L194: mov.u32 %r341,-1; $L135: .loc 1 958 0 setp.ne.u32 %r962,%r275,%r341; @ %r962 bra $L134; .loc 1 965 0 mov.b64 %r963,%r258; setp.ne.u64 %r964,%r963,9218868437227405311; @ %r964 bra $L136; ld.u64 %r456,[%frame+8]; bra $L111; $L136: .loc 1 967 0 and.b32 %r965,%r273,2146435072; .loc 1 968 0 add.u32 %r966,%r965,1048576; .loc 1 967 0 cvt.u64.u32 %r967,%r966; .loc 1 974 0 shl.b64 %r468,%r967,32; mov.b64 %r258,%r468; .loc 1 979 0 bra $L129; $L133: .loc 1 982 0 mov.b64 %r973,%r258; and.b64 %r972,%r973,4503599627370495; setp.ne.u64 %r974,%r972,0; @ %r974 bra $L134; shr.u64 %r1114,%r468,32; $L131: cvt.u32.u64 %r446,%r1114; .loc 1 1000 0 setp.eq.u32 %r976,%r316,0; @ ! %r976 bra $L320; and.b32 %r1116,%r446,2146435072; bra $L137; $L320: .loc 1 1001 0 and.b32 %r1116,%r446,2146435072; .loc 1 1002 0 setp.gt.s32 %r977,%r1116,112197632; @ %r977 bra $L137; .loc 1 1003 0 setp.gt.s32 %r978,%r1116,57671680; @ %r978 bra $L138; bra $L139; $L137: .loc 1 1012 0 add.u32 %r980,%r1116,-1048576; .loc 1 1014 0 or.b32 %r981,%r980,1048575; cvt.u64.u32 %r982,%r981; shl.b64 %r983,%r982,32; .loc 1 1016 0 or.b64 %r468,%r983,4294967295; mov.b64 %r258,%r468; .loc 1 1021 0 bra $L129; $L134: .loc 1 1026 0 setp.eq.u32 %r987,%r340,0; @ %r987 bra $L140; .loc 1 1027 0 shr.u64 %r988,%r468,32; cvt.u32.u64 %r990,%r988; and.b32 %r989,%r340,%r990; setp.eq.u32 %r991,%r989,0; @ %r991 bra $L129; bra $L141; $L140: .loc 1 1030 0 cvt.u32.u64 %r993,%r468; and.b32 %r992,%r339,%r993; setp.eq.u32 %r994,%r992,0; @ %r994 bra $L129; $L141: .loc 1 1037 0 @ %r1118 bra $L142; .loc 1 1039 0 st.u64 [%frame+32],%r468; add.u64 %r998,%frame,32; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r998; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r316; call (%value_in),sulp,(%out_arg1,%out_arg2); ld.param.f64 %r999,[%value_in]; } add.f64 %r258,%r258,%r999; mov.b64 %r468,%r258; bra $L129; $L142: .loc 1 1046 0 st.u64 [%frame+32],%r468; add.u64 %r1002,%frame,32; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r1002; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r316; call (%value_in),sulp,(%out_arg1,%out_arg2); ld.param.f64 %r1003,[%value_in]; } sub.f64 %r258,%r258,%r1003; mov.b64 %r468,%r258; .loc 1 1051 0 setp.eq.f64 %r1004,%r258,0d0000000000000000; @ %r1004 bra $L139; bra $L129; $L132: .loc 1 1061 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r924; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call (%value_in),__ratio,(%out_arg1,%out_arg2); ld.param.f64 %r1007,[%value_in]; } setp.le.f64 %r1008,%r1007,0d4000000000000000; @ ! %r1008 bra $L321; .loc 1 1062 0 setp.eq.u32 %r1009,%r385,0; @ %r1009 bra $L145; .loc 1 1063 0 mov.u64 %r467,4607182418800017408; mov.f64 %r331,0d3ff0000000000000; bra $L146; $L145: mov.b64 %r354,%r258; .loc 1 1064 0 and.b64 %r1010,%r354,4503599627370495; setp.eq.u64 %r1011,%r1010,0; @ %r1011 bra $L147; .loc 1 1066 0 setp.eq.u64 %r1012,%r354,1; @ %r1012 bra $L139; .loc 1 1070 0 mov.u64 %r467,-4616189618054758400; .loc 1 1069 0 mov.f64 %r331,0d3ff0000000000000; bra $L146; $L147: .loc 1 1076 0 setp.lt.f64 %r1013,%r1007,0d3ff0000000000000; @ %r1013 bra $L195; .loc 1 1079 0 mul.f64 %r331,%r1007,0d3fe0000000000000; neg.f64 %r447,%r331; bra $L148; $L195: mov.f64 %r447,0dbfe0000000000000; .loc 1 1077 0 mov.f64 %r331,0d3fe0000000000000; $L148: .loc 1 1080 0 mov.b64 %r467,%r447; bra $L146; $L321: .loc 1 1084 0 mul.f64 %r331,%r1007,0d3fe0000000000000; .loc 1 1085 0 setp.ne.u32 %r1014,%r385,0; @ %r1014 bra $L196; neg.f64 %r342,%r331; bra $L149; $L196: mov.f64 %r342,%r331; $L149: mov.b64 %r467,%r342; $L146: .loc 1 1100 0 shr.u64 %r1015,%r468,32; cvt.u32.u64 %r292,%r1015; and.b32 %r388,%r292,2146435072; .loc 1 1104 0 setp.ne.u32 %r1016,%r388,2145386496; @ %r1016 bra $L150; .loc 1 1106 0 add.u32 %r1017,%r292,-55574528; cvt.u64.u32 %r1018,%r1017; shl.b64 %r1019,%r1018,32; and.b64 %r1020,%r468,4294967295; or.b64 %r468,%r1020,%r1019; .loc 1 1107 0 mov.b64 %r295,%r467; mov.b64 %r296,%r468; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r296; call (%value_in),__ulp,(%out_arg1); ld.param.f64 %r1023,[%value_in]; } .loc 1 1108 0 fma.rn.f64 %r299,%r295,%r1023,%r296; mov.b64 %r468,%r299; shr.u64 %r1025,%r468,32; cvt.u32.u64 %r355,%r1025; .loc 1 1109 0 and.b32 %r1026,%r355,2146435072; setp.le.u32 %r1027,%r1026,2090860543; @ %r1027 bra $L151; .loc 1 1111 0 mov.b64 %r1028,%r258; setp.ne.u64 %r1029,%r1028,9218868437227405311; @ %r1029 bra $L152; ld.u64 %r456,[%frame+8]; bra $L111; $L152: .loc 1 1115 0 mov.u64 %r468,9218868437227405311; .loc 1 1117 0 bra $L153; $L151: .loc 1 1120 0 add.u32 %r455,%r355,55574528; cvt.u64.u32 %r1030,%r455; shl.b64 %r1031,%r1030,32; and.b64 %r1032,%r468,4294967295; or.b64 %r468,%r1032,%r1031; bra $L154; $L150: .loc 1 1124 0 set.u32.le.u32 %r1038,%r388,111149056; neg.s32 %r1039,%r1038; cvt.u16.u32 %r1042,%r1039; and.b16 %r1040,%r1129,%r1042; cvt.u32.u16 %r1043,%r1040; cvt.u16.u8 %r1044,%r1043; setp.eq.u16 %r1045,%r1044,0; @ %r1045 bra $L155; .loc 1 1125 0 setp.le.f64 %r1046,%r331,0d41dfffffffc00000; @ ! %r1046 bra $L156; .loc 1 1126 0 cvt.rzi.u32.f64 %r389,%r331; setp.eq.u32 %r1047,%r389,0; @ %r1047 bra $L197; cvt.rn.f64.u32 %r331,%r389; bra $L158; $L197: mov.f64 %r331,0d3ff0000000000000; $L158: .loc 1 1129 0 setp.ne.u32 %r1048,%r385,0; @ %r1048 bra $L198; neg.f64 %r343,%r331; bra $L159; $L198: mov.f64 %r343,%r331; $L159: mov.b64 %r467,%r343; $L156: .loc 1 1131 0 shr.u64 %r1049,%r467,32; cvt.u32.u64 %r1051,%r1049; add.u32 %r1050,%r1051,112197632; sub.u32 %r1052,%r1050,%r388; cvt.u64.u32 %r1053,%r1052; shl.b64 %r1054,%r1053,32; and.b64 %r1055,%r467,4294967295; or.b64 %r467,%r1055,%r1054; $L155: .loc 1 1133 0 mov.b64 %r306,%r467; { .param .f64 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r258; call (%value_in),__ulp,(%out_arg1); ld.param.f64 %r1058,[%value_in]; } .loc 1 1134 0 fma.rn.f64 %r1059,%r306,%r1058,%r258; mov.b64 %r468,%r1059; shr.u64 %r1114,%r468,32; cvt.u32.u64 %r455,%r1114; $L154: .loc 1 1184 0 and.b32 %r1061,%r455,2146435072; .loc 1 1189 0 set.u32.eq.u32 %r1063,%r1061,%r388; neg.s32 %r1064,%r1063; cvt.u16.u32 %r1069,%r1064; and.b16 %r1068,%r1069,%r1126; cvt.u32.u16 %r1071,%r1068; cvt.u16.u8 %r1072,%r1071; setp.eq.u16 %r1073,%r1072,0; @ %r1073 bra $L153; .loc 1 1191 0 cvt.rzi.s32.f64 %r1074,%r331; .loc 1 1192 0 cvt.rn.f64.s32 %r309,%r1074; sub.f64 %r393,%r331,%r309; .loc 1 1194 0 setp.ne.u32 %r1075,%r385,0; @ %r1075 bra $L160; and.b64 %r1076,%r468,4503599627370495; setp.eq.u64 %r1077,%r1076,0; @ %r1077 bra $L161; $L160: .loc 1 1195 0 setp.lt.f64 %r1078,%r393,0d3fdfffff94a03595; @ ! %r1078 bra $L322; ld.u64 %r456,[%frame+8]; bra $L164; $L322: setp.gt.f64 %r1079,%r393,0d3fe0000035afe535; @ ! %r1079 bra $L153; ld.u64 %r456,[%frame+8]; bra $L164; $L161: .loc 1 1198 0 setp.lt.f64 %r1080,%r393,0d3fcfffff94a03595; @ ! %r1080 bra $L153; ld.u64 %r456,[%frame+8]; bra $L164; $L153: .loc 1 1203 0 ld.u64 %r1083,[%frame+8]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r1083; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1204 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r335; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1205 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1206 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r924; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 723 0 bra $L167; $L129: .loc 1 1222 0 setp.ne.u32 %r1090,%r316,0; @ %r1090 bra $L138; ld.u64 %r456,[%frame+8]; bra $L164; $L138: .loc 1 1227 0 mul.f64 %r314,%r258,0d3950000000000000; mov.b64 %r468,%r314; .loc 1 1230 0 setp.eq.u64 %r1093,%r468,0; @ %r1093 bra $L168; ld.u64 %r456,[%frame+8]; bra $L164; $L168: .loc 1 1231 0 mov.u32 %r1094,34; st.u32 [%r471],%r1094; ld.u64 %r456,[%frame+8]; $L164: .loc 1 1243 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r456; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1244 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r335; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1245 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r337; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1246 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r838; call _Bfree,(%out_arg1,%out_arg2); } .loc 1 1247 0 { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r471; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r338; call _Bfree,(%out_arg1,%out_arg2); } mov.b64 %r470,%r468; bra $L30; $L178: .loc 1 1248 0 mov.f64 %r470,0d0000000000000000; $L30: .loc 1 1249 0 setp.eq.u64 %r1105,%r473,0; @ %r1105 bra $L169; .loc 1 1250 0 ld.u64 %r1106,[%frame+16]; st.u64 [%r473],%r1106; $L169: .loc 1 1251 0 setp.eq.u32 %r1107,%r329,0; @ %r1107 bra $L6; neg.f64 %r470,%r470; bra $L6; $L177: .loc 1 1249 0 mov.f64 %r470,0d0000000000000000; .loc 1 1251 0 bra $L6; $L107: .loc 1 586 0 mov.u32 %r1109,34; st.u32 [%r471],%r1109; mov.f64 %r470,0d7ff0000000000000; bra $L30; $L110: ld.u64 %r456,[%frame+8]; $L111: mov.u32 %r1110,34; st.u32 [%r471],%r1110; .loc 1 608 0 mov.u64 %r468,9218868437227405312; bra $L164; $L139: .loc 1 691 0 mov.u64 %r468,0; .loc 1 693 0 mov.u32 %r1111,34; st.u32 [%r471],%r1111; ld.u64 %r456,[%frame+8]; bra $L164; $L172: .loc 1 350 0 ld.u64 %r458,[%frame+16]; .loc 1 360 0 add.u32 %r192,%r322,-48; .loc 1 361 0 add.u32 %r327,%r345,1; .loc 1 350 0 mov.u64 %r358,%r458; .loc 1 361 0 mov.u32 %r293,1; bra $L171; $L181: .loc 1 264 0 mov.u32 %r345,%r290; $L38: .loc 1 349 0 add.u32 %r1112,%r322,-49; setp.le.u32 %r1113,%r1112,8; @ %r1113 bra $L172; .loc 1 335 0 mov.u32 %r327,%r290; .loc 1 349 0 mov.u32 %r293,%r290; .loc 1 344 0 mov.u32 %r323,1; bra $L36; $L6: .loc 1 1252 0 mov.f64 %value,%r470; st.shared.u64 [%sspslot],%sspprev; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtod .visible .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r29; .reg .f64 %r30; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; .loc 1 1260 0 ld.global.u64 %r29,[_impure_ptr]; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r29; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; call (%value_in),_strtod_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r30,[%value_in]; } .loc 1 1261 0 mov.f64 %value,%r30; st.param.f64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtof .visible .func (.param .f32 %value_out) strtof (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .f32 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r31; .reg .f64 %r32; .reg .u32 %r34; .reg .pred %r35; .reg .u64 %r36; .reg .f32 %r37; mov.u64 %r26,%ar0; mov.u64 %r27,%ar1; .loc 1 1268 0 ld.global.u64 %r31,[_impure_ptr]; { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; call (%value_in),_strtod_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.f64 %r32,[%value_in]; } .loc 1 1269 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r32; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r34,[%value_in]; } setp.ne.u32 %r35,%r34,0; @ %r35 bra $L325; .loc 1 1270 0 mov.u64 %r36,0; { .param .f32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r36; call (%value_in),nanf,(%out_arg1); ld.param.f32 %r37,[%value_in]; } mov.f32 %r25,%r37; bra $L324; $L325: .loc 1 1271 0 cvt.rn.f32.f64 %r25,%r32; $L324: .loc 1 1272 0 mov.f32 %value,%r25; st.param.f32 [%value_out],%value; ret; } lib_a-strtok.o/ 0 0 0 644 1402 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtok .visible .func (.param .u64 %value_out) strtok (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/string/strtok.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: __strtok_r .extern .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strtok .visible .func (.param .u64 %value_out) strtok (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r25; .reg .u64 %r26; .reg .u32 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; .loc 1 103 0 ld.global.u64 %r32,[_impure_ptr]; add.u64 %r31,%r32,152; mov.u32 %r30,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r26; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r31; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r30; call (%value_in),__strtok_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r33,[%value_in]; } .loc 1 104 0 mov.u64 %value,%r33; st.param.u64 [%value_out],%value; ret; } /752 0 0 0 644 3638 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __strtok_r .visible .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../../newlib/libc/string/strtok_r.c" // BEGIN GLOBAL FUNCTION DECL: strtok_r .visible .func (.param .u64 %value_out) strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DEF: __strtok_r .visible .func (.param .u64 %value_out) __strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u64 %r49; .reg .u32 %r52; .reg .u32 %r53; .reg .u64 %r54; .reg .u64 %r55; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u64 %r61; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .u32 %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .u32 %r74; .reg .pred %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u16 %r78; .reg .u16 %r79; .reg .pred %r80; .reg .pred %r81; .reg .u32 %r82; .reg .pred %r83; .reg .pred %r85; mov.u64 %r66,%ar0; mov.u64 %r67,%ar1; mov.u64 %r68,%ar2; mov.u32 %r69,%ar3; .loc 1 44 0 setp.ne.u64 %r70,%r66,0; @ %r70 bra $L2; ld.u64 %r66,[%r68]; setp.eq.u64 %r71,%r66,0; @ %r71 bra $L11; $L2: mov.u64 %r56,%r66; .loc 1 54 0 setp.ne.u32 %r85,%r69,0; $L5: mov.u64 %r65,%r56; add.u64 %r56,%r56,1; .loc 1 51 0 ld.s8 %r57,[%r65]; .loc 1 52 0 mov.u64 %r61,%r67; bra $L4; $L6: add.u64 %r61,%r61,1; .loc 1 53 0 setp.ne.u32 %r72,%r57,%r58; @ %r72 bra $L4; .loc 1 54 0 @ %r85 bra $L5; .loc 1 58 0 st.u64 [%r68],%r56; .loc 1 59 0 mov.u32 %r74,0; st.u8 [%r65],%r74; .loc 1 60 0 bra $L1; $L4: .loc 1 52 0 ld.s8 %r58,[%r61]; setp.ne.u32 %r75,%r58,0; @ %r75 bra $L6; .loc 1 65 0 setp.ne.u32 %r76,%r57,0; @ %r76 bra $L7; .loc 1 66 0 mov.u64 %r77,0; st.u64 [%r68],%r77; .loc 1 67 0 mov.u64 %r65,%r77; bra $L1; $L7: mov.u64 %r54,%r56; add.u64 %r56,%r56,1; mov.u64 %r55,%r56; .loc 1 76 0 ld.s8 %r52,[%r54]; mov.u64 %r49,%r67; .loc 1 79 0 cvt.u16.u32 %r78,%r52; $L10: ld.s8 %r53,[%r49]; cvt.u16.u32 %r79,%r53; setp.ne.u16 %r80,%r78,%r79; @ %r80 bra $L8; .loc 1 80 0 setp.eq.u32 %r81,%r53,0; @ %r81 bra $L12; .loc 1 83 0 mov.u32 %r82,0; st.u8 [%r54],%r82; bra $L9; $L12: .loc 1 81 0 mov.u64 %r55,0; $L9: .loc 1 84 0 st.u64 [%r68],%r55; .loc 1 85 0 bra $L1; $L8: add.u64 %r49,%r49,1; .loc 1 87 0 setp.ne.u32 %r83,%r53,0; @ %r83 bra $L10; bra $L7; $L11: .loc 1 45 0 mov.u64 %r65,%r66; $L1: .loc 1 90 0 mov.u64 %value,%r65; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtok_r .visible .func (.param .u64 %value_out) strtok_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r29; .reg .u64 %r30; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; mov.u64 %r25,%ar2; .loc 1 98 0 mov.u32 %r29,1; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r29; call (%value_in),__strtok_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r30,[%value_in]; } .loc 1 99 0 mov.u64 %value,%r30; st.param.u64 [%value_out],%value; ret; } lib_a-strtol.o/ 0 0 0 644 7501 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtol_r .visible .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../../newlib/libc/stdlib/strtol.c" // BEGIN GLOBAL FUNCTION DECL: strtol .visible .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtol_r .visible .func (.param .u64 %value_out) _strtol_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r81; .reg .u32 %r82; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u16 %r127; .reg .u16 %r128; .reg .u32 %r129; .reg .u16 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .u16 %r133; .reg .u32 %r135; .reg .pred %r136; .reg .u16 %r137; .reg .pred %r138; .reg .pred %r139; .reg .u32 %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u16 %r146; .reg .u16 %r147; .reg .u16 %r148; .reg .u32 %r149; .reg .u16 %r150; .reg .pred %r151; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r156; .reg .u32 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u16 %r160; .reg .u32 %r161; .reg .u16 %r162; .reg .pred %r163; .reg .u64 %r164; .reg .pred %r165; .reg .u32 %r166; .reg .pred %r167; .reg .pred %r169; .reg .pred %r170; .reg .pred %r172; .reg .u32 %r173; .reg .pred %r174; .reg .pred %r175; .reg .u32 %r177; .reg .u32 %r178; .reg .u16 %r179; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 153 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r85,%r95; $L2: mov.u64 %r75,%r85; add.u64 %r62,%r85,1; mov.u64 %r85,%r62; .loc 1 152 0 ld.u8 %r49,[%r75]; .loc 1 153 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r179,[%r100+1]; mov.u16 %r104,%r179; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 154 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 156 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 155 0 mov.u32 %r91,1; bra $L4; $L3: .loc 1 157 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 152 0 mov.u32 %r78,%r49; .loc 1 144 0 mov.u32 %r91,0; bra $L4; $L5: .loc 1 158 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 144 0 mov.u32 %r91,0; bra $L4; $L21: .loc 1 159 0 setp.ne.u32 %r113,%r78,48; @ %r113 bra $L6; .loc 1 160 0 ld.u8 %r179,[%r62]; mov.u16 %r116,%r179; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 161 0 ld.u8 %r78,[%r62+1]; .loc 1 162 0 add.u64 %r62,%r62,2; mov.u64 %r90,16; .loc 1 163 0 cvt.u32.u64 %r97,%r90; bra $L8; $L7: .loc 1 165 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L23; cvt.s64.s32 %r90,%r97; bra $L8; $L41: cvt.s64.s32 %r90,%r97; bra $L8; $L23: mov.u64 %r90,8; .loc 1 166 0 cvt.u32.u64 %r97,%r90; bra $L8; $L28: .loc 1 165 0 mov.u64 %r90,10; .loc 1 166 0 cvt.u32.u64 %r97,%r90; $L8: .loc 1 185 0 setp.eq.u32 %r175,%r91,0; selp.u64 %r81,9223372036854775807,-9223372036854775808,%r175; .loc 1 186 0 rem.u64 %r123,%r81,%r90; cvt.u32.u64 %r86,%r123; .loc 1 187 0 div.u64 %r87,%r81,%r90; mov.u64 %r92,%r62; .loc 1 188 0 mov.u32 %r80,0; mov.u64 %r77,0; .loc 1 198 0 mov.u32 %r177,-1; .loc 1 200 0 mov.u32 %r178,1; $L15: .loc 1 189 0 cvt.s64.s32 %r124,%r78; add.u64 %r125,%r50,%r124; ld.s8 %r66,[%r125+1]; cvt.u16.u32 %r128,%r66; and.b16 %r127,%r128,4; cvt.u32.u16 %r129,%r127; cvt.s32.s8 %r131,%r129; cvt.u16.u32 %r130,%r131; setp.eq.u16 %r132,%r130,0; @ %r132 bra $L10; .loc 1 190 0 add.u32 %r79,%r78,-48; bra $L11; $L10: and.b16 %r133,%r128,3; cvt.u32.u16 %r135,%r133; cvt.s32.s8 %r56,%r135; .loc 1 191 0 setp.eq.u32 %r136,%r56,0; @ %r136 bra $L12; .loc 1 192 0 cvt.u16.u32 %r137,%r56; setp.ne.u16 %r138,%r137,1; selp.u32 %r82,87,55,%r138; sub.u32 %r79,%r78,%r82; $L11: .loc 1 195 0 setp.le.s32 %r139,%r97,%r79; @ %r139 bra $L12; .loc 1 197 0 shr.u32 %r141,%r80,31; set.u32.gt.u64 %r143,%r77,%r87; neg.s32 %r144,%r143; cvt.u16.u32 %r147,%r141; cvt.u16.u32 %r148,%r144; or.b16 %r146,%r147,%r148; cvt.u32.u16 %r149,%r146; cvt.u16.u8 %r150,%r149; setp.ne.u16 %r151,%r150,0; @ %r151 bra $L26; set.u32.eq.u64 %r153,%r77,%r87; neg.s32 %r154,%r153; set.u32.gt.s32 %r156,%r79,%r86; neg.s32 %r157,%r156; cvt.u16.u32 %r159,%r154; cvt.u16.u32 %r160,%r157; and.b16 %r158,%r159,%r160; cvt.u32.u16 %r161,%r158; cvt.u16.u8 %r162,%r161; setp.ne.u16 %r163,%r162,0; @ %r163 bra $L27; .loc 1 202 0 cvt.s64.s32 %r164,%r79; mad.lo.u64 %r77,%r77,%r90,%r164; .loc 1 200 0 mov.u32 %r80,%r178; bra $L14; $L26: .loc 1 198 0 mov.u32 %r80,%r177; bra $L14; $L27: mov.u32 %r80,%r177; $L14: .loc 1 188 0 ld.u8 %r78,[%r92]; add.u64 %r92,%r92,1; .loc 1 189 0 bra $L15; $L12: .loc 1 205 0 setp.ne.u32 %r165,%r80,-1; @ %r165 bra $L16; .loc 1 207 0 mov.u32 %r166,34; st.u32 [%r94],%r166; .loc 1 210 0 setp.ne.u64 %r167,%r96,0; @ %r167 bra $L17; .loc 1 206 0 mov.u64 %r77,%r81; bra $L33; $L16: .loc 1 208 0 @ %r175 bra $L19; .loc 1 209 0 neg.s64 %r77,%r77; $L19: .loc 1 210 0 setp.eq.u64 %r169,%r96,0; @ %r169 bra $L33; .loc 1 211 0 setp.eq.u32 %r170,%r80,0; @ %r170 bra $L20; mov.u64 %r81,%r77; $L17: add.u64 %r95,%r92,-1; mov.u64 %r77,%r81; $L20: st.u64 [%r96],%r95; .loc 1 212 0 bra $L33; $L6: .loc 1 165 0 setp.eq.u32 %r172,%r97,0; @ %r172 bra $L28; cvt.s64.s32 %r90,%r97; bra $L8; $L4: .loc 1 159 0 and.b32 %r173,%r97,-17; setp.eq.u32 %r174,%r173,0; @ %r174 bra $L21; bra $L41; $L33: .loc 1 213 0 mov.u64 %value,%r77; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtol .visible .func (.param .u64 %value_out) strtol (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 223 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtol_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 224 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } lib_a-strtold.o/0 0 0 644 1018 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtold .visible .func (.param .f64 %value_out) strtold (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/strtold.c" // BEGIN GLOBAL FUNCTION DECL: strtod .extern .func (.param .f64 %value_out) strtod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: strtold .visible .func (.param .f64 %value_out) strtold (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 42 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),strtod,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 46 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-strtoll.o/0 0 0 644 1458 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtoll .visible .func (.param .u64 %value_out) strtoll (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libc/stdlib/strtoll.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strtoll_r .extern .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strtoll .visible .func (.param .u64 %value_out) strtoll (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 135 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtoll_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 136 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } /770 0 0 0 644 6346 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtoll_r .visible .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../../newlib/libc/stdlib/strtoll_r.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtoll_r .visible .func (.param .u64 %value_out) _strtoll_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u64 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r81; .reg .u32 %r82; .reg .u64 %r85; .reg .u32 %r86; .reg .u64 %r87; .reg .u64 %r90; .reg .u32 %r91; .reg .u64 %r92; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r123; .reg .u64 %r124; .reg .u64 %r125; .reg .u16 %r127; .reg .u16 %r128; .reg .u32 %r129; .reg .u16 %r130; .reg .u32 %r131; .reg .pred %r132; .reg .u16 %r133; .reg .u32 %r135; .reg .pred %r136; .reg .u16 %r137; .reg .pred %r138; .reg .pred %r139; .reg .u32 %r141; .reg .u32 %r143; .reg .u32 %r144; .reg .u16 %r146; .reg .u16 %r147; .reg .u16 %r148; .reg .u32 %r149; .reg .u16 %r150; .reg .pred %r151; .reg .u32 %r153; .reg .u32 %r154; .reg .u32 %r156; .reg .u32 %r157; .reg .u16 %r158; .reg .u16 %r159; .reg .u16 %r160; .reg .u32 %r161; .reg .u16 %r162; .reg .pred %r163; .reg .u64 %r164; .reg .pred %r165; .reg .u32 %r166; .reg .pred %r167; .reg .pred %r169; .reg .pred %r170; .reg .pred %r172; .reg .u32 %r173; .reg .pred %r174; .reg .pred %r175; .reg .u32 %r177; .reg .u32 %r178; .reg .u16 %r179; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 78 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r85,%r95; $L2: mov.u64 %r75,%r85; add.u64 %r62,%r85,1; mov.u64 %r85,%r62; .loc 1 77 0 ld.u8 %r49,[%r75]; .loc 1 78 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r179,[%r100+1]; mov.u16 %r104,%r179; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 79 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 81 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 80 0 mov.u32 %r91,1; bra $L4; $L3: .loc 1 82 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 77 0 mov.u32 %r78,%r49; .loc 1 69 0 mov.u32 %r91,0; bra $L4; $L5: .loc 1 83 0 add.u64 %r62,%r75,2; ld.u8 %r78,[%r75+1]; .loc 1 69 0 mov.u32 %r91,0; bra $L4; $L21: .loc 1 84 0 setp.ne.u32 %r113,%r78,48; @ %r113 bra $L6; .loc 1 85 0 ld.u8 %r179,[%r62]; mov.u16 %r116,%r179; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 86 0 ld.u8 %r78,[%r62+1]; .loc 1 87 0 add.u64 %r62,%r62,2; mov.u64 %r90,16; .loc 1 88 0 cvt.u32.u64 %r97,%r90; bra $L8; $L7: .loc 1 90 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L23; cvt.s64.s32 %r90,%r97; bra $L8; $L41: cvt.s64.s32 %r90,%r97; bra $L8; $L23: mov.u64 %r90,8; .loc 1 91 0 cvt.u32.u64 %r97,%r90; bra $L8; $L28: .loc 1 90 0 mov.u64 %r90,10; .loc 1 91 0 cvt.u32.u64 %r97,%r90; $L8: .loc 1 110 0 setp.eq.u32 %r175,%r91,0; selp.u64 %r81,9223372036854775807,-9223372036854775808,%r175; .loc 1 111 0 rem.u64 %r123,%r81,%r90; cvt.u32.u64 %r86,%r123; .loc 1 112 0 div.u64 %r87,%r81,%r90; mov.u64 %r92,%r62; .loc 1 113 0 mov.u32 %r80,0; mov.u64 %r77,0; .loc 1 123 0 mov.u32 %r177,-1; .loc 1 125 0 mov.u32 %r178,1; $L15: .loc 1 114 0 cvt.s64.s32 %r124,%r78; add.u64 %r125,%r50,%r124; ld.s8 %r66,[%r125+1]; cvt.u16.u32 %r128,%r66; and.b16 %r127,%r128,4; cvt.u32.u16 %r129,%r127; cvt.s32.s8 %r131,%r129; cvt.u16.u32 %r130,%r131; setp.eq.u16 %r132,%r130,0; @ %r132 bra $L10; .loc 1 115 0 add.u32 %r79,%r78,-48; bra $L11; $L10: and.b16 %r133,%r128,3; cvt.u32.u16 %r135,%r133; cvt.s32.s8 %r56,%r135; .loc 1 116 0 setp.eq.u32 %r136,%r56,0; @ %r136 bra $L12; .loc 1 117 0 cvt.u16.u32 %r137,%r56; setp.ne.u16 %r138,%r137,1; selp.u32 %r82,87,55,%r138; sub.u32 %r79,%r78,%r82; $L11: .loc 1 120 0 setp.le.s32 %r139,%r97,%r79; @ %r139 bra $L12; .loc 1 122 0 shr.u32 %r141,%r80,31; set.u32.gt.u64 %r143,%r77,%r87; neg.s32 %r144,%r143; cvt.u16.u32 %r147,%r141; cvt.u16.u32 %r148,%r144; or.b16 %r146,%r147,%r148; cvt.u32.u16 %r149,%r146; cvt.u16.u8 %r150,%r149; setp.ne.u16 %r151,%r150,0; @ %r151 bra $L26; set.u32.eq.u64 %r153,%r77,%r87; neg.s32 %r154,%r153; set.u32.gt.s32 %r156,%r79,%r86; neg.s32 %r157,%r156; cvt.u16.u32 %r159,%r154; cvt.u16.u32 %r160,%r157; and.b16 %r158,%r159,%r160; cvt.u32.u16 %r161,%r158; cvt.u16.u8 %r162,%r161; setp.ne.u16 %r163,%r162,0; @ %r163 bra $L27; .loc 1 127 0 cvt.s64.s32 %r164,%r79; mad.lo.u64 %r77,%r77,%r90,%r164; .loc 1 125 0 mov.u32 %r80,%r178; bra $L14; $L26: .loc 1 123 0 mov.u32 %r80,%r177; bra $L14; $L27: mov.u32 %r80,%r177; $L14: .loc 1 113 0 ld.u8 %r78,[%r92]; add.u64 %r92,%r92,1; .loc 1 114 0 bra $L15; $L12: .loc 1 130 0 setp.ne.u32 %r165,%r80,-1; @ %r165 bra $L16; .loc 1 132 0 mov.u32 %r166,34; st.u32 [%r94],%r166; .loc 1 135 0 setp.ne.u64 %r167,%r96,0; @ %r167 bra $L17; .loc 1 131 0 mov.u64 %r77,%r81; bra $L33; $L16: .loc 1 133 0 @ %r175 bra $L19; .loc 1 134 0 neg.s64 %r77,%r77; $L19: .loc 1 135 0 setp.eq.u64 %r169,%r96,0; @ %r169 bra $L33; .loc 1 136 0 setp.eq.u32 %r170,%r80,0; @ %r170 bra $L20; mov.u64 %r81,%r77; $L17: add.u64 %r95,%r92,-1; mov.u64 %r77,%r81; $L20: st.u64 [%r96],%r95; .loc 1 137 0 bra $L33; $L6: .loc 1 90 0 setp.eq.u32 %r172,%r97,0; @ %r172 bra $L28; cvt.s64.s32 %r90,%r97; bra $L8; $L4: .loc 1 84 0 and.b32 %r173,%r97,-17; setp.eq.u32 %r174,%r173,0; @ %r174 bra $L21; bra $L41; $L33: .loc 1 138 0 mov.u64 %value,%r77; st.param.u64 [%value_out],%value; ret; } lib_a-strtoul.o/0 0 0 644 7848 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtoul_r .visible .func (.param .u64 %value_out) _strtoul_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../../newlib/libc/stdlib/strtoul.c" // BEGIN GLOBAL FUNCTION DECL: strtoul .visible .func (.param .u64 %value_out) strtoul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtoul_r .visible .func (.param .u64 %value_out) _strtoul_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u32 %r59; .reg .u32 %r61; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r83; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r121; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u16 %r132; .reg .u16 %r133; .reg .u32 %r134; .reg .u16 %r135; .reg .u32 %r136; .reg .pred %r137; .reg .u16 %r138; .reg .u32 %r140; .reg .pred %r141; .reg .u16 %r142; .reg .pred %r143; .reg .pred %r144; .reg .u32 %r146; .reg .u32 %r148; .reg .u32 %r149; .reg .u16 %r151; .reg .u16 %r152; .reg .u16 %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .pred %r156; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r161; .reg .u32 %r162; .reg .u16 %r163; .reg .u16 %r164; .reg .u16 %r165; .reg .u32 %r166; .reg .u16 %r167; .reg .pred %r168; .reg .u64 %r169; .reg .pred %r170; .reg .u32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .pred %r174; .reg .pred %r175; .reg .pred %r177; .reg .u64 %r178; .reg .u64 %r181; .reg .u32 %r182; .reg .pred %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .u16 %r186; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 152 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r83,%r95; $L2: mov.u64 %r75,%r83; add.u64 %r62,%r83,1; mov.u64 %r83,%r62; .loc 1 151 0 ld.u8 %r49,[%r75]; .loc 1 152 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r186,[%r100+1]; mov.u16 %r104,%r186; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 153 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 155 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 154 0 mov.u32 %r59,1; bra $L4; $L3: .loc 1 156 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 151 0 mov.u32 %r77,%r49; .loc 1 145 0 mov.u32 %r59,0; bra $L4; $L5: .loc 1 157 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 145 0 mov.u32 %r59,0; bra $L4; $L20: .loc 1 158 0 setp.ne.u32 %r113,%r77,48; @ %r113 bra $L6; .loc 1 159 0 ld.u8 %r186,[%r62]; mov.u16 %r116,%r186; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 160 0 ld.u8 %r77,[%r62+1]; .loc 1 161 0 add.u64 %r62,%r62,2; mov.u32 %r61,15; mov.u64 %r87,1152921504606846975; mov.u64 %r86,16; .loc 1 162 0 cvt.u32.u64 %r97,%r86; bra $L8; $L7: .loc 1 164 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L22; cvt.s64.s32 %r86,%r97; mov.u64 %r121,-1; div.u64 %r87,%r121,%r86; rem.u64 %r124,%r121,%r86; cvt.u32.u64 %r61,%r124; bra $L8; $L41: cvt.s64.s32 %r86,%r97; mov.u64 %r125,-1; div.u64 %r87,%r125,%r86; rem.u64 %r128,%r125,%r86; cvt.u32.u64 %r61,%r128; bra $L8; $L22: mov.u32 %r61,7; mov.u64 %r87,2305843009213693951; mov.u64 %r86,8; .loc 1 165 0 cvt.u32.u64 %r97,%r86; bra $L8; $L27: .loc 1 164 0 mov.u32 %r61,5; mov.u64 %r87,1844674407370955161; mov.u64 %r86,10; .loc 1 165 0 cvt.u32.u64 %r97,%r86; $L8: mov.u64 %r91,%r62; .loc 1 168 0 mov.u32 %r79,0; mov.u64 %r93,0; .loc 1 178 0 mov.u32 %r184,-1; .loc 1 180 0 mov.u32 %r185,1; $L14: .loc 1 169 0 cvt.s64.s32 %r129,%r77; add.u64 %r130,%r50,%r129; ld.s8 %r66,[%r130+1]; cvt.u16.u32 %r133,%r66; and.b16 %r132,%r133,4; cvt.u32.u16 %r134,%r132; cvt.s32.s8 %r136,%r134; cvt.u16.u32 %r135,%r136; setp.eq.u16 %r137,%r135,0; @ %r137 bra $L9; .loc 1 170 0 add.u32 %r78,%r77,-48; bra $L10; $L9: and.b16 %r138,%r133,3; cvt.u32.u16 %r140,%r138; cvt.s32.s8 %r56,%r140; .loc 1 171 0 setp.eq.u32 %r141,%r56,0; @ %r141 bra $L11; .loc 1 172 0 cvt.u16.u32 %r142,%r56; setp.ne.u16 %r143,%r142,1; selp.u32 %r80,87,55,%r143; sub.u32 %r78,%r77,%r80; $L10: .loc 1 175 0 setp.le.s32 %r144,%r97,%r78; @ %r144 bra $L11; .loc 1 177 0 shr.u32 %r146,%r79,31; set.u32.gt.u64 %r148,%r93,%r87; neg.s32 %r149,%r148; cvt.u16.u32 %r152,%r146; cvt.u16.u32 %r153,%r149; or.b16 %r151,%r152,%r153; cvt.u32.u16 %r154,%r151; cvt.u16.u8 %r155,%r154; setp.ne.u16 %r156,%r155,0; @ %r156 bra $L24; set.u32.eq.u64 %r158,%r93,%r87; neg.s32 %r159,%r158; set.u32.lt.s32 %r161,%r61,%r78; neg.s32 %r162,%r161; cvt.u16.u32 %r164,%r159; cvt.u16.u32 %r165,%r162; and.b16 %r163,%r164,%r165; cvt.u32.u16 %r166,%r163; cvt.u16.u8 %r167,%r166; setp.ne.u16 %r168,%r167,0; @ %r168 bra $L25; .loc 1 182 0 cvt.s64.s32 %r169,%r78; mad.lo.u64 %r93,%r93,%r86,%r169; .loc 1 180 0 mov.u32 %r79,%r185; bra $L13; $L24: .loc 1 178 0 mov.u32 %r79,%r184; bra $L13; $L25: mov.u32 %r79,%r184; $L13: .loc 1 168 0 ld.u8 %r77,[%r91]; add.u64 %r91,%r91,1; .loc 1 169 0 bra $L14; $L11: .loc 1 185 0 setp.ge.s32 %r170,%r79,0; @ %r170 bra $L15; .loc 1 187 0 mov.u32 %r171,34; st.u32 [%r94],%r171; .loc 1 190 0 setp.ne.u64 %r172,%r96,0; @ %r172 bra $L26; .loc 1 186 0 mov.u64 %r93,-1; bra $L1; $L15: .loc 1 188 0 setp.eq.u32 %r173,%r59,0; @ %r173 bra $L18; .loc 1 189 0 neg.s64 %r93,%r93; $L18: .loc 1 190 0 setp.eq.u64 %r174,%r96,0; @ %r174 bra $L1; .loc 1 191 0 setp.eq.u32 %r175,%r79,0; @ %r175 bra $L19; bra $L16; $L26: .loc 1 186 0 mov.u64 %r93,-1; $L16: .loc 1 191 0 add.u64 %r95,%r91,-1; $L19: st.u64 [%r96],%r95; .loc 1 192 0 bra $L1; $L6: .loc 1 164 0 setp.eq.u32 %r177,%r97,0; @ %r177 bra $L27; cvt.s64.s32 %r86,%r97; mov.u64 %r178,-1; div.u64 %r87,%r178,%r86; rem.u64 %r181,%r178,%r86; cvt.u32.u64 %r61,%r181; bra $L8; $L4: .loc 1 158 0 and.b32 %r182,%r97,-17; setp.eq.u32 %r183,%r182,0; @ %r183 bra $L20; bra $L41; $L1: .loc 1 193 0 mov.u64 %value,%r93; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: strtoul .visible .func (.param .u64 %value_out) strtoul (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 203 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtoul_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 204 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } /789 0 0 0 644 1466 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strtoull .visible .func (.param .u64 %value_out) strtoull (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2); .file 1 "../../../../../../newlib/libc/stdlib/strtoull.c" // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _strtoull_r .extern .func (.param .u64 %value_out) _strtoull_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DEF: strtoull .visible .func (.param .u64 %value_out) strtoull (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u32 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u32 %ar2; ld.param.u32 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u32 %r26; .reg .u64 %r31; .reg .u64 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u32 %r26,%ar2; .loc 1 136 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r26; call (%value_in),_strtoull_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r32,[%value_in]; } .loc 1 137 0 mov.u64 %value,%r32; st.param.u64 [%value_out],%value; ret; } /807 0 0 0 644 6681 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _strtoull_r .visible .func (.param .u64 %value_out) _strtoull_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); .file 1 "../../../../../../newlib/libc/stdlib/strtoull_r.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: _strtoull_r .visible .func (.param .u64 %value_out) _strtoull_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %ar3; ld.param.u32 %ar3,[%in_ar3]; .reg .u32 %r49; .reg .u64 %r50; .reg .u32 %r56; .reg .u32 %r59; .reg .u32 %r61; .reg .u64 %r62; .reg .u32 %r66; .reg .u64 %r75; .reg .u32 %r77; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u64 %r83; .reg .u64 %r86; .reg .u64 %r87; .reg .u64 %r91; .reg .u64 %r93; .reg .u64 %r94; .reg .u64 %r95; .reg .u64 %r96; .reg .u32 %r97; .reg .u64 %r98; .reg .u32 %r99; .reg .u64 %r100; .reg .u16 %r103; .reg .u16 %r104; .reg .u32 %r105; .reg .u16 %r106; .reg .u32 %r107; .reg .pred %r108; .reg .u16 %r109; .reg .pred %r110; .reg .pred %r112; .reg .pred %r113; .reg .u16 %r115; .reg .u16 %r116; .reg .u16 %r117; .reg .u32 %r118; .reg .pred %r119; .reg .pred %r120; .reg .u64 %r121; .reg .u64 %r124; .reg .u64 %r125; .reg .u64 %r128; .reg .u64 %r129; .reg .u64 %r130; .reg .u16 %r132; .reg .u16 %r133; .reg .u32 %r134; .reg .u16 %r135; .reg .u32 %r136; .reg .pred %r137; .reg .u16 %r138; .reg .u32 %r140; .reg .pred %r141; .reg .u16 %r142; .reg .pred %r143; .reg .pred %r144; .reg .u32 %r146; .reg .u32 %r148; .reg .u32 %r149; .reg .u16 %r151; .reg .u16 %r152; .reg .u16 %r153; .reg .u32 %r154; .reg .u16 %r155; .reg .pred %r156; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r161; .reg .u32 %r162; .reg .u16 %r163; .reg .u16 %r164; .reg .u16 %r165; .reg .u32 %r166; .reg .u16 %r167; .reg .pred %r168; .reg .u64 %r169; .reg .pred %r170; .reg .u32 %r171; .reg .pred %r172; .reg .pred %r173; .reg .pred %r174; .reg .pred %r175; .reg .pred %r177; .reg .u64 %r178; .reg .u64 %r181; .reg .u32 %r182; .reg .pred %r183; .reg .u32 %r184; .reg .u32 %r185; .reg .u16 %r186; mov.u64 %r94,%ar0; mov.u64 %r95,%ar1; mov.u64 %r96,%ar2; mov.u32 %r97,%ar3; .loc 1 77 0 ld.global.u64 %r50,[__ctype_ptr__]; mov.u64 %r83,%r95; $L2: mov.u64 %r75,%r83; add.u64 %r62,%r83,1; mov.u64 %r83,%r62; .loc 1 76 0 ld.u8 %r49,[%r75]; .loc 1 77 0 cvt.u32.u32 %r99,%r49; cvt.u64.u8 %r98,%r99; add.u64 %r100,%r50,%r98; ld.u8 %r186,[%r100+1]; mov.u16 %r104,%r186; and.b16 %r103,%r104,8; cvt.u32.u16 %r105,%r103; cvt.s32.s8 %r107,%r105; cvt.u16.u32 %r106,%r107; setp.ne.u16 %r108,%r106,0; @ %r108 bra $L2; .loc 1 78 0 cvt.u16.u32 %r109,%r49; setp.ne.u16 %r110,%r109,45; @ %r110 bra $L3; .loc 1 80 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 79 0 mov.u32 %r59,1; bra $L4; $L3: .loc 1 81 0 setp.eq.u16 %r112,%r109,43; @ %r112 bra $L5; .loc 1 76 0 mov.u32 %r77,%r49; .loc 1 70 0 mov.u32 %r59,0; bra $L4; $L5: .loc 1 82 0 add.u64 %r62,%r75,2; ld.u8 %r77,[%r75+1]; .loc 1 70 0 mov.u32 %r59,0; bra $L4; $L20: .loc 1 83 0 setp.ne.u32 %r113,%r77,48; @ %r113 bra $L6; .loc 1 84 0 ld.u8 %r186,[%r62]; mov.u16 %r116,%r186; and.b16 %r115,%r116,-33; cvt.u32.u16 %r118,%r115; cvt.u16.u8 %r117,%r118; setp.ne.u16 %r119,%r117,88; @ %r119 bra $L7; .loc 1 85 0 ld.u8 %r77,[%r62+1]; .loc 1 86 0 add.u64 %r62,%r62,2; mov.u32 %r61,15; mov.u64 %r87,1152921504606846975; mov.u64 %r86,16; .loc 1 87 0 cvt.u32.u64 %r97,%r86; bra $L8; $L7: .loc 1 89 0 setp.eq.u32 %r120,%r97,0; @ %r120 bra $L22; cvt.s64.s32 %r86,%r97; mov.u64 %r121,-1; div.u64 %r87,%r121,%r86; rem.u64 %r124,%r121,%r86; cvt.u32.u64 %r61,%r124; bra $L8; $L41: cvt.s64.s32 %r86,%r97; mov.u64 %r125,-1; div.u64 %r87,%r125,%r86; rem.u64 %r128,%r125,%r86; cvt.u32.u64 %r61,%r128; bra $L8; $L22: mov.u32 %r61,7; mov.u64 %r87,2305843009213693951; mov.u64 %r86,8; .loc 1 90 0 cvt.u32.u64 %r97,%r86; bra $L8; $L27: .loc 1 89 0 mov.u32 %r61,5; mov.u64 %r87,1844674407370955161; mov.u64 %r86,10; .loc 1 90 0 cvt.u32.u64 %r97,%r86; $L8: mov.u64 %r91,%r62; .loc 1 93 0 mov.u32 %r79,0; mov.u64 %r93,0; .loc 1 103 0 mov.u32 %r184,-1; .loc 1 105 0 mov.u32 %r185,1; $L14: .loc 1 94 0 cvt.s64.s32 %r129,%r77; add.u64 %r130,%r50,%r129; ld.s8 %r66,[%r130+1]; cvt.u16.u32 %r133,%r66; and.b16 %r132,%r133,4; cvt.u32.u16 %r134,%r132; cvt.s32.s8 %r136,%r134; cvt.u16.u32 %r135,%r136; setp.eq.u16 %r137,%r135,0; @ %r137 bra $L9; .loc 1 95 0 add.u32 %r78,%r77,-48; bra $L10; $L9: and.b16 %r138,%r133,3; cvt.u32.u16 %r140,%r138; cvt.s32.s8 %r56,%r140; .loc 1 96 0 setp.eq.u32 %r141,%r56,0; @ %r141 bra $L11; .loc 1 97 0 cvt.u16.u32 %r142,%r56; setp.ne.u16 %r143,%r142,1; selp.u32 %r80,87,55,%r143; sub.u32 %r78,%r77,%r80; $L10: .loc 1 100 0 setp.le.s32 %r144,%r97,%r78; @ %r144 bra $L11; .loc 1 102 0 shr.u32 %r146,%r79,31; set.u32.gt.u64 %r148,%r93,%r87; neg.s32 %r149,%r148; cvt.u16.u32 %r152,%r146; cvt.u16.u32 %r153,%r149; or.b16 %r151,%r152,%r153; cvt.u32.u16 %r154,%r151; cvt.u16.u8 %r155,%r154; setp.ne.u16 %r156,%r155,0; @ %r156 bra $L24; set.u32.eq.u64 %r158,%r93,%r87; neg.s32 %r159,%r158; set.u32.lt.s32 %r161,%r61,%r78; neg.s32 %r162,%r161; cvt.u16.u32 %r164,%r159; cvt.u16.u32 %r165,%r162; and.b16 %r163,%r164,%r165; cvt.u32.u16 %r166,%r163; cvt.u16.u8 %r167,%r166; setp.ne.u16 %r168,%r167,0; @ %r168 bra $L25; .loc 1 107 0 cvt.s64.s32 %r169,%r78; mad.lo.u64 %r93,%r93,%r86,%r169; .loc 1 105 0 mov.u32 %r79,%r185; bra $L13; $L24: .loc 1 103 0 mov.u32 %r79,%r184; bra $L13; $L25: mov.u32 %r79,%r184; $L13: .loc 1 93 0 ld.u8 %r77,[%r91]; add.u64 %r91,%r91,1; .loc 1 94 0 bra $L14; $L11: .loc 1 110 0 setp.ge.s32 %r170,%r79,0; @ %r170 bra $L15; .loc 1 112 0 mov.u32 %r171,34; st.u32 [%r94],%r171; .loc 1 115 0 setp.ne.u64 %r172,%r96,0; @ %r172 bra $L26; .loc 1 111 0 mov.u64 %r93,-1; bra $L1; $L15: .loc 1 113 0 setp.eq.u32 %r173,%r59,0; @ %r173 bra $L18; .loc 1 114 0 neg.s64 %r93,%r93; $L18: .loc 1 115 0 setp.eq.u64 %r174,%r96,0; @ %r174 bra $L1; .loc 1 116 0 setp.eq.u32 %r175,%r79,0; @ %r175 bra $L19; bra $L16; $L26: .loc 1 111 0 mov.u64 %r93,-1; $L16: .loc 1 116 0 add.u64 %r95,%r91,-1; $L19: st.u64 [%r96],%r95; .loc 1 117 0 bra $L1; $L6: .loc 1 89 0 setp.eq.u32 %r177,%r97,0; @ %r177 bra $L27; cvt.s64.s32 %r86,%r97; mov.u64 %r178,-1; div.u64 %r87,%r178,%r86; rem.u64 %r181,%r178,%r86; cvt.u32.u64 %r61,%r181; bra $L8; $L4: .loc 1 83 0 and.b32 %r182,%r97,-17; setp.eq.u32 %r183,%r182,0; @ %r183 bra $L20; bra $L41; $L1: .loc 1 118 0 mov.u64 %value,%r93; st.param.u64 [%value_out],%value; ret; } lib_a-strupr.o/ 0 0 0 644 1416 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strupr .visible .func (.param .u64 %value_out) strupr (.param .u64 %in_ar0); .file 1 "../../../../../../newlib/libc/string/strupr.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: strupr .visible .func (.param .u64 %value_out) strupr (.param .u64 %in_ar0) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u32 %r55; .reg .u32 %r56; .reg .u64 %r58; .reg .u64 %r60; .reg .pred %r61; .reg .u64 %r62; .reg .u32 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .u16 %r68; .reg .u16 %r69; .reg .u16 %r70; .reg .u32 %r71; .reg .u32 %r72; .reg .pred %r73; .reg .pred %r74; .reg .u16 %r76; mov.u64 %r60,%ar0; .loc 1 41 0 ld.u8 %r55,[%r60]; setp.eq.u32 %r61,%r55,0; @ %r61 bra $L2; mov.u64 %r58,%r60; $L4: mov.u32 %r56,%r55; .loc 1 43 0 cvt.u32.u32 %r63,%r56; cvt.u64.u8 %r62,%r63; ld.global.u64 %r64,[__ctype_ptr__]; add.u64 %r65,%r64,%r62; ld.u8 %r76,[%r65+1]; mov.u16 %r69,%r76; and.b16 %r68,%r69,3; cvt.u32.u16 %r72,%r68; cvt.s32.s8 %r71,%r72; cvt.u16.u32 %r70,%r71; setp.ne.u16 %r73,%r70,2; @ %r73 bra $L3; add.u32 %r56,%r56,-32; $L3: st.u8 [%r58],%r56; .loc 1 41 0 add.u64 %r58,%r58,1; ld.u8 %r55,[%r58]; setp.ne.u32 %r74,%r55,0; @ %r74 bra $L4; $L2: .loc 1 46 0 mov.u64 %value,%r60; st.param.u64 [%value_out],%value; ret; } lib_a-strxfrm.o/0 0 0 644 1978 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: strxfrm .visible .func (.param .u64 %value_out) strxfrm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/strxfrm.c" // BEGIN GLOBAL FUNCTION DEF: strxfrm .visible .func (.param .u64 %value_out) strxfrm (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r52; .reg .u64 %r53; .reg .u64 %r54; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r60; .reg .u64 %r62; .reg .u64 %r63; .reg .u64 %r64; .reg .u64 %r65; .reg .pred %r66; .reg .u32 %r67; .reg .pred %r68; .reg .u32 %r69; .reg .pred %r70; .reg .pred %r71; .reg .pred %r72; .reg .u64 %r73; .reg .u16 %r74; .reg .u32 %r75; .reg .pred %r76; mov.u64 %r63,%ar0; mov.u64 %r64,%ar1; mov.u64 %r65,%ar2; ld.s8 %r52,[%r64]; .loc 1 62 0 setp.eq.u64 %r66,%r65,0; @ %r66 bra $L7; .loc 1 64 0 add.u64 %r54,%r64,1; add.u64 %r57,%r63,1; cvt.u32.u32 %r67,%r52; st.u8 [%r63],%r67; setp.eq.u32 %r68,%r52,0; @ %r68 bra $L8; mov.u64 %r56,%r57; add.u64 %r60,%r64,%r65; bra $L4; $L5: add.u64 %r54,%r54,1; cvt.u32.u32 %r69,%r52; st.u8 [%r56],%r69; add.u64 %r56,%r56,1; setp.eq.u32 %r70,%r52,0; @ %r70 bra $L9; $L4: sub.u64 %r65,%r54,%r64; ld.s8 %r52,[%r54]; .loc 1 62 0 setp.ne.u64 %r71,%r54,%r60; @ %r71 bra $L5; bra $L2; $L7: mov.u64 %r54,%r64; $L2: .loc 1 69 0 setp.eq.u32 %r72,%r52,0; @ %r72 bra $L10; mov.u64 %r53,%r54; $L6: .loc 1 71 0 add.u64 %r53,%r53,1; add.u64 %r73,%r53,%r65; sub.u64 %r62,%r73,%r54; .loc 1 69 0 ld.s8 %r75,[%r53]; cvt.u16.u32 %r74,%r75; setp.ne.u16 %r76,%r74,0; @ %r76 bra $L6; bra $L1; $L8: .loc 1 61 0 mov.u64 %r62,0; bra $L1; $L9: mov.u64 %r62,%r65; bra $L1; $L10: .loc 1 69 0 mov.u64 %r62,%r65; $L1: .loc 1 76 0 mov.u64 %value,%r62; st.param.u64 [%value_out],%value; ret; } /827 0 0 0 644 44219 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __ssprint_r .visible .func (.param .u32 %value_out) __ssprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/stdio/vfprintf.c" // BEGIN GLOBAL FUNCTION DECL: _svfiprintf_r .visible .func (.param .u32 %value_out) _svfiprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memcpy .extern .func (.param .u64 %value_out) memcpy (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _realloc_os_r .extern .func (.param .u64 %value_out) _realloc_os_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: _free_r .extern .func _free_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: memmove .extern .func (.param .u64 %value_out) memmove (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: blanks$4046 .const .align 1 .u8 blanks$4046[16] = {32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 }; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[17] = {48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[17] = {48,49,50,51,52,53,54,55,56,57,97,98,99,100,101,102,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[7] = {40,110,117,108,108,41,0 }; // BEGIN VAR DEF: zeroes$4047 .const .align 1 .u8 zeroes$4047[16] = {48,48,48,48,48,48,48,48,48,48,48,48,48,48,48,48 }; // BEGIN GLOBAL FUNCTION DEF: __ssprint_r .visible .func (.param .u32 %value_out) __ssprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r23; .reg .u64 %r25; .reg .u64 %r27; .reg .u32 %r28; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r36; .reg .u64 %r41; .reg .u64 %r43; .reg .u64 %r49; .reg .u32 %r52; .reg .u64 %r53; .reg .u32 %r54; .reg .u32 %r57; .reg .u64 %r58; .reg .u64 %r60; .reg .u64 %r62; .reg .u32 %r64; .reg .u64 %r65; .reg .u64 %r66; .reg .u64 %r67; .reg .u64 %r68; .reg .pred %r69; .reg .u32 %r70; .reg .pred %r71; .reg .pred %r72; .reg .u16 %r73; .reg .u16 %r74; .reg .pred %r75; .reg .u32 %r76; .reg .u32 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .u32 %r81; .reg .u64 %r83; .reg .u64 %r84; .reg .pred %r85; .reg .u32 %r86; .reg .u32 %r87; .reg .u16 %r89; .reg .u16 %r90; .reg .pred %r91; .reg .u64 %r94; .reg .pred %r95; .reg .u32 %r96; .reg .u64 %r100; .reg .u64 %r101; .reg .u16 %r102; .reg .u16 %r103; .reg .u16 %r104; .reg .u64 %r109; .reg .u64 %r110; .reg .pred %r111; .reg .u64 %r114; .reg .u32 %r115; .reg .u32 %r116; .reg .pred %r117; .reg .u64 %r121; .reg .u32 %r122; .reg .u64 %r123; .reg .u64 %r124; .reg .pred %r125; .reg .u16 %r126; .reg .u16 %r127; .reg .u64 %r128; .reg .u32 %r129; mov.u64 %r65,%ar0; mov.u64 %r66,%ar1; mov.u64 %r67,%ar2; .loc 1 283 0 ld.u64 %r68,[%r67+16]; setp.eq.u64 %r69,%r68,0; @ %r69 bra $L2; .loc 1 280 0 ld.u64 %r41,[%r67]; ld.u64 %r62,[%r66]; ld.u32 %r52,[%r66+12]; .loc 1 278 0 mov.u64 %r36,0; .loc 1 281 0 mov.u64 %r43,%r36; bra $L3; $L2: .loc 1 284 0 mov.u32 %r70,0; st.u32 [%r67+8],%r70; .loc 1 285 0 mov.u32 %r64,%r70; bra $L1; $L5: .loc 1 290 0 ld.u64 %r36,[%r41]; .loc 1 291 0 ld.u64 %r43,[%r41+8]; .loc 1 292 0 add.u64 %r41,%r41,16; $L3: .loc 1 289 0 setp.eq.u64 %r71,%r43,0; @ %r71 bra $L5; cvt.s64.s32 %r60,%r52; .loc 1 295 0 setp.lt.u64 %r72,%r43,%r60; @ %r72 bra $L6; ld.s16 %r23,[%r66+16]; cvt.u16.u32 %r74,%r23; and.b16 %r73,%r74,1152; setp.ne.u16 %r75,%r73,0; @ %r75 bra $L7; cvt.u32.u64 %r76,%r43; cvt.s64.s32 %r58,%r76; bra $L8; $L7: .loc 1 298 0 ld.u64 %r25,[%r66+24]; sub.u64 %r27,%r62,%r25; cvt.u32.u64 %r57,%r27; .loc 1 306 0 ld.u32 %r28,[%r66+32]; add.u32 %r78,%r28,%r28; add.u32 %r79,%r78,%r28; shr.u32 %r80,%r79,31; add.u32 %r81,%r80,%r79; shr.s32 %r54,%r81,1; .loc 1 307 0 cvt.s64.s32 %r30,%r54; cvt.s64.s32 %r31,%r57; add.u64 %r83,%r43,1; add.u64 %r84,%r83,%r31; setp.ge.u64 %r85,%r30,%r84; @ %r85 bra $L9; .loc 1 308 0 cvt.u32.u64 %r87,%r43; add.u32 %r86,%r87,1; add.u32 %r54,%r86,%r57; cvt.s64.s32 %r30,%r54; $L9: .loc 1 309 0 cvt.u16.u32 %r90,%r23; and.b16 %r89,%r90,1024; setp.eq.u16 %r91,%r89,0; @ %r91 bra $L10; .loc 1 312 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r65; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r30; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r94,[%value_in]; } mov.u64 %r53,%r94; .loc 1 313 0 setp.ne.u64 %r95,%r94,0; @ %r95 bra $L11; .loc 1 315 0 mov.u32 %r96,12; st.u32 [%r65],%r96; .loc 1 316 0 bra $L12; $L11: .loc 1 318 0 ld.u64 %r100,[%r66+24]; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r53; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r100; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r31; call (%value_in),memcpy,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r101,[%value_in]; } .loc 1 319 0 ld.u16 %r103,[%r66+16]; and.b16 %r102,%r103,-1153; or.b16 %r104,%r102,128; st.u16 [%r66+16],%r104; bra $L13; $L10: .loc 1 323 0 cvt.s64.s32 %r109,%r28; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r65; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r25; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r109; call (%value_in),_realloc_os_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u64 %r110,[%value_in]; } mov.u64 %r53,%r110; .loc 1 325 0 setp.ne.u64 %r111,%r110,0; @ %r111 bra $L13; .loc 1 327 0 ld.u64 %r114,[%r66+24]; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r65; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r114; call _free_r,(%out_arg1,%out_arg2); } .loc 1 330 0 mov.u32 %r115,12; st.u32 [%r65],%r115; .loc 1 331 0 bra $L12; $L13: .loc 1 334 0 st.u64 [%r66+24],%r53; .loc 1 335 0 add.u64 %r62,%r53,%r31; st.u64 [%r66],%r62; .loc 1 336 0 st.u32 [%r66+32],%r54; .loc 1 337 0 cvt.u32.u64 %r52,%r43; .loc 1 338 0 sub.u32 %r116,%r54,%r57; st.u32 [%r66+12],%r116; .loc 1 340 0 cvt.s64.s32 %r60,%r52; setp.le.u64 %r117,%r60,%r43; @ %r117 bra $L15; $L6: .loc 1 341 0 cvt.u32.u64 %r52,%r43; cvt.s64.s32 %r60,%r52; mov.u64 %r58,%r60; bra $L8; $L15: mov.u64 %r58,%r60; $L8: .loc 1 342 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r62; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r36; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r60; call (%value_in),memmove,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r121,[%value_in]; } .loc 1 343 0 ld.u32 %r122,[%r66+12]; sub.u32 %r52,%r122,%r52; st.u32 [%r66+12],%r52; .loc 1 344 0 ld.u64 %r123,[%r66]; add.u64 %r62,%r123,%r60; st.u64 [%r66],%r62; .loc 1 346 0 add.u64 %r36,%r36,%r58; .loc 1 347 0 sub.u64 %r43,%r43,%r58; .loc 1 348 0 ld.u64 %r124,[%r67+16]; sub.u64 %r49,%r124,%r58; st.u64 [%r67+16],%r49; setp.ne.u64 %r125,%r49,0; @ %r125 bra $L3; bra $L2; $L12: .loc 1 355 0 ld.u16 %r127,[%r66+16]; or.b16 %r126,%r127,64; st.u16 [%r66+16],%r126; .loc 1 356 0 mov.u64 %r128,0; st.u64 [%r67+16],%r128; .loc 1 357 0 cvt.u32.u64 %r129,%r128; st.u32 [%r67+8],%r129; .loc 1 358 0 mov.u32 %r64,-1; $L1: .loc 1 359 0 mov.u32 %value,%r64; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: _svfiprintf_r .visible .func (.param .u32 %value_out) _svfiprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,200; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r80; .reg .u64 %r84; .reg .u32 %r88; .reg .u32 %r145; .reg .u32 %r157; .reg .u32 %r158; .reg .u64 %r160; .reg .u64 %r167; .reg .u32 %r168; .reg .u64 %r171; .reg .u64 %r173; .reg .u64 %r177; .reg .u32 %r178; .reg .u64 %r183; .reg .u32 %r185; .reg .u64 %r186; .reg .u64 %r187; .reg .u32 %r188; .reg .u64 %r189; .reg .u32 %r190; .reg .u32 %r191; .reg .u64 %r192; .reg .u32 %r193; .reg .u32 %r194; .reg .u32 %r195; .reg .u64 %r196; .reg .u64 %r197; .reg .u32 %r198; .reg .u32 %r200; .reg .u32 %r203; .reg .u32 %r204; .reg .u32 %r205; .reg .u64 %r207; .reg .u64 %r208; .reg .u64 %r209; .reg .u64 %r210; .reg .u32 %r214; .reg .u64 %r219; .reg .u32 %r220; .reg .u32 %r221; .reg .u64 %r223; .reg .u64 %r224; .reg .u64 %r226; .reg .u64 %r227; .reg .u64 %r228; .reg .u64 %r229; .reg .u64 %r230; .reg .u64 %r231; .reg .u64 %r232; .reg .u64 %r234; .reg .u64 %r235; .reg .u64 %r236; .reg .u64 %r237; .reg .u64 %r238; .reg .u64 %r239; .reg .u64 %r240; .reg .u64 %r241; .reg .u64 %r242; .reg .u32 %r250; .reg .u64 %r252; .reg .u64 %r253; .reg .u64 %r255; .reg .u32 %r256; .reg .u32 %r257; .reg .u64 %r258; .reg .u32 %r259; .reg .u64 %r260; .reg .u64 %r264; .reg .u32 %r265; .reg .u64 %r266; .reg .u64 %r267; .reg .u32 %r276; .reg .u32 %r277; .reg .u32 %r278; .reg .u32 %r279; .reg .u32 %r280; .reg .u32 %r281; .reg .u32 %r284; .reg .u64 %r285; .reg .u64 %r286; .reg .u64 %r287; .reg .u64 %r288; .reg .u16 %r296; .reg .u16 %r297; .reg .pred %r298; .reg .u64 %r299; .reg .pred %r300; .reg .u64 %r302; .reg .u64 %r303; .reg .pred %r304; .reg .u32 %r305; .reg .u32 %r306; .reg .u64 %r307; .reg .u32 %r308; .reg .u16 %r310; .reg .u32 %r311; .reg .u32 %r312; .reg .u32 %r315; .reg .u32 %r316; .reg .u16 %r317; .reg .u16 %r318; .reg .u16 %r319; .reg .u32 %r320; .reg .u16 %r321; .reg .pred %r322; .reg .u16 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r329; .reg .u32 %r330; .reg .u16 %r331; .reg .u16 %r332; .reg .u16 %r333; .reg .u32 %r334; .reg .u16 %r335; .reg .pred %r336; .reg .u64 %r337; .reg .pred %r338; .reg .u64 %r339; .reg .u64 %r340; .reg .u32 %r341; .reg .pred %r342; .reg .u32 %r347; .reg .pred %r348; .reg .u16 %r349; .reg .u32 %r350; .reg .pred %r351; .reg .u32 %r352; .reg .pred %r353; .reg .pred %r354; .reg .pred %r355; .reg .pred %r356; .reg .pred %r357; .reg .pred %r358; .reg .pred %r359; .reg .pred %r360; .reg .pred %r361; .reg .pred %r362; .reg .pred %r363; .reg .pred %r364; .reg .pred %r365; .reg .pred %r366; .reg .pred %r367; .reg .pred %r368; .reg .pred %r369; .reg .pred %r370; .reg .pred %r371; .reg .pred %r372; .reg .pred %r373; .reg .pred %r374; .reg .pred %r375; .reg .pred %r376; .reg .pred %r377; .reg .pred %r378; .reg .pred %r379; .reg .pred %r380; .reg .pred %r381; .reg .pred %r382; .reg .pred %r383; .reg .pred %r384; .reg .u32 %r385; .reg .pred %r386; .reg .u32 %r387; .reg .pred %r388; .reg .pred %r389; .reg .pred %r390; .reg .pred %r391; .reg .u32 %r392; .reg .u32 %r394; .reg .u32 %r395; .reg .u32 %r396; .reg .pred %r397; .reg .u32 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .pred %r404; .reg .u16 %r405; .reg .pred %r406; .reg .u32 %r407; .reg .u32 %r408; .reg .pred %r409; .reg .u32 %r410; .reg .u32 %r411; .reg .pred %r412; .reg .u32 %r413; .reg .pred %r414; .reg .u32 %r415; .reg .pred %r416; .reg .u16 %r417; .reg .pred %r418; .reg .u32 %r419; .reg .pred %r420; .reg .u32 %r421; .reg .u64 %r422; .reg .u32 %r423; .reg .pred %r424; .reg .u64 %r425; .reg .u32 %r426; .reg .pred %r427; .reg .u64 %r428; .reg .u32 %r429; .reg .pred %r430; .reg .u32 %r431; .reg .pred %r432; .reg .u32 %r433; .reg .pred %r434; .reg .u32 %r435; .reg .pred %r436; .reg .u16 %r437; .reg .u32 %r438; .reg .u32 %r439; .reg .u32 %r440; .reg .pred %r441; .reg .pred %r442; .reg .u32 %r444; .reg .u64 %r446; .reg .u64 %r447; .reg .pred %r448; .reg .u64 %r449; .reg .u32 %r450; .reg .u64 %r452; .reg .u32 %r453; .reg .pred %r454; .reg .u32 %r455; .reg .pred %r456; .reg .u32 %r457; .reg .pred %r458; .reg .u16 %r459; .reg .pred %r460; .reg .u32 %r461; .reg .u32 %r462; .reg .pred %r463; .reg .u32 %r464; .reg .pred %r465; .reg .u32 %r466; .reg .pred %r467; .reg .u16 %r468; .reg .u32 %r469; .reg .pred %r470; .reg .pred %r471; .reg .u32 %r472; .reg .u32 %r473; .reg .pred %r475; .reg .u32 %r477; .reg .u32 %r478; .reg .u32 %r480; .reg .u32 %r481; .reg .u16 %r482; .reg .u16 %r483; .reg .u16 %r484; .reg .u32 %r485; .reg .u16 %r486; .reg .pred %r487; .reg .u16 %r488; .reg .pred %r489; .reg .pred %r491; .reg .u16 %r493; .reg .u16 %r494; .reg .u16 %r496; .reg .u32 %r498; .reg .pred %r500; .reg .u16 %r502; .reg .u32 %r503; .reg .u32 %r504; .reg .u16 %r506; .reg .u16 %r507; .reg .u16 %r509; .reg .u16 %r510; .reg .u32 %r512; .reg .u16 %r513; .reg .pred %r514; .reg .u64 %r515; .reg .u32 %r516; .reg .u64 %r517; .reg .pred %r518; .reg .u16 %r520; .reg .u16 %r521; .reg .u32 %r522; .reg .u64 %r524; .reg .u16 %r526; .reg .u16 %r527; .reg .u32 %r528; .reg .pred %r531; .reg .u64 %r532; .reg .u64 %r533; .reg .u64 %r534; .reg .u32 %r535; .reg .pred %r536; .reg .u64 %r537; .reg .pred %r538; .reg .pred %r539; .reg .u32 %r540; .reg .pred %r541; .reg .u32 %r542; .reg .pred %r543; .reg .u32 %r544; .reg .pred %r545; .reg .pred %r547; .reg .pred %r548; .reg .pred %r549; .reg .u64 %r551; .reg .pred %r552; .reg .u32 %r557; .reg .pred %r558; .reg .pred %r559; .reg .pred %r561; .reg .u32 %r566; .reg .pred %r567; .reg .u16 %r568; .reg .u32 %r569; .reg .pred %r570; .reg .u64 %r572; .reg .pred %r573; .reg .u32 %r578; .reg .pred %r579; .reg .u64 %r582; .reg .pred %r583; .reg .u32 %r588; .reg .pred %r589; .reg .pred %r590; .reg .pred %r591; .reg .pred %r592; .reg .u64 %r594; .reg .pred %r595; .reg .u32 %r600; .reg .pred %r601; .reg .pred %r602; .reg .pred %r604; .reg .u32 %r609; .reg .pred %r610; .reg .pred %r611; .reg .pred %r612; .reg .u64 %r614; .reg .pred %r615; .reg .u32 %r620; .reg .pred %r621; .reg .pred %r622; .reg .pred %r624; .reg .u32 %r629; .reg .pred %r630; .reg .u32 %r631; .reg .pred %r632; .reg .u32 %r637; .reg .pred %r638; .reg .u32 %r639; .reg .pred %r640; .reg .pred %r641; .reg .pred %r642; .reg .u64 %r644; .reg .pred %r645; .reg .u32 %r650; .reg .pred %r651; .reg .pred %r652; .reg .pred %r654; .reg .u32 %r659; .reg .pred %r660; .reg .u32 %r661; .reg .pred %r662; .reg .u32 %r663; .reg .u32 %r668; .reg .pred %r669; .reg .u64 %r670; .reg .pred %r671; .reg .u64 %r675; .reg .u32 %r676; .reg .u16 %r677; .reg .u16 %r678; .reg .pred %r679; .reg .pred %r682; .reg .u32 %r684; .reg .u32 %r685; .reg .u32 %r687; .reg .u32 %r688; .reg .u16 %r689; .reg .u16 %r690; .reg .u16 %r691; .reg .u32 %r692; .reg .u16 %r693; .reg .pred %r694; .reg .u32 %r695; .reg .u64 %r697; .reg .pred %r698; .reg .u64 %r699; .reg .u32 %r717; .reg .u64 %r718; .reg .u64 %r719; .reg .u64 %r720; mov.u64 %r285,%ar0; mov.u64 %r286,%ar1; mov.u64 %r287,%ar2; mov.u64 %r288,%ar3; .loc 1 880 0 ld.u16 %r297,[%r286+16]; and.b16 %r296,%r297,128; setp.eq.u16 %r298,%r296,0; @ %r298 bra $L20; ld.u64 %r299,[%r286+24]; setp.ne.u64 %r300,%r299,0; @ %r300 bra $L20; .loc 1 882 0 mov.u64 %r302,64; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r302; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r303,[%value_in]; } st.u64 [%r286],%r303; st.u64 [%r286+24],%r303; .loc 1 883 0 setp.ne.u64 %r304,%r303,0; @ %r304 bra $L21; .loc 1 885 0 mov.u32 %r305,12; st.u32 [%r285],%r305; .loc 1 886 0 mov.u32 %r284,-1; bra $L19; $L21: .loc 1 888 0 cvt.u32.u64 %r306,%r302; st.u32 [%r286+32],%r306; $L20: .loc 1 894 0 st.u64 [%frame+168],%frame; .loc 1 895 0 mov.u64 %r307,0; st.u64 [%frame+184],%r307; .loc 1 896 0 cvt.u32.u64 %r308,%r307; st.u32 [%frame+176],%r308; .loc 1 894 0 mov.u64 %r196,%frame; .loc 1 718 0 mov.u64 %r80,%r307; .loc 1 898 0 cvt.u32.u64 %r284,%r80; .loc 1 929 0 add.u64 %r718,%frame,168; .loc 1 1694 0 add.u64 %r719,%frame,192; .loc 1 1692 0 add.u64 %r720,%frame,194; $L23: .loc 1 925 0 ld.s8 %r221,[%r287]; cvt.u16.u32 %r310,%r221; set.u32.ne.u16 %r311,%r310,0; neg.s32 %r312,%r311; set.u32.ne.u16 %r315,%r310,37; neg.s32 %r316,%r315; cvt.u16.u32 %r318,%r312; cvt.u16.u32 %r319,%r316; and.b16 %r317,%r318,%r319; cvt.u32.u16 %r320,%r317; cvt.u16.u8 %r321,%r320; setp.eq.u16 %r322,%r321,0; @ %r322 bra $L149; mov.u64 %r219,%r287; $L25: .loc 1 926 0 add.u64 %r219,%r219,1; .loc 1 925 0 ld.s8 %r200,[%r219]; cvt.u16.u32 %r324,%r200; set.u32.ne.u16 %r325,%r324,0; neg.s32 %r326,%r325; set.u32.ne.u16 %r329,%r324,37; neg.s32 %r330,%r329; cvt.u16.u32 %r332,%r326; cvt.u16.u32 %r333,%r330; and.b16 %r331,%r332,%r333; cvt.u32.u16 %r334,%r331; cvt.u16.u8 %r335,%r334; setp.ne.u16 %r336,%r335,0; @ %r336 bra $L25; sub.u64 %r337,%r219,%r287; cvt.u32.u64 %r250,%r337; .loc 1 928 0 setp.eq.u32 %r338,%r250,0; @ %r338 bra $L24; .loc 1 929 0 st.u64 [%r196],%r287; cvt.s64.s32 %r84,%r250; st.u64 [%r196+8],%r84; ld.u64 %r340,[%frame+184]; add.u64 %r339,%r340,%r84; st.u64 [%frame+184],%r339; ld.u32 %r341,[%frame+176]; add.u32 %r88,%r341,1; st.u32 [%frame+176],%r88; setp.gt.s32 %r342,%r88,7; @ %r342 bra $L26; add.u64 %r196,%r196,16; bra $L27; $L26: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r347,[%value_in]; } setp.ne.u32 %r348,%r347,0; @ %r348 bra $L28; mov.u64 %r196,%frame; $L27: .loc 1 930 0 add.u32 %r284,%r284,%r250; bra $L24; $L149: .loc 1 925 0 mov.u64 %r219,%r287; $L24: .loc 1 936 0 ld.s8 %r350,[%r219]; cvt.u16.u32 %r349,%r350; setp.eq.u16 %r351,%r349,0; @ %r351 bra $L29; .loc 1 940 0 add.u64 %r287,%r219,1; .loc 1 946 0 mov.u32 %r352,0; st.u8 [%frame+194],%r352; ld.s8 %r280,[%r219+1]; mov.u32 %r220,0; mov.u32 %r203,%r220; .loc 1 945 0 mov.u32 %r191,-1; .loc 1 944 0 mov.u32 %r190,%r220; .loc 1 942 0 mov.u32 %r188,%r220; .loc 1 1071 0 mov.u32 %r717,%r220; bra $L30; $L150: .loc 1 1018 0 mov.u64 %r288,%r234; $L30: .loc 1 958 0 add.u64 %r287,%r287,1; mov.u32 %r185,%r280; $L31: .loc 1 959 0 setp.eq.u32 %r353,%r185,88; @ %r353 bra $L33; setp.gt.s32 %r354,%r185,88; @ %r354 bra $L34; setp.eq.u32 %r355,%r185,46; @ %r355 bra $L35; setp.gt.s32 %r356,%r185,46; @ %r356 bra $L36; setp.eq.u32 %r357,%r185,42; @ %r357 bra $L37; setp.gt.s32 %r358,%r185,42; @ %r358 bra $L38; setp.eq.u32 %r359,%r185,32; @ %r359 bra $L39; setp.eq.u32 %r360,%r185,35; @ %r360 bra $L40; bra $L32; $L38: setp.eq.u32 %r361,%r185,43; @ %r361 bra $L41; setp.eq.u32 %r362,%r185,45; @ %r362 bra $L42; bra $L32; $L36: setp.gt.s32 %r363,%r185,57; @ %r363 bra $L43; setp.ge.s32 %r364,%r185,49; @ %r364 bra $L44; setp.eq.u32 %r365,%r185,48; @ %r365 bra $L45; bra $L32; $L43: setp.eq.u32 %r366,%r185,79; @ %r366 bra $L46; setp.eq.u32 %r367,%r185,85; @ %r367 bra $L47; setp.eq.u32 %r368,%r185,68; @ ! %r368 bra $L32; bra $L48; $L34: setp.eq.u32 %r369,%r185,110; @ %r369 bra $L49; setp.gt.s32 %r370,%r185,110; @ %r370 bra $L50; setp.eq.u32 %r371,%r185,104; @ %r371 bra $L51; setp.gt.s32 %r372,%r185,104; @ %r372 bra $L52; setp.eq.u32 %r373,%r185,99; @ %r373 bra $L53; setp.eq.u32 %r374,%r185,100; @ %r374 bra $L54; bra $L32; $L52: setp.eq.u32 %r375,%r185,105; @ %r375 bra $L54; setp.eq.u32 %r376,%r185,108; @ %r376 bra $L55; bra $L32; $L50: setp.eq.u32 %r377,%r185,113; @ %r377 bra $L56; setp.gt.s32 %r378,%r185,113; @ %r378 bra $L57; setp.eq.u32 %r379,%r185,111; @ %r379 bra $L58; setp.eq.u32 %r380,%r185,112; @ %r380 bra $L59; bra $L32; $L57: setp.eq.u32 %r381,%r185,117; @ %r381 bra $L60; setp.eq.u32 %r382,%r185,120; @ %r382 bra $L61; setp.eq.u32 %r383,%r185,115; @ ! %r383 bra $L32; bra $L62; $L42: ld.s8 %r280,[%r287]; bra $L63; $L33: setp.eq.u32 %r384,%r220,0; @ %r384 bra $L64; cvt.u32.u32 %r385,%r203; st.u8 [%frame+194],%r385; $L64: .loc 1 1542 0 cvta.const.u64 %r80,$LC0; bra $L65; $L54: setp.eq.u32 %r386,%r220,0; @ %r386 bra $L67; cvt.u32.u32 %r387,%r203; st.u8 [%frame+194],%r387; bra $L67; $L39: ld.s8 %r280,[%r287]; .loc 1 975 0 setp.ne.u32 %r388,%r203,0; selp.u32 %r220,%r220,1,%r388; selp.u32 %r203,%r203,32,%r388; bra $L30; $L40: .loc 1 979 0 or.b32 %r188,%r188,1; ld.s8 %r280,[%r287]; .loc 1 980 0 bra $L30; $L37: .loc 1 1018 0 add.u64 %r234,%r288,4; ld.u32 %r190,[%r288]; ld.s8 %r280,[%r287]; .loc 1 1022 0 setp.ge.s32 %r389,%r190,0; @ %r389 bra $L150; .loc 1 1024 0 neg.s32 %r190,%r190; .loc 1 1018 0 mov.u64 %r288,%r234; $L63: .loc 1 1027 0 or.b32 %r188,%r188,4; .loc 1 1028 0 bra $L30; $L41: ld.s8 %r280,[%r287]; .loc 1 1031 0 mov.u32 %r220,1; .loc 1 1030 0 mov.u32 %r203,%r185; .loc 1 1031 0 bra $L30; $L35: .loc 1 1033 0 add.u64 %r210,%r287,1; ld.s8 %r185,[%r287]; setp.eq.u32 %r390,%r185,42; @ %r390 bra $L69; .loc 1 1072 0 add.u32 %r695,%r185,-48; setp.le.u32 %r391,%r695,9; @ %r391 bra $L70; .loc 1 1033 0 mov.u64 %r287,%r210; .loc 1 1071 0 mov.u32 %r191,%r717; bra $L31; $L69: ld.u32 %r392,[%r288]; max.s32 %r191,%r392,-1; ld.s8 %r280,[%r287+1]; .loc 1 1063 0 add.u64 %r288,%r288,4; .loc 1 1033 0 mov.u64 %r287,%r210; bra $L30; $L70: mov.u64 %r197,%r210; .loc 1 1071 0 mov.u32 %r191,%r717; $L72: .loc 1 1073 0 shl.b32 %r394,%r191,2; add.u32 %r395,%r394,%r191; add.u32 %r396,%r395,%r395; add.u32 %r191,%r396,%r695; add.u64 %r287,%r197,1; .loc 1 1074 0 ld.s8 %r185,[%r197]; .loc 1 1072 0 add.u32 %r695,%r185,-48; mov.u64 %r197,%r287; setp.le.u32 %r397,%r695,9; @ %r397 bra $L72; bra $L31; $L45: .loc 1 1084 0 or.b32 %r188,%r188,128; ld.s8 %r280,[%r287]; .loc 1 1085 0 bra $L30; $L44: mov.u64 %r189,%r287; .loc 1 1088 0 mov.u32 %r190,0; add.u32 %r695,%r185,-48; $L73: .loc 1 1090 0 shl.b32 %r399,%r190,2; add.u32 %r400,%r399,%r190; add.u32 %r401,%r400,%r400; add.u32 %r190,%r695,%r401; add.u64 %r287,%r287,1; .loc 1 1091 0 ld.s8 %r185,[%r189]; mov.u64 %r189,%r287; .loc 1 1092 0 add.u32 %r695,%r185,-48; setp.le.u32 %r404,%r695,9; @ %r404 bra $L73; bra $L31; $L51: .loc 1 1118 0 or.b32 %r188,%r188,64; ld.s8 %r280,[%r287]; .loc 1 1119 0 bra $L30; $L55: .loc 1 1122 0 ld.s8 %r280,[%r287]; cvt.u16.u32 %r405,%r280; setp.ne.u16 %r406,%r405,108; @ %r406 bra $L74; .loc 1 1124 0 or.b32 %r188,%r188,32; ld.s8 %r280,[%r287+1]; .loc 1 1123 0 add.u64 %r287,%r287,1; bra $L30; $L74: .loc 1 1127 0 or.b32 %r188,%r188,16; bra $L30; $L56: .loc 1 1130 0 or.b32 %r188,%r188,32; ld.s8 %r280,[%r287]; .loc 1 1131 0 bra $L30; $L53: .loc 1 1189 0 ld.u32 %r407,[%r288]; st.u8 [%frame+128],%r407; .loc 1 1192 0 mov.u32 %r408,0; st.u8 [%frame+194],%r408; .loc 1 1189 0 add.u64 %r288,%r288,4; .loc 1 1193 0 mov.u32 %r194,1; .loc 1 1190 0 mov.u32 %r195,%r194; .loc 1 1173 0 add.u64 %r187,%frame,128; .loc 1 1193 0 bra $L75; $L48: setp.eq.u32 %r409,%r220,0; @ %r409 bra $L76; cvt.u32.u32 %r410,%r203; st.u8 [%frame+194],%r410; $L76: .loc 1 1195 0 or.b32 %r188,%r188,16; $L67: .loc 1 1199 0 and.b32 %r411,%r188,32; setp.eq.u32 %r412,%r411,0; @ %r412 bra $L77; add.u64 %r227,%r288,7; and.b64 %r226,%r227,-8; add.u64 %r288,%r226,8; ld.u64 %r192,[%r226]; bra $L78; $L77: and.b32 %r413,%r188,16; setp.eq.u32 %r414,%r413,0; @ %r414 bra $L79; add.u64 %r223,%r288,7; and.b64 %r228,%r223,-8; add.u64 %r288,%r228,8; ld.u64 %r192,[%r228]; bra $L78; $L79: ld.u32 %r279,[%r288]; add.u64 %r288,%r288,4; and.b32 %r415,%r188,64; setp.eq.u32 %r416,%r415,0; @ %r416 bra $L80; cvt.u16.u32 %r417,%r279; cvt.s64.s16 %r192,%r417; bra $L78; $L80: cvt.s64.s32 %r192,%r279; $L78: .loc 1 1201 0 setp.ge.s64 %r418,%r192,0; @ %r418 bra $L81; .loc 1 1207 0 neg.s64 %r192,%r192; .loc 1 1208 0 mov.u32 %r419,45; st.u8 [%frame+194],%r419; bra $L81; $L49: setp.eq.u32 %r420,%r220,0; @ %r420 bra $L82; cvt.u32.u32 %r421,%r203; st.u8 [%frame+194],%r421; $L82: add.u64 %r422,%r288,7; and.b64 %r252,%r422,-8; ld.u64 %r253,[%r252]; add.u64 %r288,%r252,8; .loc 1 1392 0 and.b32 %r423,%r188,32; setp.eq.u32 %r424,%r423,0; @ %r424 bra $L83; .loc 1 1393 0 cvt.s64.s32 %r425,%r284; st.u64 [%r253],%r425; bra $L23; $L83: .loc 1 1396 0 and.b32 %r426,%r188,16; setp.eq.u32 %r427,%r426,0; @ %r427 bra $L85; .loc 1 1397 0 cvt.s64.s32 %r428,%r284; st.u64 [%r253],%r428; bra $L23; $L85: .loc 1 1398 0 and.b32 %r429,%r188,64; setp.eq.u32 %r430,%r429,0; @ %r430 bra $L86; .loc 1 1399 0 st.u16 [%r253],%r284; bra $L23; $L86: .loc 1 1405 0 st.u32 [%r253],%r284; bra $L23; $L46: .loc 1 1408 0 or.b32 %r188,%r188,16; $L58: .loc 1 1411 0 and.b32 %r431,%r188,32; setp.eq.u32 %r432,%r431,0; @ %r432 bra $L87; add.u64 %r238,%r288,7; and.b64 %r239,%r238,-8; add.u64 %r288,%r239,8; ld.u64 %r192,[%r239]; .loc 1 1412 0 mov.u32 %r193,0; bra $L88; $L87: .loc 1 1411 0 and.b32 %r433,%r188,16; setp.eq.u32 %r434,%r433,0; @ %r434 bra $L89; add.u64 %r240,%r288,7; and.b64 %r241,%r240,-8; add.u64 %r288,%r241,8; ld.u64 %r192,[%r241]; .loc 1 1412 0 mov.u32 %r193,%r431; bra $L88; $L89: ld.u32 %r278,[%r288]; add.u64 %r288,%r288,4; .loc 1 1411 0 and.b32 %r435,%r188,64; setp.eq.u32 %r436,%r435,0; @ %r436 bra $L90; cvt.u16.u32 %r437,%r278; cvt.u64.u16 %r192,%r437; .loc 1 1412 0 mov.u32 %r193,%r433; bra $L88; $L90: .loc 1 1411 0 cvt.u64.u32 %r192,%r278; .loc 1 1412 0 mov.u32 %r193,%r435; bra $L88; $L59: .loc 1 1426 0 add.u64 %r208,%r288,7; and.b64 %r209,%r208,-8; add.u64 %r288,%r209,8; ld.u64 %r192,[%r209]; .loc 1 1429 0 or.b32 %r188,%r188,2; .loc 1 1430 0 mov.u32 %r438,48; st.u8 [%frame+192],%r438; .loc 1 1431 0 mov.u32 %r439,120; st.u8 [%frame+193],%r439; .loc 1 1428 0 cvta.const.u64 %r80,$LC1; .loc 1 1427 0 mov.u32 %r193,2; .loc 1 1432 0 bra $L88; $L62: .loc 1 1437 0 add.u64 %r183,%r288,7; and.b64 %r242,%r183,-8; add.u64 %r288,%r242,8; ld.u64 %r187,[%r242]; .loc 1 1441 0 mov.u32 %r440,0; st.u8 [%frame+194],%r440; .loc 1 1447 0 setp.ne.u64 %r441,%r187,0; @ %r441 bra $L91; .loc 1 1449 0 min.u32 %r195,%r191,6; mov.u32 %r194,%r195; .loc 1 1448 0 cvta.const.u64 %r187,$LC2; bra $L75; $L91: .loc 1 1516 0 setp.eq.u32 %r442,%r191,-1; @ %r442 bra $L92; .loc 1 1522 0 cvt.s64.s32 %r446,%r191; mov.u32 %r444,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r187; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r444; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r446; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r447,[%value_in]; } .loc 1 1524 0 setp.eq.u64 %r448,%r447,0; @ %r448 bra $L93; .loc 1 1525 0 sub.u64 %r449,%r447,%r187; cvt.u32.u64 %r450,%r449; min.s32 %r195,%r191,%r450; ld.s8 %r281,[%frame+194]; .loc 1 943 0 mov.u32 %r191,%r444; bra $L94; $L92: .loc 1 1531 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r187; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r452,[%value_in]; } cvt.u32.u64 %r195,%r452; ld.s8 %r281,[%frame+194]; .loc 1 943 0 mov.u32 %r191,0; bra $L94; $L47: .loc 1 1535 0 or.b32 %r188,%r188,16; $L60: .loc 1 1538 0 and.b32 %r453,%r188,32; setp.eq.u32 %r454,%r453,0; @ %r454 bra $L95; add.u64 %r235,%r288,7; and.b64 %r236,%r235,-8; add.u64 %r288,%r236,8; ld.u64 %r192,[%r236]; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L95: .loc 1 1538 0 and.b32 %r455,%r188,16; setp.eq.u32 %r456,%r455,0; @ %r456 bra $L96; add.u64 %r230,%r288,7; and.b64 %r229,%r230,-8; add.u64 %r288,%r229,8; ld.u64 %r192,[%r229]; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L96: ld.u32 %r277,[%r288]; add.u64 %r288,%r288,4; .loc 1 1538 0 and.b32 %r457,%r188,64; setp.eq.u32 %r458,%r457,0; @ %r458 bra $L97; cvt.u16.u32 %r459,%r277; cvt.u64.u16 %r192,%r459; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L97: .loc 1 1538 0 cvt.u64.u32 %r192,%r277; .loc 1 1539 0 mov.u32 %r193,1; bra $L88; $L61: setp.eq.u32 %r460,%r220,0; @ %r460 bra $L98; cvt.u32.u32 %r461,%r203; st.u8 [%frame+194],%r461; $L98: .loc 1 1545 0 cvta.const.u64 %r80,$LC1; $L65: .loc 1 1546 0 and.b32 %r462,%r188,32; setp.eq.u32 %r463,%r462,0; @ %r463 bra $L99; add.u64 %r237,%r288,7; and.b64 %r224,%r237,-8; add.u64 %r288,%r224,8; ld.u64 %r192,[%r224]; bra $L100; $L99: and.b32 %r464,%r188,16; setp.eq.u32 %r465,%r464,0; @ %r465 bra $L101; add.u64 %r232,%r288,7; and.b64 %r231,%r232,-8; add.u64 %r288,%r231,8; ld.u64 %r192,[%r231]; bra $L100; $L101: ld.u32 %r276,[%r288]; add.u64 %r288,%r288,4; and.b32 %r466,%r188,64; setp.eq.u32 %r467,%r466,0; @ %r467 bra $L102; cvt.u16.u32 %r468,%r276; cvt.u64.u16 %r192,%r468; bra $L100; $L102: cvt.u64.u32 %r192,%r276; $L100: .loc 1 1549 0 and.b32 %r469,%r188,1; setp.eq.u32 %r470,%r469,0; @ %r470 bra $L151; setp.eq.u64 %r471,%r192,0; @ %r471 bra $L152; .loc 1 1550 0 mov.u32 %r472,48; st.u8 [%frame+192],%r472; .loc 1 1551 0 st.u8 [%frame+193],%r185; .loc 1 1552 0 or.b32 %r188,%r188,2; .loc 1 1547 0 mov.u32 %r193,2; bra $L88; $L151: mov.u32 %r193,2; bra $L88; $L152: mov.u32 %r193,2; $L88: .loc 1 1559 0 mov.u32 %r473,0; st.u8 [%frame+194],%r473; .loc 1 1565 0 setp.eq.u32 %r475,%r191,-1; @ %r475 bra $L153; .loc 1 1566 0 and.b32 %r204,%r188,-129; .loc 1 1574 0 set.u32.ne.u64 %r477,%r192,0; neg.s32 %r478,%r477; set.u32.ne.u32 %r480,%r191,0; neg.s32 %r481,%r480; cvt.u16.u32 %r483,%r478; cvt.u16.u32 %r484,%r481; or.b16 %r482,%r483,%r484; cvt.u32.u16 %r485,%r482; cvt.u16.u8 %r486,%r485; setp.eq.u16 %r487,%r486,0; @ %r487 bra $L104; bra $L147; $L161: mov.u32 %r193,1; $L147: ld.s8 %r281,[%frame+194]; mov.u32 %r188,%r204; bra $L103; $L153: mov.u32 %r281,0; $L103: .loc 1 1580 0 cvt.u16.u32 %r488,%r193; setp.eq.u16 %r489,%r488,1; @ %r489 bra $L106; setp.eq.u16 %r491,%r488,2; @ %r491 bra $L154; .loc 1 1573 0 mov.u64 %r186,%r718; bra $L105; $L156: .loc 1 1581 0 mov.u64 %r186,%r187; $L105: .loc 1 1583 0 add.u64 %r187,%r186,-1; cvt.u16.u64 %r494,%r192; and.b16 %r493,%r494,7; add.u16 %r496,%r493,48; cvt.u32.u16 %r498,%r496; cvt.s32.s8 %r145,%r498; st.u8 [%r187],%r498; .loc 1 1584 0 shr.u64 %r192,%r192,3; .loc 1 1585 0 setp.ne.u64 %r500,%r192,0; @ %r500 bra $L156; .loc 1 1587 0 cvt.u16.u32 %r502,%r145; set.u32.ne.u16 %r503,%r502,48; neg.s32 %r504,%r503; cvt.u16.u32 %r507,%r188; and.b16 %r506,%r507,1; cvt.u16.u32 %r510,%r504; and.b16 %r509,%r510,%r506; cvt.u32.u16 %r512,%r509; cvt.u16.u8 %r513,%r512; setp.ne.u16 %r514,%r513,0; @ %r514 bra $L108; sub.u64 %r515,%r718,%r187; cvt.u32.u64 %r195,%r515; bra $L94; $L108: .loc 1 1588 0 add.u64 %r207,%r186,-2; mov.u32 %r516,48; st.u8 [%r187+-1],%r516; sub.u64 %r517,%r718,%r207; cvt.u32.u64 %r195,%r517; mov.u64 %r187,%r207; bra $L94; $L106: .loc 1 1593 0 setp.gt.u64 %r518,%r192,9; @ %r518 bra $L157; .loc 1 1594 0 cvt.u16.u64 %r521,%r192; add.u16 %r520,%r521,48; cvt.u32.u16 %r522,%r520; st.u8 [%frame+167],%r522; .loc 1 1595 0 mov.u32 %r195,1; .loc 1 1594 0 add.u64 %r187,%frame,167; .loc 1 1595 0 bra $L94; $L157: .loc 1 1573 0 mov.u64 %r187,%r718; $L110: .loc 1 1601 0 add.u64 %r187,%r187,-1; rem.u64 %r524,%r192,10; cvt.u16.u64 %r527,%r524; add.u16 %r526,%r527,48; cvt.u32.u16 %r528,%r526; st.u8 [%r187],%r528; .loc 1 1622 0 div.u64 %r192,%r192,10; .loc 1 1623 0 setp.ne.u64 %r531,%r192,0; @ %r531 bra $L110; sub.u64 %r532,%r718,%r187; cvt.u32.u64 %r195,%r532; bra $L94; $L154: .loc 1 1573 0 mov.u64 %r187,%r718; $L107: .loc 1 1628 0 add.u64 %r187,%r187,-1; and.b64 %r533,%r192,15; add.u64 %r534,%r80,%r533; ld.u8 %r535,[%r534]; st.u8 [%r187],%r535; .loc 1 1629 0 shr.u64 %r192,%r192,4; .loc 1 1630 0 setp.ne.u64 %r536,%r192,0; @ %r536 bra $L107; sub.u64 %r537,%r718,%r187; cvt.u32.u64 %r195,%r537; bra $L94; $L104: .loc 1 1648 0 setp.eq.u32 %r538,%r193,0; @ %r538 bra $L111; $L148: ld.s8 %r281,[%frame+194]; .loc 1 1594 0 mov.u32 %r188,%r204; mov.u32 %r191,0; mov.u32 %r195,%r191; .loc 1 1573 0 mov.u64 %r187,%r718; bra $L94; $L111: .loc 1 1648 0 and.b32 %r195,%r188,1; setp.ne.u32 %r539,%r195,0; @ %r539 bra $L112; mov.u32 %r191,%r193; mov.u32 %r281,%r191; .loc 1 1566 0 mov.u32 %r188,%r204; .loc 1 1573 0 mov.u64 %r187,%r718; bra $L94; $L112: .loc 1 1649 0 mov.u32 %r540,48; st.u8 [%frame+167],%r540; mov.u32 %r281,%r193; .loc 1 1566 0 mov.u32 %r188,%r204; .loc 1 1649 0 mov.u32 %r191,%r281; add.u64 %r187,%frame,167; bra $L94; $L32: setp.eq.u32 %r541,%r220,0; @ %r541 bra $L113; cvt.u32.u32 %r542,%r203; st.u8 [%frame+194],%r542; $L113: .loc 1 1655 0 setp.eq.u32 %r543,%r185,0; @ %r543 bra $L29; .loc 1 1659 0 st.u8 [%frame+128],%r185; .loc 1 1661 0 mov.u32 %r544,0; st.u8 [%frame+194],%r544; .loc 1 1662 0 mov.u32 %r194,1; .loc 1 1660 0 mov.u32 %r195,%r194; .loc 1 1658 0 add.u64 %r187,%frame,128; .loc 1 1662 0 bra $L75; $L93: ld.s8 %r281,[%frame+194]; .loc 1 1524 0 mov.u32 %r195,%r191; .loc 1 943 0 cvt.u32.u64 %r191,%r447; $L94: .loc 1 1680 0 max.s32 %r194,%r191,%r195; .loc 1 1681 0 setp.eq.u32 %r545,%r281,0; @ %r545 bra $L114; .loc 1 1682 0 add.u32 %r194,%r194,1; $L114: .loc 1 1683 0 and.b32 %r157,%r188,2; setp.eq.u32 %r698,%r157,0; @ %r698 bra $L115; .loc 1 1684 0 add.u32 %r194,%r194,2; $L115: .loc 1 1687 0 and.b32 %r158,%r188,132; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; setp.ne.u32 %r547,%r158,0; @ %r547 bra $L116; .loc 1 1688 0 sub.u32 %r205,%r190,%r194; setp.le.s32 %r548,%r205,0; @ %r548 bra $L116; setp.le.s32 %r549,%r205,16; @ ! %r549 bra $L234; cvta.const.u64 %r699,blanks$4046; bra $L117; $L234: cvta.const.u64 %r699,blanks$4046; $L120: st.u64 [%r196],%r699; mov.u64 %r551,16; st.u64 [%r196+8],%r551; add.u64 %r255,%r255,16; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r552,%r256,7; @ %r552 bra $L118; add.u64 %r196,%r196,16; bra $L119; $L118: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r557,[%value_in]; } setp.ne.u32 %r558,%r557,0; @ %r558 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L119: add.u32 %r205,%r205,-16; setp.gt.s32 %r559,%r205,16; @ %r559 bra $L120; $L117: st.u64 [%r196],%r699; cvt.s64.s32 %r160,%r205; st.u64 [%r196+8],%r160; add.u64 %r255,%r255,%r160; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r561,%r256,7; @ %r561 bra $L121; add.u64 %r196,%r196,16; bra $L116; $L121: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r566,[%value_in]; } setp.ne.u32 %r567,%r566,0; @ %r567 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L116: add.u32 %r257,%r256,1; add.u64 %r258,%r196,16; .loc 1 1691 0 ld.s8 %r569,[%frame+194]; cvt.u16.u32 %r568,%r569; setp.eq.u16 %r570,%r568,0; @ %r570 bra $L122; .loc 1 1692 0 st.u64 [%r196],%r720; mov.u64 %r572,1; st.u64 [%r196+8],%r572; add.u64 %r255,%r255,1; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r257; setp.gt.s32 %r573,%r257,7; @ %r573 bra $L123; add.u32 %r259,%r256,2; add.u64 %r260,%r196,32; mov.u32 %r256,%r257; mov.u32 %r257,%r259; mov.u64 %r196,%r258; mov.u64 %r258,%r260; bra $L122; $L123: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r578,[%value_in]; } setp.ne.u32 %r579,%r578,0; @ %r579 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; add.u32 %r257,%r256,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L122: .loc 1 1693 0 @ %r698 bra $L124; .loc 1 1694 0 st.u64 [%r196],%r719; mov.u64 %r582,2; st.u64 [%r196+8],%r582; add.u64 %r255,%r255,2; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r257; setp.gt.s32 %r583,%r257,7; @ %r583 bra $L125; mov.u32 %r256,%r257; add.u32 %r257,%r257,1; mov.u64 %r196,%r258; add.u64 %r258,%r258,16; bra $L124; $L125: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r588,[%value_in]; } setp.ne.u32 %r589,%r588,0; @ %r589 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; add.u32 %r257,%r256,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L124: .loc 1 1697 0 setp.ne.u32 %r590,%r158,128; @ %r590 bra $L126; .loc 1 1698 0 sub.u32 %r214,%r190,%r194; setp.le.s32 %r591,%r214,0; @ %r591 bra $L126; setp.le.s32 %r592,%r214,16; @ %r592 bra $L158; cvta.const.u64 %r697,zeroes$4047; $L130: st.u64 [%r196],%r697; mov.u64 %r594,16; st.u64 [%r196+8],%r594; add.u64 %r255,%r255,16; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r595,%r256,7; @ %r595 bra $L128; add.u64 %r196,%r196,16; bra $L129; $L128: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r600,[%value_in]; } setp.ne.u32 %r601,%r600,0; @ %r601 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L129: add.u32 %r214,%r214,-16; setp.gt.s32 %r602,%r214,16; @ %r602 bra $L130; add.u32 %r256,%r256,1; add.u64 %r267,%r196,16; bra $L127; $L158: mov.u64 %r267,%r258; mov.u32 %r256,%r257; cvta.const.u64 %r697,zeroes$4047; $L127: st.u64 [%r196],%r697; cvt.s64.s32 %r167,%r214; st.u64 [%r196+8],%r167; add.u64 %r255,%r255,%r167; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r256; setp.gt.s32 %r604,%r256,7; @ %r604 bra $L131; add.u32 %r257,%r256,1; add.u64 %r258,%r267,16; mov.u64 %r196,%r267; bra $L126; $L131: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r609,[%value_in]; } setp.ne.u32 %r610,%r609,0; @ %r610 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; add.u32 %r257,%r256,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L126: .loc 1 1701 0 sub.u32 %r198,%r191,%r195; setp.le.s32 %r611,%r198,0; @ %r611 bra $L132; setp.le.s32 %r612,%r198,16; @ %r612 bra $L159; cvta.const.u64 %r697,zeroes$4047; $L136: st.u64 [%r196],%r697; mov.u64 %r614,16; st.u64 [%r196+8],%r614; add.u64 %r255,%r255,16; st.u64 [%frame+184],%r255; add.u32 %r256,%r256,1; st.u32 [%frame+176],%r256; setp.gt.s32 %r615,%r256,7; @ %r615 bra $L134; add.u64 %r196,%r196,16; bra $L135; $L134: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r620,[%value_in]; } setp.ne.u32 %r621,%r620,0; @ %r621 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r256,[%frame+176]; mov.u64 %r196,%frame; $L135: add.u32 %r198,%r198,-16; setp.gt.s32 %r622,%r198,16; @ %r622 bra $L136; add.u32 %r257,%r256,1; add.u64 %r266,%r196,16; bra $L133; $L159: mov.u64 %r266,%r258; cvta.const.u64 %r697,zeroes$4047; $L133: st.u64 [%r196],%r697; cvt.s64.s32 %r171,%r198; st.u64 [%r196+8],%r171; add.u64 %r255,%r255,%r171; st.u64 [%frame+184],%r255; st.u32 [%frame+176],%r257; setp.gt.s32 %r624,%r257,7; @ %r624 bra $L137; add.u32 %r257,%r257,1; add.u64 %r258,%r266,16; mov.u64 %r196,%r266; bra $L132; $L137: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r629,[%value_in]; } setp.ne.u32 %r630,%r629,0; @ %r630 bra $L28; ld.u64 %r255,[%frame+184]; ld.u32 %r631,[%frame+176]; add.u32 %r257,%r631,1; add.u64 %r258,%frame,16; mov.u64 %r196,%frame; $L132: .loc 1 1767 0 st.u64 [%r196],%r187; cvt.s64.s32 %r173,%r195; st.u64 [%r196+8],%r173; add.u64 %r264,%r173,%r255; st.u64 [%frame+184],%r264; st.u32 [%frame+176],%r257; setp.le.s32 %r632,%r257,7; @ %r632 bra $L138; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r637,[%value_in]; } setp.ne.u32 %r638,%r637,0; @ %r638 bra $L28; ld.u64 %r264,[%frame+184]; mov.u64 %r258,%frame; $L138: .loc 1 1770 0 and.b32 %r639,%r188,4; setp.eq.u32 %r640,%r639,0; @ %r640 bra $L139; .loc 1 1771 0 sub.u32 %r168,%r190,%r194; setp.le.s32 %r641,%r168,0; @ %r641 bra $L139; ld.u32 %r265,[%frame+176]; setp.le.s32 %r642,%r168,16; @ ! %r642 bra $L235; cvta.const.u64 %r699,blanks$4046; bra $L140; $L235: cvta.const.u64 %r699,blanks$4046; $L143: st.u64 [%r258],%r699; mov.u64 %r644,16; st.u64 [%r258+8],%r644; add.u64 %r264,%r264,16; st.u64 [%frame+184],%r264; add.u32 %r265,%r265,1; st.u32 [%frame+176],%r265; setp.gt.s32 %r645,%r265,7; @ %r645 bra $L141; add.u64 %r258,%r258,16; bra $L142; $L141: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r650,[%value_in]; } setp.ne.u32 %r651,%r650,0; @ %r651 bra $L28; ld.u64 %r264,[%frame+184]; ld.u32 %r265,[%frame+176]; mov.u64 %r258,%frame; $L142: add.u32 %r168,%r168,-16; setp.gt.s32 %r652,%r168,16; @ %r652 bra $L143; $L140: st.u64 [%r258],%r699; cvt.s64.s32 %r177,%r168; st.u64 [%r258+8],%r177; add.u64 %r264,%r264,%r177; st.u64 [%frame+184],%r264; add.u32 %r178,%r265,1; st.u32 [%frame+176],%r178; setp.le.s32 %r654,%r178,7; @ %r654 bra $L139; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r659,[%value_in]; } setp.ne.u32 %r660,%r659,0; @ %r660 bra $L28; ld.u64 %r264,[%frame+184]; $L139: .loc 1 1774 0 max.s32 %r661,%r190,%r194; add.u32 %r284,%r284,%r661; .loc 1 1776 0 setp.ne.u64 %r662,%r264,0; @ %r662 bra $L144; $L145: mov.u32 %r663,0; st.u32 [%frame+176],%r663; mov.u64 %r196,%frame; bra $L23; $L144: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r718; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r668,[%value_in]; } setp.ne.u32 %r669,%r668,0; @ ! %r669 bra $L145; .loc 1 1785 0 bra $L28; $L29: .loc 1 1784 0 ld.u64 %r670,[%frame+184]; setp.eq.u64 %r671,%r670,0; @ %r671 bra $L28; add.u64 %r675,%frame,168; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r285; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r286; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r675; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r676,[%value_in]; } $L28: .loc 1 1791 0 ld.u16 %r678,[%r286+16]; and.b16 %r677,%r678,64; setp.ne.u16 %r679,%r677,0; selp.u32 %r284,-1,%r284,%r679; bra $L19; $L81: .loc 1 1565 0 setp.ne.u32 %r682,%r191,-1; @ %r682 bra $L146; ld.s8 %r281,[%frame+194]; bra $L106; $L75: .loc 1 943 0 mov.u32 %r191,0; bra $L114; $L146: .loc 1 1566 0 and.b32 %r204,%r188,-129; .loc 1 1574 0 set.u32.ne.u32 %r684,%r191,0; neg.s32 %r685,%r684; set.u32.ne.u64 %r687,%r192,0; neg.s32 %r688,%r687; cvt.u16.u32 %r690,%r685; cvt.u16.u32 %r691,%r688; or.b16 %r689,%r690,%r691; cvt.u32.u16 %r692,%r689; cvt.u16.u8 %r693,%r692; setp.ne.u16 %r694,%r693,0; @ ! %r694 bra $L148; bra $L161; $L19: .loc 1 1793 0 mov.u32 %value,%r284; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } /847 0 0 0 644 74873 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .visible .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdio/vfprintf.c" // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _malloc_r .extern .func (.param .u64 %value_out) _malloc_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __ssprint_r .extern .func (.param .u32 %value_out) __ssprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: zeroes$4103 .const .align 1 .u8 zeroes$4103[16] = {48,48,48,48,48,48,48,48,48,48,48,48,48,48,48,48 }; // BEGIN VAR DEF: blanks$4102 .const .align 1 .u8 blanks$4102[16] = {32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {73,78,70,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {105,110,102,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[4] = {78,65,78,0 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {110,97,110,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[17] = {48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[17] = {48,49,50,51,52,53,54,55,56,57,97,98,99,100,101,102,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[7] = {40,110,117,108,108,41,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[2] = {48,0 }; // BEGIN GLOBAL FUNCTION DEF: _svfprintf_r .visible .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,224; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r118; .reg .u64 %r122; .reg .u32 %r126; .reg .u32 %r150; .reg .u32 %r152; .reg .u32 %r153; .reg .u32 %r189; .reg .u64 %r201; .reg .u32 %r203; .reg .u32 %r204; .reg .u64 %r206; .reg .u32 %r207; .reg .u32 %r210; .reg .u32 %r214; .reg .u64 %r218; .reg .u32 %r219; .reg .u32 %r221; .reg .u64 %r223; .reg .u32 %r224; .reg .u64 %r227; .reg .u32 %r228; .reg .u32 %r230; .reg .u32 %r234; .reg .u32 %r240; .reg .u64 %r244; .reg .u32 %r245; .reg .u32 %r247; .reg .u32 %r249; .reg .u64 %r255; .reg .u32 %r256; .reg .u64 %r258; .reg .u32 %r259; .reg .u64 %r261; .reg .u32 %r263; .reg .u32 %r265; .reg .u64 %r267; .reg .u32 %r268; .reg .u32 %r271; .reg .u32 %r274; .reg .u32 %r277; .reg .u32 %r278; .reg .u64 %r279; .reg .u32 %r281; .reg .u32 %r283; .reg .u32 %r284; .reg .u64 %r286; .reg .u32 %r287; .reg .u64 %r292; .reg .u64 %r293; .reg .u64 %r297; .reg .u64 %r300; .reg .u64 %r304; .reg .u32 %r305; .reg .u32 %r311; .reg .u64 %r312; .reg .u64 %r313; .reg .u32 %r314; .reg .u32 %r315; .reg .u32 %r316; .reg .u32 %r317; .reg .u64 %r318; .reg .u32 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u64 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u64 %r327; .reg .u32 %r333; .reg .u32 %r334; .reg .f64 %r335; .reg .u32 %r340; .reg .u32 %r342; .reg .u64 %r343; .reg .u32 %r347; .reg .u32 %r350; .reg .u64 %r351; .reg .u64 %r352; .reg .u64 %r353; .reg .u32 %r354; .reg .u64 %r355; .reg .u32 %r356; .reg .u64 %r359; .reg .u32 %r361; .reg .f64 %r368; .reg .u64 %r369; .reg .u64 %r370; .reg .u32 %r371; .reg .u64 %r375; .reg .u32 %r381; .reg .u64 %r385; .reg .u32 %r390; .reg .u64 %r394; .reg .u64 %r398; .reg .u64 %r399; .reg .u32 %r400; .reg .u32 %r401; .reg .u64 %r402; .reg .u64 %r403; .reg .u64 %r404; .reg .u64 %r406; .reg .u64 %r407; .reg .u64 %r408; .reg .u64 %r409; .reg .u64 %r410; .reg .u64 %r411; .reg .u64 %r412; .reg .u64 %r415; .reg .u64 %r416; .reg .u64 %r418; .reg .u64 %r421; .reg .u64 %r422; .reg .u64 %r423; .reg .u64 %r424; .reg .u64 %r426; .reg .u64 %r434; .reg .u32 %r441; .reg .u64 %r443; .reg .u64 %r444; .reg .u64 %r447; .reg .u32 %r448; .reg .u32 %r450; .reg .u32 %r451; .reg .u32 %r452; .reg .u64 %r453; .reg .u32 %r454; .reg .u32 %r458; .reg .u32 %r459; .reg .u64 %r460; .reg .u32 %r461; .reg .u64 %r462; .reg .u32 %r464; .reg .u32 %r465; .reg .u64 %r466; .reg .u32 %r467; .reg .u32 %r468; .reg .u32 %r469; .reg .u32 %r470; .reg .u32 %r471; .reg .u32 %r480; .reg .u32 %r481; .reg .u32 %r482; .reg .u32 %r483; .reg .u32 %r484; .reg .u32 %r485; .reg .u64 %r486; .reg .u32 %r489; .reg .u64 %r490; .reg .u64 %r491; .reg .u64 %r492; .reg .u64 %r493; .reg .u64 %r505; .reg .u64 %r507; .reg .u16 %r508; .reg .u16 %r509; .reg .pred %r510; .reg .u64 %r511; .reg .pred %r512; .reg .u64 %r514; .reg .u64 %r515; .reg .pred %r516; .reg .u32 %r517; .reg .u32 %r518; .reg .u64 %r519; .reg .u32 %r520; .reg .u16 %r522; .reg .u32 %r523; .reg .u32 %r524; .reg .u32 %r527; .reg .u32 %r528; .reg .u16 %r529; .reg .u16 %r530; .reg .u16 %r531; .reg .u32 %r532; .reg .u16 %r533; .reg .pred %r534; .reg .u16 %r536; .reg .u32 %r537; .reg .u32 %r538; .reg .u32 %r541; .reg .u32 %r542; .reg .u16 %r543; .reg .u16 %r544; .reg .u16 %r545; .reg .u32 %r546; .reg .u16 %r547; .reg .pred %r548; .reg .u64 %r549; .reg .pred %r550; .reg .u64 %r551; .reg .u64 %r552; .reg .u32 %r553; .reg .pred %r554; .reg .u32 %r559; .reg .pred %r560; .reg .u16 %r561; .reg .u32 %r562; .reg .pred %r563; .reg .u32 %r564; .reg .pred %r565; .reg .pred %r566; .reg .pred %r567; .reg .pred %r568; .reg .pred %r569; .reg .pred %r570; .reg .pred %r571; .reg .pred %r572; .reg .pred %r573; .reg .pred %r574; .reg .pred %r575; .reg .pred %r576; .reg .pred %r577; .reg .pred %r578; .reg .pred %r579; .reg .pred %r580; .reg .pred %r581; .reg .pred %r582; .reg .pred %r583; .reg .pred %r584; .reg .pred %r585; .reg .pred %r586; .reg .pred %r587; .reg .pred %r588; .reg .pred %r589; .reg .pred %r590; .reg .pred %r591; .reg .pred %r592; .reg .pred %r593; .reg .pred %r594; .reg .pred %r595; .reg .pred %r596; .reg .pred %r597; .reg .pred %r598; .reg .pred %r599; .reg .pred %r600; .reg .u32 %r601; .reg .pred %r602; .reg .u32 %r603; .reg .pred %r604; .reg .pred %r605; .reg .pred %r606; .reg .pred %r607; .reg .u32 %r608; .reg .u32 %r610; .reg .u32 %r611; .reg .u32 %r612; .reg .pred %r613; .reg .u32 %r615; .reg .u32 %r616; .reg .u32 %r617; .reg .pred %r620; .reg .u16 %r621; .reg .pred %r622; .reg .u32 %r623; .reg .u32 %r624; .reg .pred %r625; .reg .u32 %r626; .reg .u32 %r627; .reg .pred %r628; .reg .u32 %r629; .reg .pred %r630; .reg .u32 %r631; .reg .pred %r632; .reg .u16 %r633; .reg .pred %r634; .reg .u32 %r635; .reg .pred %r636; .reg .u32 %r637; .reg .u64 %r638; .reg .u32 %r642; .reg .pred %r643; .reg .pred %r644; .reg .u32 %r645; .reg .pred %r646; .reg .u32 %r648; .reg .pred %r649; .reg .pred %r650; .reg .pred %r651; .reg .u32 %r653; .reg .u32 %r654; .reg .u32 %r656; .reg .u32 %r657; .reg .u16 %r658; .reg .u16 %r659; .reg .u16 %r660; .reg .u32 %r661; .reg .u16 %r662; .reg .pred %r663; .reg .u64 %r664; .reg .u64 %r665; .reg .u32 %r666; .reg .pred %r667; .reg .pred %r668; .reg .pred %r669; .reg .u32 %r672; .reg .u64 %r680; .reg .u32 %r681; .reg .u64 %r682; .reg .u64 %r683; .reg .pred %r684; .reg .u64 %r685; .reg .u32 %r686; .reg .pred %r687; .reg .pred %r688; .reg .u64 %r689; .reg .u32 %r692; .reg .u32 %r693; .reg .u32 %r695; .reg .u32 %r696; .reg .u16 %r697; .reg .u16 %r698; .reg .u16 %r699; .reg .u32 %r700; .reg .u16 %r701; .reg .pred %r702; .reg .pred %r703; .reg .pred %r704; .reg .u32 %r705; .reg .u32 %r706; .reg .u32 %r707; .reg .pred %r708; .reg .u32 %r712; .reg .u16 %r714; .reg .u16 %r715; .reg .u32 %r716; .reg .pred %r721; .reg .u16 %r723; .reg .u16 %r724; .reg .u32 %r725; .reg .pred %r729; .reg .u32 %r731; .reg .pred %r734; .reg .u64 %r741; .reg .u32 %r742; .reg .u16 %r744; .reg .u16 %r745; .reg .u32 %r746; .reg .u64 %r748; .reg .pred %r749; .reg .pred %r750; .reg .pred %r751; .reg .pred %r752; .reg .u32 %r753; .reg .pred %r754; .reg .u32 %r755; .reg .pred %r756; .reg .u32 %r757; .reg .pred %r758; .reg .pred %r759; .reg .u32 %r760; .reg .pred %r761; .reg .pred %r762; .reg .u32 %r763; .reg .pred %r764; .reg .u32 %r765; .reg .pred %r766; .reg .u32 %r767; .reg .u64 %r768; .reg .u32 %r769; .reg .pred %r770; .reg .u64 %r771; .reg .u32 %r772; .reg .pred %r773; .reg .u64 %r774; .reg .u32 %r775; .reg .pred %r776; .reg .u32 %r777; .reg .pred %r778; .reg .u32 %r779; .reg .pred %r780; .reg .u32 %r781; .reg .pred %r782; .reg .u16 %r783; .reg .u32 %r784; .reg .u32 %r785; .reg .u32 %r786; .reg .pred %r787; .reg .pred %r788; .reg .u32 %r790; .reg .u64 %r792; .reg .u64 %r793; .reg .pred %r794; .reg .u64 %r795; .reg .u32 %r796; .reg .u64 %r798; .reg .u32 %r799; .reg .pred %r800; .reg .u32 %r801; .reg .pred %r802; .reg .u32 %r803; .reg .pred %r804; .reg .u16 %r805; .reg .pred %r806; .reg .u32 %r807; .reg .u32 %r808; .reg .pred %r809; .reg .u32 %r810; .reg .pred %r811; .reg .u32 %r812; .reg .pred %r813; .reg .u16 %r814; .reg .u32 %r815; .reg .pred %r816; .reg .pred %r817; .reg .u32 %r818; .reg .u32 %r819; .reg .pred %r821; .reg .u32 %r823; .reg .u32 %r824; .reg .u32 %r826; .reg .u32 %r827; .reg .u16 %r828; .reg .u16 %r829; .reg .u16 %r830; .reg .u32 %r831; .reg .u16 %r832; .reg .pred %r833; .reg .u16 %r834; .reg .pred %r835; .reg .pred %r837; .reg .u16 %r839; .reg .u16 %r840; .reg .u16 %r842; .reg .u32 %r844; .reg .pred %r846; .reg .u16 %r848; .reg .u32 %r849; .reg .u32 %r850; .reg .u16 %r852; .reg .u16 %r853; .reg .u16 %r855; .reg .u16 %r856; .reg .u32 %r858; .reg .u16 %r859; .reg .pred %r860; .reg .u64 %r861; .reg .u32 %r862; .reg .u64 %r863; .reg .pred %r864; .reg .u16 %r866; .reg .u16 %r867; .reg .u32 %r868; .reg .u64 %r870; .reg .u16 %r872; .reg .u16 %r873; .reg .u32 %r874; .reg .pred %r877; .reg .u64 %r878; .reg .u64 %r879; .reg .u64 %r880; .reg .u32 %r881; .reg .pred %r882; .reg .u64 %r883; .reg .pred %r884; .reg .pred %r885; .reg .u32 %r886; .reg .pred %r887; .reg .u32 %r888; .reg .pred %r889; .reg .u32 %r890; .reg .pred %r893; .reg .pred %r894; .reg .pred %r895; .reg .u64 %r897; .reg .pred %r898; .reg .u32 %r903; .reg .pred %r904; .reg .pred %r905; .reg .pred %r907; .reg .u32 %r912; .reg .pred %r913; .reg .u64 %r916; .reg .u32 %r917; .reg .pred %r918; .reg .u32 %r923; .reg .pred %r924; .reg .u64 %r927; .reg .u32 %r928; .reg .pred %r929; .reg .u32 %r934; .reg .pred %r935; .reg .pred %r936; .reg .pred %r937; .reg .pred %r938; .reg .u64 %r940; .reg .pred %r941; .reg .u32 %r946; .reg .pred %r947; .reg .pred %r948; .reg .pred %r950; .reg .u32 %r955; .reg .pred %r956; .reg .pred %r957; .reg .pred %r958; .reg .u64 %r960; .reg .pred %r961; .reg .u32 %r966; .reg .pred %r967; .reg .pred %r968; .reg .pred %r970; .reg .u32 %r975; .reg .pred %r976; .reg .u32 %r977; .reg .pred %r978; .reg .u32 %r979; .reg .pred %r980; .reg .u32 %r985; .reg .pred %r986; .reg .pred %r987; .reg .pred %r988; .reg .u64 %r989; .reg .u64 %r990; .reg .u64 %r991; .reg .u32 %r992; .reg .pred %r993; .reg .u32 %r998; .reg .pred %r999; .reg .u32 %r1000; .reg .pred %r1001; .reg .u32 %r1002; .reg .pred %r1003; .reg .u64 %r1004; .reg .u32 %r1005; .reg .pred %r1006; .reg .u32 %r1011; .reg .pred %r1012; .reg .pred %r1013; .reg .pred %r1014; .reg .u64 %r1016; .reg .pred %r1017; .reg .u32 %r1022; .reg .pred %r1023; .reg .pred %r1024; .reg .pred %r1026; .reg .u32 %r1031; .reg .pred %r1032; .reg .pred %r1033; .reg .u64 %r1034; .reg .u64 %r1035; .reg .u32 %r1036; .reg .pred %r1037; .reg .u32 %r1042; .reg .pred %r1043; .reg .u32 %r1044; .reg .pred %r1045; .reg .u32 %r1046; .reg .pred %r1047; .reg .u32 %r1048; .reg .pred %r1049; .reg .u32 %r1054; .reg .pred %r1055; .reg .pred %r1056; .reg .pred %r1057; .reg .u64 %r1059; .reg .pred %r1060; .reg .u32 %r1065; .reg .pred %r1066; .reg .pred %r1067; .reg .pred %r1069; .reg .u32 %r1074; .reg .pred %r1075; .reg .pred %r1076; .reg .u32 %r1081; .reg .pred %r1082; .reg .pred %r1083; .reg .u32 %r1084; .reg .pred %r1085; .reg .u32 %r1090; .reg .pred %r1091; .reg .pred %r1092; .reg .pred %r1093; .reg .u64 %r1095; .reg .pred %r1096; .reg .u32 %r1101; .reg .pred %r1102; .reg .pred %r1103; .reg .pred %r1105; .reg .u32 %r1110; .reg .pred %r1111; .reg .pred %r1112; .reg .u32 %r1113; .reg .pred %r1114; .reg .u32 %r1115; .reg .pred %r1116; .reg .u32 %r1121; .reg .pred %r1122; .reg .pred %r1123; .reg .u64 %r1124; .reg .u64 %r1125; .reg .u32 %r1126; .reg .pred %r1127; .reg .u32 %r1132; .reg .pred %r1133; .reg .u32 %r1134; .reg .pred %r1135; .reg .pred %r1136; .reg .u64 %r1138; .reg .pred %r1139; .reg .u32 %r1144; .reg .pred %r1145; .reg .pred %r1146; .reg .pred %r1148; .reg .u32 %r1153; .reg .pred %r1154; .reg .pred %r1155; .reg .u32 %r1156; .reg .pred %r1157; .reg .u64 %r1158; .reg .pred %r1159; .reg .u32 %r1164; .reg .pred %r1165; .reg .pred %r1166; .reg .u32 %r1171; .reg .pred %r1172; .reg .pred %r1173; .reg .u64 %r1174; .reg .pred %r1175; .reg .u32 %r1180; .reg .pred %r1181; .reg .u32 %r1182; .reg .pred %r1183; .reg .pred %r1184; .reg .u64 %r1186; .reg .pred %r1187; .reg .u32 %r1192; .reg .pred %r1193; .reg .pred %r1194; .reg .pred %r1196; .reg .u32 %r1201; .reg .pred %r1202; .reg .u32 %r1203; .reg .u64 %r1204; .reg .pred %r1205; .reg .u32 %r1210; .reg .pred %r1211; .reg .u32 %r1212; .reg .pred %r1214; .reg .u32 %r1219; .reg .pred %r1220; .reg .u32 %r1221; .reg .pred %r1222; .reg .pred %r1223; .reg .pred %r1224; .reg .u64 %r1226; .reg .pred %r1227; .reg .u32 %r1232; .reg .pred %r1233; .reg .pred %r1234; .reg .pred %r1236; .reg .u32 %r1241; .reg .pred %r1242; .reg .u32 %r1243; .reg .pred %r1244; .reg .u32 %r1245; .reg .u32 %r1250; .reg .pred %r1251; .reg .u64 %r1252; .reg .pred %r1253; .reg .u64 %r1257; .reg .u32 %r1258; .reg .u16 %r1259; .reg .u16 %r1260; .reg .pred %r1261; .reg .u64 %r1263; .reg .u32 %r1266; .reg .u64 %r1274; .reg .u32 %r1278; .reg .u64 %r1286; .reg .u16 %r1288; .reg .u32 %r1289; .reg .u32 %r1290; .reg .u32 %r1291; .reg .u32 %r1293; .reg .u32 %r1294; .reg .u16 %r1295; .reg .u16 %r1296; .reg .u16 %r1297; .reg .u32 %r1298; .reg .u16 %r1299; .reg .pred %r1300; .reg .pred %r1302; .reg .u64 %r1303; .reg .u32 %r1304; .reg .pred %r1305; .reg .u32 %r1307; .reg .u32 %r1308; .reg .u32 %r1310; .reg .u32 %r1311; .reg .u16 %r1312; .reg .u16 %r1313; .reg .u16 %r1314; .reg .u32 %r1315; .reg .u16 %r1316; .reg .pred %r1317; .reg .u64 %r1318; .reg .u64 %r1319; .reg .pred %r1324; .reg .u32 %r1325; .reg .u64 %r1326; .reg .u32 %r1327; .reg .pred %r1328; .reg .pred %r1329; .reg .u64 %r1353; .reg .u64 %r1354; .reg .u64 %r1355; .reg .u64 %r1356; .reg .u64 %r1357; .reg .u64 %r1358; .reg .u64 %r1359; .reg .u64 %r1360; .reg .u64 %r1361; .reg .u64 %r1362; mov.u64 %r490,%ar0; mov.u64 %r491,%ar1; mov.u64 %r492,%ar2; mov.u64 %r493,%ar3; .loc 1 696 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r505,[%value_in]; } ld.u64 %r327,[%r505]; .loc 1 697 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r327; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r507,[%value_in]; } .loc 1 880 0 ld.u16 %r509,[%r491+16]; and.b16 %r508,%r509,128; setp.eq.u16 %r510,%r508,0; @ %r510 bra $L2; ld.u64 %r511,[%r491+24]; setp.ne.u64 %r512,%r511,0; @ %r512 bra $L2; .loc 1 882 0 mov.u64 %r514,64; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r514; call (%value_in),_malloc_r,(%out_arg1,%out_arg2); ld.param.u64 %r515,[%value_in]; } st.u64 [%r491],%r515; st.u64 [%r491+24],%r515; .loc 1 883 0 setp.ne.u64 %r516,%r515,0; @ %r516 bra $L3; .loc 1 885 0 mov.u32 %r517,12; st.u32 [%r490],%r517; .loc 1 886 0 mov.u32 %r489,-1; bra $L1; $L3: .loc 1 888 0 cvt.u32.u64 %r518,%r514; st.u32 [%r491+32],%r518; $L2: .loc 1 894 0 st.u64 [%frame+168],%frame; .loc 1 895 0 mov.u64 %r519,0; st.u64 [%frame+184],%r519; .loc 1 896 0 cvt.u32.u64 %r520,%r519; st.u32 [%frame+176],%r520; .loc 1 707 0 cvt.u32.u64 %r401,%r519; .loc 1 699 0 mov.f64 %r335,0d0000000000000000; .loc 1 894 0 mov.u64 %r322,%frame; .loc 1 718 0 mov.u64 %r118,%r519; .loc 1 702 0 cvt.u32.u64 %r317,%r118; .loc 1 898 0 cvt.u32.u64 %r489,%r118; .loc 1 929 0 add.u64 %r1353,%frame,168; .loc 1 1763 0 add.u64 %r1354,%frame,200; .loc 1 1694 0 add.u64 %r1355,%frame,216; .loc 1 1692 0 add.u64 %r1356,%frame,218; .loc 1 1880 0 add.u64 %r1357,%frame,192; add.u64 %r1358,%frame,208; add.u64 %r1359,%frame,212; .loc 1 1928 0 add.u64 %r1360,%frame,204; .loc 1 1917 0 add.u64 %r1361,%frame,199; .loc 1 1923 0 add.u64 %r1362,%frame,202; $L5: .loc 1 925 0 ld.s8 %r278,[%r492]; cvt.u16.u32 %r522,%r278; set.u32.ne.u16 %r523,%r522,37; neg.s32 %r524,%r523; set.u32.ne.u16 %r527,%r522,0; neg.s32 %r528,%r527; cvt.u16.u32 %r530,%r524; cvt.u16.u32 %r531,%r528; and.b16 %r529,%r530,%r531; cvt.u32.u16 %r532,%r529; cvt.u16.u8 %r533,%r532; setp.eq.u16 %r534,%r533,0; @ %r534 bra $L236; mov.u64 %r359,%r492; $L7: .loc 1 926 0 add.u64 %r359,%r359,1; .loc 1 925 0 ld.s8 %r333,[%r359]; cvt.u16.u32 %r536,%r333; set.u32.ne.u16 %r537,%r536,0; neg.s32 %r538,%r537; set.u32.ne.u16 %r541,%r536,37; neg.s32 %r542,%r541; cvt.u16.u32 %r544,%r538; cvt.u16.u32 %r545,%r542; and.b16 %r543,%r544,%r545; cvt.u32.u16 %r546,%r543; cvt.u16.u8 %r547,%r546; setp.ne.u16 %r548,%r547,0; @ %r548 bra $L7; sub.u64 %r549,%r359,%r492; cvt.u32.u64 %r441,%r549; .loc 1 928 0 setp.eq.u32 %r550,%r441,0; @ %r550 bra $L6; .loc 1 929 0 st.u64 [%r322],%r492; cvt.s64.s32 %r122,%r441; st.u64 [%r322+8],%r122; ld.u64 %r552,[%frame+184]; add.u64 %r551,%r552,%r122; st.u64 [%frame+184],%r551; ld.u32 %r553,[%frame+176]; add.u32 %r126,%r553,1; st.u32 [%frame+176],%r126; setp.gt.s32 %r554,%r126,7; @ %r554 bra $L8; add.u64 %r322,%r322,16; bra $L9; $L8: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r559,[%value_in]; } setp.ne.u32 %r560,%r559,0; @ %r560 bra $L10; mov.u64 %r322,%frame; $L9: .loc 1 930 0 add.u32 %r489,%r489,%r441; bra $L6; $L236: .loc 1 925 0 mov.u64 %r359,%r492; $L6: .loc 1 936 0 ld.s8 %r562,[%r359]; cvt.u16.u32 %r561,%r562; setp.eq.u16 %r563,%r561,0; @ %r563 bra $L11; .loc 1 940 0 add.u64 %r492,%r359,1; .loc 1 946 0 mov.u32 %r564,0; st.u8 [%frame+218],%r564; ld.s8 %r484,[%r359+1]; mov.u32 %r323,0; mov.u32 %r390,%r323; .loc 1 945 0 mov.u32 %r316,-1; .loc 1 944 0 mov.u32 %r315,%r323; .loc 1 942 0 mov.u32 %r314,%r323; bra $L12; $L237: .loc 1 1018 0 mov.u64 %r493,%r406; $L12: .loc 1 958 0 add.u64 %r492,%r492,1; mov.u32 %r311,%r484; $L13: .loc 1 959 0 setp.eq.u32 %r565,%r311,85; @ %r565 bra $L15; setp.gt.s32 %r566,%r311,85; @ %r566 bra $L16; setp.eq.u32 %r567,%r311,48; @ %r567 bra $L17; setp.gt.s32 %r568,%r311,48; @ %r568 bra $L18; setp.eq.u32 %r569,%r311,42; @ %r569 bra $L19; setp.gt.s32 %r570,%r311,42; @ %r570 bra $L20; setp.eq.u32 %r571,%r311,32; @ %r571 bra $L21; setp.eq.u32 %r572,%r311,35; @ %r572 bra $L22; bra $L14; $L20: setp.eq.u32 %r573,%r311,45; @ %r573 bra $L23; setp.eq.u32 %r574,%r311,46; @ %r574 bra $L24; setp.eq.u32 %r575,%r311,43; @ ! %r575 bra $L14; bra $L25; $L18: setp.eq.u32 %r576,%r311,69; @ %r576 bra $L26; setp.gt.s32 %r577,%r311,69; @ %r577 bra $L27; setp.le.s32 %r578,%r311,57; @ %r578 bra $L28; setp.eq.u32 %r579,%r311,68; @ %r579 bra $L29; bra $L14; $L27: setp.eq.u32 %r580,%r311,76; @ %r580 bra $L30; setp.eq.u32 %r581,%r311,79; @ %r581 bra $L31; setp.eq.u32 %r582,%r311,71; @ ! %r582 bra $L14; bra $L26; $L16: setp.eq.u32 %r583,%r311,108; @ %r583 bra $L32; setp.gt.s32 %r584,%r311,108; @ %r584 bra $L33; setp.gt.s32 %r585,%r311,103; @ %r585 bra $L34; setp.ge.s32 %r586,%r311,101; @ %r586 bra $L26; setp.eq.u32 %r587,%r311,99; @ %r587 bra $L35; setp.gt.s32 %r588,%r311,99; @ %r588 bra $L36; setp.eq.u32 %r589,%r311,88; @ %r589 bra $L37; bra $L14; $L34: setp.eq.u32 %r590,%r311,104; @ %r590 bra $L38; setp.eq.u32 %r591,%r311,105; @ %r591 bra $L36; bra $L14; $L33: setp.eq.u32 %r592,%r311,113; @ %r592 bra $L39; setp.gt.s32 %r593,%r311,113; @ %r593 bra $L40; setp.eq.u32 %r594,%r311,111; @ %r594 bra $L41; setp.gt.s32 %r595,%r311,111; @ %r595 bra $L42; setp.eq.u32 %r596,%r311,110; @ %r596 bra $L43; bra $L14; $L40: setp.eq.u32 %r597,%r311,117; @ %r597 bra $L44; setp.eq.u32 %r598,%r311,120; @ %r598 bra $L45; setp.eq.u32 %r599,%r311,115; @ ! %r599 bra $L14; bra $L46; $L23: ld.s8 %r484,[%r492]; bra $L47; $L37: setp.eq.u32 %r600,%r323,0; @ %r600 bra $L48; cvt.u32.u32 %r601,%r390; st.u8 [%frame+218],%r601; $L48: .loc 1 1542 0 cvta.const.u64 %r118,$LC4; bra $L49; $L36: setp.eq.u32 %r602,%r323,0; @ %r602 bra $L51; cvt.u32.u32 %r603,%r390; st.u8 [%frame+218],%r603; bra $L51; $L21: ld.s8 %r484,[%r492]; .loc 1 975 0 setp.ne.u32 %r604,%r390,0; selp.u32 %r323,%r323,1,%r604; selp.u32 %r390,%r390,32,%r604; bra $L12; $L22: .loc 1 979 0 or.b32 %r314,%r314,1; ld.s8 %r484,[%r492]; .loc 1 980 0 bra $L12; $L19: .loc 1 1018 0 add.u64 %r406,%r493,4; ld.u32 %r315,[%r493]; ld.s8 %r484,[%r492]; .loc 1 1022 0 setp.ge.s32 %r605,%r315,0; @ %r605 bra $L237; .loc 1 1024 0 neg.s32 %r315,%r315; .loc 1 1018 0 mov.u64 %r493,%r406; $L47: .loc 1 1027 0 or.b32 %r314,%r314,4; .loc 1 1028 0 bra $L12; $L25: ld.s8 %r484,[%r492]; .loc 1 1031 0 mov.u32 %r323,1; .loc 1 1030 0 mov.u32 %r390,%r311; .loc 1 1031 0 bra $L12; $L24: .loc 1 1033 0 add.u64 %r355,%r492,1; ld.s8 %r311,[%r492]; setp.eq.u32 %r606,%r311,42; @ %r606 bra $L53; .loc 1 1072 0 add.u32 %r1325,%r311,-48; setp.le.u32 %r607,%r1325,9; @ %r607 bra $L54; .loc 1 1033 0 mov.u64 %r492,%r355; .loc 1 1071 0 mov.u32 %r316,0; bra $L13; $L53: ld.u32 %r608,[%r493]; max.s32 %r316,%r608,-1; ld.s8 %r484,[%r492+1]; .loc 1 1063 0 add.u64 %r493,%r493,4; .loc 1 1033 0 mov.u64 %r492,%r355; bra $L12; $L54: mov.u64 %r370,%r355; .loc 1 1071 0 mov.u32 %r316,0; $L56: .loc 1 1073 0 shl.b32 %r610,%r316,2; add.u32 %r611,%r610,%r316; add.u32 %r612,%r611,%r611; add.u32 %r316,%r612,%r1325; add.u64 %r492,%r370,1; .loc 1 1074 0 ld.s8 %r311,[%r370]; .loc 1 1072 0 add.u32 %r1325,%r311,-48; mov.u64 %r370,%r492; setp.le.u32 %r613,%r1325,9; @ %r613 bra $L56; bra $L13; $L17: .loc 1 1084 0 or.b32 %r314,%r314,128; ld.s8 %r484,[%r492]; .loc 1 1085 0 bra $L12; $L28: mov.u64 %r369,%r492; .loc 1 1088 0 mov.u32 %r315,0; add.u32 %r1325,%r311,-48; $L57: .loc 1 1090 0 shl.b32 %r615,%r315,2; add.u32 %r616,%r615,%r315; add.u32 %r617,%r616,%r616; add.u32 %r315,%r1325,%r617; add.u64 %r492,%r492,1; .loc 1 1091 0 ld.s8 %r311,[%r369]; mov.u64 %r369,%r492; .loc 1 1092 0 add.u32 %r1325,%r311,-48; setp.le.u32 %r620,%r1325,9; @ %r620 bra $L57; bra $L13; $L30: .loc 1 1108 0 or.b32 %r314,%r314,8; ld.s8 %r484,[%r492]; .loc 1 1109 0 bra $L12; $L38: .loc 1 1118 0 or.b32 %r314,%r314,64; ld.s8 %r484,[%r492]; .loc 1 1119 0 bra $L12; $L32: .loc 1 1122 0 ld.s8 %r484,[%r492]; cvt.u16.u32 %r621,%r484; setp.ne.u16 %r622,%r621,108; @ %r622 bra $L58; .loc 1 1124 0 or.b32 %r314,%r314,32; ld.s8 %r484,[%r492+1]; .loc 1 1123 0 add.u64 %r492,%r492,1; bra $L12; $L58: .loc 1 1127 0 or.b32 %r314,%r314,16; bra $L12; $L39: .loc 1 1130 0 or.b32 %r314,%r314,32; ld.s8 %r484,[%r492]; .loc 1 1131 0 bra $L12; $L35: .loc 1 1189 0 ld.u32 %r623,[%r493]; st.u8 [%frame+128],%r623; .loc 1 1192 0 mov.u32 %r624,0; st.u8 [%frame+218],%r624; .loc 1 1189 0 add.u64 %r493,%r493,4; .loc 1 1193 0 mov.u32 %r320,1; .loc 1 1190 0 mov.u32 %r321,%r320; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1173 0 add.u64 %r313,%frame,128; setp.eq.u32 %r1328,1,1; .loc 1 1193 0 bra $L136; $L29: setp.eq.u32 %r625,%r323,0; @ %r625 bra $L60; cvt.u32.u32 %r626,%r390; st.u8 [%frame+218],%r626; $L60: .loc 1 1195 0 or.b32 %r314,%r314,16; $L51: .loc 1 1199 0 and.b32 %r627,%r314,32; setp.eq.u32 %r628,%r627,0; @ %r628 bra $L61; add.u64 %r423,%r493,7; and.b64 %r402,%r423,-8; add.u64 %r493,%r402,8; ld.u64 %r318,[%r402]; bra $L62; $L61: and.b32 %r629,%r314,16; setp.eq.u32 %r630,%r629,0; @ %r630 bra $L63; add.u64 %r411,%r493,7; and.b64 %r407,%r411,-8; add.u64 %r493,%r407,8; ld.u64 %r318,[%r407]; bra $L62; $L63: ld.u32 %r483,[%r493]; add.u64 %r493,%r493,4; and.b32 %r631,%r314,64; setp.eq.u32 %r632,%r631,0; @ %r632 bra $L64; cvt.u16.u32 %r633,%r483; cvt.s64.s16 %r318,%r633; bra $L62; $L64: cvt.s64.s32 %r318,%r483; $L62: .loc 1 1201 0 setp.ge.s64 %r634,%r318,0; @ %r634 bra $L65; .loc 1 1207 0 neg.s64 %r318,%r318; .loc 1 1208 0 mov.u32 %r635,45; st.u8 [%frame+218],%r635; bra $L65; $L26: setp.eq.u32 %r636,%r323,0; @ %r636 bra $L66; cvt.u32.u32 %r637,%r390; st.u8 [%frame+218],%r637; $L66: add.u64 %r638,%r493,7; and.b64 %r447,%r638,-8; add.u64 %r493,%r447,8; .loc 1 1225 0 ld.f64 %r335,[%r447]; .loc 1 1236 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r335; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r642,[%value_in]; } setp.ne.u32 %r643,%r642,1; @ %r643 bra $L69; .loc 1 1237 0 setp.lt.f64 %r644,%r335,0d0000000000000000; @ %r644 bra $L70; ld.s8 %r452,[%frame+218]; bra $L71; $L70: .loc 1 1238 0 mov.u32 %r645,45; st.u8 [%frame+218],%r645; mov.u32 %r452,45; $L71: .loc 1 1239 0 setp.gt.s32 %r646,%r311,71; @ %r646 bra $L238; .loc 1 1240 0 cvta.const.u64 %r313,$LC0; bra $L72; $L238: .loc 1 1242 0 cvta.const.u64 %r313,$LC1; $L72: .loc 1 1244 0 and.b32 %r314,%r314,-129; .loc 1 1245 0 mov.u32 %r320,3; .loc 1 1243 0 mov.u32 %r321,%r320; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1245 0 bra $L59; $L69: .loc 1 1247 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r335; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r648,[%value_in]; } mov.u32 %r150,%r648; setp.ne.u32 %r649,%r648,0; @ %r649 bra $L73; .loc 1 1248 0 setp.gt.s32 %r650,%r311,71; @ %r650 bra $L239; .loc 1 1249 0 cvta.const.u64 %r313,$LC2; bra $L74; $L239: .loc 1 1251 0 cvta.const.u64 %r313,$LC3; $L74: .loc 1 1253 0 and.b32 %r314,%r314,-129; ld.s8 %r452,[%frame+218]; .loc 1 943 0 mov.u32 %r316,%r648; .loc 1 1254 0 mov.u32 %r320,3; .loc 1 1252 0 mov.u32 %r321,%r320; .loc 1 1254 0 bra $L59; $L73: and.b32 %r448,%r311,-33; .loc 1 1309 0 setp.eq.u32 %r651,%r316,-1; @ %r651 bra $L240; .loc 1 1311 0 set.u32.eq.u32 %r653,%r316,0; neg.s32 %r654,%r653; set.u32.eq.u32 %r656,%r448,71; neg.s32 %r657,%r656; cvt.u16.u32 %r659,%r654; cvt.u16.u32 %r660,%r657; and.b16 %r658,%r659,%r660; cvt.u32.u16 %r661,%r658; cvt.u16.u8 %r662,%r661; setp.ne.u16 %r663,%r662,0; .loc 1 1312 0 selp.u32 %r316,1,%r316,%r663; bra $L75; $L240: .loc 1 1310 0 mov.u32 %r316,6; $L75: .loc 1 1315 0 or.b32 %r342,%r314,256; .loc 1 1814 0 mov.b64 %r664,%r335; shr.u64 %r665,%r664,32; cvt.u32.u64 %r666,%r665; setp.ge.s32 %r667,%r666,0; @ %r667 bra $L242; .loc 1 1815 0 neg.f64 %r368,%r335; .loc 1 1816 0 mov.u32 %r400,45; bra $L76; $L242: .loc 1 1814 0 mov.f64 %r368,%r335; .loc 1 1818 0 mov.u32 %r400,0; $L76: .loc 1 1867 0 setp.eq.u32 %r668,%r448,70; @ %r668 bra $L77; .loc 1 1874 0 setp.ne.u32 %r669,%r448,69; @ %r669 bra $L78; .loc 1 1875 0 add.u32 %r371,%r316,1; .loc 1 1880 0 mov.u32 %r672,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r368; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r672; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r371; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1359; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1358; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1357; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r680,[%value_in]; } mov.u64 %r313,%r680; setp.eq.u32 %r1329,1,1; bra $L79; $L368: ld.u64 %r343,[%frame+192]; bra $L80; $L367: ld.u32 %r451,[%frame+212]; bra $L81; $L229: .loc 1 1886 0 mov.u32 %r681,1; sub.u32 %r451,%r681,%r316; st.u32 [%frame+212],%r451; $L81: .loc 1 1887 0 cvt.s64.s32 %r682,%r451; add.u64 %r683,%r682,%r353; add.u64 %r375,%r1286,%r683; setp.eq.u32 %r1329,1,1; $L227: .loc 1 1889 0 setp.eq.f64 %r684,%r368,0d0000000000000000; @ %r684 bra $L243; bra $L355; $L83: .loc 1 1892 0 add.u64 %r685,%r343,1; st.u64 [%frame+192],%r685; st.u8 [%r343],%r686; .loc 1 1891 0 ld.u64 %r343,[%frame+192]; setp.gt.u64 %r687,%r375,%r343; @ %r687 bra $L83; bra $L80; $L355: ld.u64 %r343,[%frame+192]; setp.lt.u64 %r688,%r343,%r375; @ ! %r688 bra $L80; .loc 1 1892 0 mov.u32 %r686,48; bra $L83; $L243: .loc 1 1889 0 mov.u64 %r343,%r375; $L80: .loc 1 1894 0 sub.u64 %r689,%r343,%r313; cvt.u32.u64 %r401,%r689; ld.u32 %r150,[%frame+212]; .loc 1 1320 0 @ %r1329 bra $L84; .loc 1 1321 0 set.u32.lt.s32 %r692,%r316,%r150; neg.s32 %r693,%r692; set.u32.lt.s32 %r695,%r150,-3; neg.s32 %r696,%r695; cvt.u16.u32 %r698,%r693; cvt.u16.u32 %r699,%r696; or.b16 %r697,%r698,%r699; cvt.u32.u16 %r700,%r697; cvt.u16.u8 %r701,%r700; setp.eq.u16 %r702,%r701,0; @ %r702 bra $L85; .loc 1 1322 0 add.u32 %r311,%r311,-2; bra $L86; $L84: .loc 1 1330 0 setp.eq.u32 %r703,%r311,102; @ %r703 bra $L87; $L86: .loc 1 1331 0 add.u32 %r381,%r150,-1; st.u32 [%frame+212],%r381; .loc 1 1910 0 st.u8 [%frame+200],%r311; .loc 1 1911 0 setp.ge.s32 %r704,%r381,0; @ %r704 bra $L88; .loc 1 1912 0 mov.u32 %r705,1; sub.u32 %r381,%r705,%r150; .loc 1 1913 0 mov.u32 %r706,45; st.u8 [%frame+201],%r706; bra $L89; $L88: .loc 1 1916 0 mov.u32 %r707,43; st.u8 [%frame+201],%r707; $L89: .loc 1 1918 0 setp.le.s32 %r708,%r381,9; @ %r708 bra $L90; .loc 1 1917 0 mov.u64 %r385,%r1361; bra $L91; $L244: .loc 1 1921 0 mov.u64 %r385,%r1326; $L91: .loc 1 1920 0 add.u64 %r1326,%r385,-1; rem.s32 %r712,%r381,10; cvt.u16.u32 %r715,%r712; add.u16 %r714,%r715,48; cvt.u32.u16 %r716,%r714; st.u8 [%r1326],%r716; .loc 1 1921 0 div.s32 %r381,%r381,10; setp.gt.s32 %r721,%r381,9; @ %r721 bra $L244; .loc 1 1922 0 add.u64 %r352,%r385,-2; cvt.u16.u32 %r724,%r381; add.u16 %r723,%r724,48; cvt.u32.u16 %r725,%r723; cvt.s32.s8 %r450,%r725; st.u8 [%r1326+-1],%r725; .loc 1 1923 0 setp.ge.u64 %r729,%r352,%r1361; @ %r729 bra $L245; mov.u64 %r434,%r1362; $L94: add.u64 %r352,%r352,1; cvt.u32.u32 %r731,%r450; st.u8 [%r434],%r731; add.u64 %r434,%r434,1; setp.ne.u64 %r734,%r352,%r1361; @ %r734 bra $L93; sub.u64 %r741,%r1354,%r1326; add.u64 %r394,%r1362,%r741; bra $L92; $L93: ld.s8 %r450,[%r352]; bra $L94; $L90: .loc 1 1927 0 mov.u32 %r742,48; st.u8 [%frame+202],%r742; .loc 1 1928 0 cvt.u16.u32 %r745,%r381; add.u16 %r744,%r745,48; cvt.u32.u16 %r746,%r744; st.u8 [%frame+203],%r746; mov.u64 %r394,%r1360; bra $L92; $L245: .loc 1 1923 0 mov.u64 %r394,%r1362; $L92: .loc 1 1930 0 sub.u64 %r748,%r394,%r1354; cvt.u32.u64 %r317,%r748; .loc 1 1333 0 add.u32 %r321,%r401,%r317; .loc 1 1334 0 setp.gt.s32 %r749,%r401,1; @ %r749 bra $L95; and.b32 %r150,%r314,1; setp.ne.u32 %r750,%r150,0; @ %r750 bra $L95; max.s32 %r320,%r321,0; bra $L96; $L95: .loc 1 1335 0 add.u32 %r321,%r321,1; max.s32 %r320,%r321,0; .loc 1 948 0 mov.u32 %r150,0; bra $L96; $L87: .loc 1 1341 0 setp.le.s32 %r751,%r150,0; @ %r751 bra $L97; .loc 1 1343 0 setp.ne.u32 %r752,%r316,0; @ %r752 bra $L98; and.b32 %r753,%r314,1; setp.eq.u32 %r754,%r753,0; @ %r754 bra $L246; $L98: .loc 1 1344 0 add.u32 %r755,%r316,1; add.u32 %r321,%r755,%r150; mov.u32 %r320,%r321; bra $L96; $L97: .loc 1 1348 0 setp.ne.u32 %r756,%r316,0; @ %r756 bra $L100; .loc 1 1346 0 and.b32 %r757,%r314,1; setp.eq.u32 %r758,%r757,0; @ %r758 bra $L247; $L100: .loc 1 1348 0 add.u32 %r321,%r316,2; mov.u32 %r320,%r321; bra $L96; $L85: .loc 1 1349 0 setp.gt.s32 %r759,%r401,%r150; @ %r759 bra $L101; .loc 1 1351 0 and.b32 %r760,%r314,1; setp.ne.u32 %r761,%r760,0; @ %r761 bra $L102; max.s32 %r320,%r150,0; mov.u32 %r321,%r150; mov.u32 %r311,103; bra $L96; $L102: .loc 1 1352 0 add.u32 %r321,%r150,1; max.s32 %r320,%r321,0; mov.u32 %r311,103; bra $L96; $L101: .loc 1 1355 0 setp.gt.s32 %r762,%r150,0; @ %r762 bra $L248; mov.u32 %r763,2; sub.u32 %r325,%r763,%r150; bra $L103; $L248: mov.u32 %r325,1; $L103: .loc 1 1354 0 add.u32 %r321,%r325,%r401; max.s32 %r320,%r321,0; mov.u32 %r311,103; bra $L96; $L246: mov.u32 %r320,%r150; mov.u32 %r321,%r150; bra $L96; $L247: mov.u32 %r320,1; .loc 1 1348 0 mov.u32 %r321,%r320; $L96: .loc 1 1377 0 setp.ne.u32 %r764,%r400,0; @ %r764 bra $L104; ld.s8 %r452,[%frame+218]; .loc 1 1315 0 mov.u32 %r314,%r342; .loc 1 943 0 mov.u32 %r316,%r400; bra $L59; $L104: .loc 1 1378 0 mov.u32 %r765,45; st.u8 [%frame+218],%r765; .loc 1 1315 0 mov.u32 %r314,%r342; .loc 1 943 0 mov.u32 %r316,0; setp.eq.u32 %r1328,1,0; bra $L356; $L43: setp.eq.u32 %r766,%r323,0; @ %r766 bra $L105; cvt.u32.u32 %r767,%r390; st.u8 [%frame+218],%r767; $L105: add.u64 %r768,%r493,7; and.b64 %r443,%r768,-8; add.u64 %r493,%r443,8; ld.u64 %r444,[%r443]; .loc 1 1392 0 and.b32 %r769,%r314,32; setp.eq.u32 %r770,%r769,0; @ %r770 bra $L106; .loc 1 1393 0 cvt.s64.s32 %r771,%r489; st.u64 [%r444],%r771; bra $L5; $L106: .loc 1 1396 0 and.b32 %r772,%r314,16; setp.eq.u32 %r773,%r772,0; @ %r773 bra $L108; .loc 1 1397 0 cvt.s64.s32 %r774,%r489; st.u64 [%r444],%r774; bra $L5; $L108: .loc 1 1398 0 and.b32 %r775,%r314,64; setp.eq.u32 %r776,%r775,0; @ %r776 bra $L109; .loc 1 1399 0 st.u16 [%r444],%r489; bra $L5; $L109: .loc 1 1405 0 st.u32 [%r444],%r489; bra $L5; $L31: .loc 1 1408 0 or.b32 %r314,%r314,16; $L41: .loc 1 1411 0 and.b32 %r777,%r314,32; setp.eq.u32 %r778,%r777,0; @ %r778 bra $L110; add.u64 %r412,%r493,7; and.b64 %r408,%r412,-8; add.u64 %r493,%r408,8; ld.u64 %r318,[%r408]; .loc 1 1412 0 mov.u32 %r319,0; bra $L111; $L110: .loc 1 1411 0 and.b32 %r779,%r314,16; setp.eq.u32 %r780,%r779,0; @ %r780 bra $L112; add.u64 %r415,%r493,7; and.b64 %r403,%r415,-8; add.u64 %r493,%r403,8; ld.u64 %r318,[%r403]; .loc 1 1412 0 mov.u32 %r319,%r777; bra $L111; $L112: ld.u32 %r482,[%r493]; add.u64 %r493,%r493,4; .loc 1 1411 0 and.b32 %r781,%r314,64; setp.eq.u32 %r782,%r781,0; @ %r782 bra $L113; cvt.u16.u32 %r783,%r482; cvt.u64.u16 %r318,%r783; .loc 1 1412 0 mov.u32 %r319,%r779; bra $L111; $L113: .loc 1 1411 0 cvt.u64.u32 %r318,%r482; .loc 1 1412 0 mov.u32 %r319,%r781; bra $L111; $L42: .loc 1 1426 0 add.u64 %r426,%r493,7; and.b64 %r201,%r426,-8; add.u64 %r493,%r201,8; ld.u64 %r318,[%r201]; .loc 1 1429 0 or.b32 %r314,%r314,2; .loc 1 1430 0 mov.u32 %r784,48; st.u8 [%frame+216],%r784; .loc 1 1431 0 mov.u32 %r785,120; st.u8 [%frame+217],%r785; .loc 1 1428 0 cvta.const.u64 %r118,$LC5; .loc 1 1427 0 mov.u32 %r319,2; .loc 1 1431 0 mov.u32 %r311,120; .loc 1 1432 0 bra $L111; $L46: .loc 1 1437 0 add.u64 %r424,%r493,7; and.b64 %r398,%r424,-8; add.u64 %r493,%r398,8; ld.u64 %r313,[%r398]; .loc 1 1441 0 mov.u32 %r786,0; st.u8 [%frame+218],%r786; .loc 1 1447 0 setp.ne.u64 %r787,%r313,0; @ %r787 bra $L114; .loc 1 1449 0 min.u32 %r320,%r316,6; mov.u32 %r321,%r320; mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1448 0 cvta.const.u64 %r313,$LC6; setp.eq.u32 %r1328,1,1; bra $L136; $L114: .loc 1 1516 0 setp.eq.u32 %r788,%r316,-1; @ %r788 bra $L115; .loc 1 1522 0 cvt.s64.s32 %r792,%r316; mov.u32 %r790,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r313; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r790; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r792; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r793,[%value_in]; } .loc 1 1524 0 setp.ne.u64 %r794,%r793,0; @ %r794 bra $L116; ld.s8 %r452,[%frame+218]; mov.u32 %r320,%r316; mov.u32 %r321,%r316; .loc 1 943 0 cvt.u32.u64 %r316,%r793; .loc 1 948 0 mov.u32 %r150,%r316; bra $L59; $L116: .loc 1 1525 0 sub.u64 %r795,%r793,%r313; cvt.u32.u64 %r796,%r795; min.s32 %r321,%r316,%r796; ld.s8 %r452,[%frame+218]; max.s32 %r320,%r321,0; .loc 1 943 0 mov.u32 %r316,%r790; .loc 1 948 0 mov.u32 %r150,%r316; bra $L59; $L115: .loc 1 1531 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r313; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r798,[%value_in]; } cvt.u32.u64 %r321,%r798; ld.s8 %r452,[%frame+218]; max.s32 %r320,%r321,0; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; bra $L59; $L15: .loc 1 1535 0 or.b32 %r314,%r314,16; $L44: .loc 1 1538 0 and.b32 %r799,%r314,32; setp.eq.u32 %r800,%r799,0; @ %r800 bra $L117; add.u64 %r418,%r493,7; and.b64 %r404,%r418,-8; add.u64 %r493,%r404,8; ld.u64 %r318,[%r404]; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L117: .loc 1 1538 0 and.b32 %r801,%r314,16; setp.eq.u32 %r802,%r801,0; @ %r802 bra $L118; add.u64 %r421,%r493,7; and.b64 %r410,%r421,-8; add.u64 %r493,%r410,8; ld.u64 %r318,[%r410]; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L118: ld.u32 %r481,[%r493]; add.u64 %r493,%r493,4; .loc 1 1538 0 and.b32 %r803,%r314,64; setp.eq.u32 %r804,%r803,0; @ %r804 bra $L119; cvt.u16.u32 %r805,%r481; cvt.u64.u16 %r318,%r805; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L119: .loc 1 1538 0 cvt.u64.u32 %r318,%r481; .loc 1 1539 0 mov.u32 %r319,1; bra $L111; $L45: setp.eq.u32 %r806,%r323,0; @ %r806 bra $L120; cvt.u32.u32 %r807,%r390; st.u8 [%frame+218],%r807; $L120: .loc 1 1545 0 cvta.const.u64 %r118,$LC5; $L49: .loc 1 1546 0 and.b32 %r808,%r314,32; setp.eq.u32 %r809,%r808,0; @ %r809 bra $L121; add.u64 %r409,%r493,7; and.b64 %r422,%r409,-8; add.u64 %r493,%r422,8; ld.u64 %r318,[%r422]; bra $L122; $L121: and.b32 %r810,%r314,16; setp.eq.u32 %r811,%r810,0; @ %r811 bra $L123; add.u64 %r416,%r493,7; and.b64 %r399,%r416,-8; add.u64 %r493,%r399,8; ld.u64 %r318,[%r399]; bra $L122; $L123: ld.u32 %r480,[%r493]; add.u64 %r493,%r493,4; and.b32 %r812,%r314,64; setp.eq.u32 %r813,%r812,0; @ %r813 bra $L124; cvt.u16.u32 %r814,%r480; cvt.u64.u16 %r318,%r814; bra $L122; $L124: cvt.u64.u32 %r318,%r480; $L122: .loc 1 1549 0 and.b32 %r815,%r314,1; setp.eq.u32 %r816,%r815,0; @ %r816 bra $L249; setp.eq.u64 %r817,%r318,0; @ %r817 bra $L250; .loc 1 1550 0 mov.u32 %r818,48; st.u8 [%frame+216],%r818; .loc 1 1551 0 st.u8 [%frame+217],%r311; .loc 1 1552 0 or.b32 %r314,%r314,2; .loc 1 1547 0 mov.u32 %r319,2; bra $L111; $L249: mov.u32 %r319,2; bra $L111; $L250: mov.u32 %r319,2; $L111: .loc 1 1559 0 mov.u32 %r819,0; st.u8 [%frame+218],%r819; .loc 1 1565 0 setp.eq.u32 %r821,%r316,-1; @ %r821 bra $L251; .loc 1 1566 0 and.b32 %r350,%r314,-129; .loc 1 1574 0 set.u32.ne.u64 %r823,%r318,0; neg.s32 %r824,%r823; set.u32.ne.u32 %r826,%r316,0; neg.s32 %r827,%r826; cvt.u16.u32 %r829,%r824; cvt.u16.u32 %r830,%r827; or.b16 %r828,%r829,%r830; cvt.u32.u16 %r831,%r828; cvt.u16.u8 %r832,%r831; setp.eq.u16 %r833,%r832,0; @ %r833 bra $L126; bra $L234; $L259: mov.u32 %r319,1; $L234: ld.s8 %r452,[%frame+218]; mov.u32 %r314,%r350; bra $L125; $L251: mov.u32 %r452,0; $L125: .loc 1 1580 0 cvt.u16.u32 %r834,%r319; setp.eq.u16 %r835,%r834,1; @ %r835 bra $L128; setp.eq.u16 %r837,%r834,2; @ %r837 bra $L252; .loc 1 1573 0 mov.u64 %r312,%r1353; bra $L127; $L254: .loc 1 1581 0 mov.u64 %r312,%r313; $L127: .loc 1 1583 0 add.u64 %r313,%r312,-1; cvt.u16.u64 %r840,%r318; and.b16 %r839,%r840,7; add.u16 %r842,%r839,48; cvt.u32.u16 %r844,%r842; cvt.s32.s8 %r189,%r844; st.u8 [%r313],%r844; .loc 1 1584 0 shr.u64 %r318,%r318,3; .loc 1 1585 0 setp.ne.u64 %r846,%r318,0; @ %r846 bra $L254; .loc 1 1587 0 cvt.u16.u32 %r848,%r189; set.u32.ne.u16 %r849,%r848,48; neg.s32 %r850,%r849; cvt.u16.u32 %r853,%r314; and.b16 %r852,%r853,1; cvt.u16.u32 %r856,%r850; and.b16 %r855,%r856,%r852; cvt.u32.u16 %r858,%r855; cvt.u16.u8 %r859,%r858; setp.ne.u16 %r860,%r859,0; @ %r860 bra $L130; sub.u64 %r861,%r1353,%r313; cvt.u32.u64 %r321,%r861; bra $L131; $L130: .loc 1 1588 0 add.u64 %r351,%r312,-2; mov.u32 %r862,48; st.u8 [%r313+-1],%r862; sub.u64 %r863,%r1353,%r351; cvt.u32.u64 %r321,%r863; mov.u64 %r313,%r351; bra $L131; $L128: .loc 1 1593 0 setp.gt.u64 %r864,%r318,9; @ %r864 bra $L255; .loc 1 1594 0 cvt.u16.u64 %r867,%r318; add.u16 %r866,%r867,48; cvt.u32.u16 %r868,%r866; st.u8 [%frame+167],%r868; .loc 1 1595 0 mov.u32 %r321,1; .loc 1 1594 0 add.u64 %r313,%frame,167; .loc 1 1595 0 bra $L131; $L255: .loc 1 1573 0 mov.u64 %r313,%r1353; $L132: .loc 1 1601 0 add.u64 %r313,%r313,-1; rem.u64 %r870,%r318,10; cvt.u16.u64 %r873,%r870; add.u16 %r872,%r873,48; cvt.u32.u16 %r874,%r872; st.u8 [%r313],%r874; .loc 1 1622 0 div.u64 %r318,%r318,10; .loc 1 1623 0 setp.ne.u64 %r877,%r318,0; @ %r877 bra $L132; sub.u64 %r878,%r1353,%r313; cvt.u32.u64 %r321,%r878; bra $L131; $L252: .loc 1 1573 0 mov.u64 %r313,%r1353; $L129: .loc 1 1628 0 add.u64 %r313,%r313,-1; and.b64 %r879,%r318,15; add.u64 %r880,%r118,%r879; ld.u8 %r881,[%r880]; st.u8 [%r313],%r881; .loc 1 1629 0 shr.u64 %r318,%r318,4; .loc 1 1630 0 setp.ne.u64 %r882,%r318,0; @ %r882 bra $L129; sub.u64 %r883,%r1353,%r313; cvt.u32.u64 %r321,%r883; bra $L131; $L126: .loc 1 1648 0 setp.eq.u32 %r884,%r319,0; @ %r884 bra $L133; $L235: ld.s8 %r452,[%frame+218]; .loc 1 1594 0 mov.u32 %r314,%r350; mov.u32 %r316,0; mov.u32 %r321,%r316; .loc 1 1573 0 mov.u64 %r313,%r1353; bra $L131; $L133: .loc 1 1648 0 and.b32 %r321,%r314,1; setp.ne.u32 %r885,%r321,0; @ %r885 bra $L134; mov.u32 %r316,%r319; mov.u32 %r452,%r316; .loc 1 1566 0 mov.u32 %r314,%r350; .loc 1 1573 0 mov.u64 %r313,%r1353; bra $L131; $L134: .loc 1 1649 0 mov.u32 %r886,48; st.u8 [%frame+167],%r886; mov.u32 %r452,%r319; .loc 1 1566 0 mov.u32 %r314,%r350; .loc 1 1649 0 mov.u32 %r316,%r452; add.u64 %r313,%frame,167; $L131: max.s32 %r320,%r316,%r321; .loc 1 948 0 mov.u32 %r150,0; bra $L59; $L14: setp.eq.u32 %r887,%r323,0; @ %r887 bra $L135; cvt.u32.u32 %r888,%r390; st.u8 [%frame+218],%r888; $L135: .loc 1 1655 0 setp.eq.u32 %r889,%r311,0; @ %r889 bra $L11; .loc 1 1659 0 st.u8 [%frame+128],%r311; .loc 1 1661 0 mov.u32 %r890,0; st.u8 [%frame+218],%r890; .loc 1 1662 0 mov.u32 %r320,1; .loc 1 1660 0 mov.u32 %r321,%r320; .loc 1 943 0 mov.u32 %r316,0; .loc 1 948 0 mov.u32 %r150,%r316; .loc 1 1658 0 add.u64 %r313,%frame,128; setp.eq.u32 %r1328,1,1; .loc 1 1662 0 bra $L136; $L59: .loc 1 1681 0 setp.eq.u32 %r1328,%r452,0; @ %r1328 bra $L136; $L356: .loc 1 1682 0 add.u32 %r320,%r320,1; $L136: .loc 1 1683 0 and.b32 %r203,%r314,2; setp.eq.u32 %r1324,%r203,0; @ %r1324 bra $L137; .loc 1 1684 0 add.u32 %r320,%r320,2; $L137: .loc 1 1687 0 and.b32 %r204,%r314,132; ld.u64 %r453,[%frame+184]; setp.ne.u32 %r893,%r204,0; @ %r893 bra $L138; .loc 1 1688 0 sub.u32 %r256,%r315,%r320; setp.le.s32 %r894,%r256,0; @ %r894 bra $L138; ld.u32 %r471,[%frame+176]; setp.le.s32 %r895,%r256,16; @ ! %r895 bra $L357; cvta.const.u64 %r1318,blanks$4102; bra $L139; $L357: cvta.const.u64 %r1318,blanks$4102; $L142: st.u64 [%r322],%r1318; mov.u64 %r897,16; st.u64 [%r322+8],%r897; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r471,%r471,1; st.u32 [%frame+176],%r471; setp.gt.s32 %r898,%r471,7; @ %r898 bra $L140; add.u64 %r322,%r322,16; bra $L141; $L140: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r903,[%value_in]; } setp.ne.u32 %r904,%r903,0; @ %r904 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r471,[%frame+176]; mov.u64 %r322,%frame; $L141: add.u32 %r256,%r256,-16; setp.gt.s32 %r905,%r256,16; @ %r905 bra $L142; $L139: st.u64 [%r322],%r1318; cvt.s64.s32 %r206,%r256; st.u64 [%r322+8],%r206; add.u64 %r453,%r453,%r206; st.u64 [%frame+184],%r453; add.u32 %r207,%r471,1; st.u32 [%frame+176],%r207; setp.gt.s32 %r907,%r207,7; @ %r907 bra $L143; add.u64 %r322,%r322,16; ld.s8 %r452,[%frame+218]; setp.eq.u32 %r1328,%r452,0; bra $L138; $L143: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r912,[%value_in]; } setp.ne.u32 %r913,%r912,0; @ %r913 bra $L10; ld.s8 %r452,[%frame+218]; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; setp.eq.u32 %r1328,%r452,0; $L138: .loc 1 1691 0 @ %r1328 bra $L144; .loc 1 1692 0 st.u64 [%r322],%r1356; mov.u64 %r916,1; st.u64 [%r322+8],%r916; add.u64 %r453,%r453,1; st.u64 [%frame+184],%r453; ld.u32 %r917,[%frame+176]; add.u32 %r210,%r917,1; st.u32 [%frame+176],%r210; setp.gt.s32 %r918,%r210,7; @ %r918 bra $L145; add.u64 %r322,%r322,16; bra $L144; $L145: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r923,[%value_in]; } setp.ne.u32 %r924,%r923,0; @ %r924 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L144: .loc 1 1693 0 @ %r1324 bra $L146; .loc 1 1694 0 st.u64 [%r322],%r1355; mov.u64 %r927,2; st.u64 [%r322+8],%r927; add.u64 %r453,%r453,2; st.u64 [%frame+184],%r453; ld.u32 %r928,[%frame+176]; add.u32 %r214,%r928,1; st.u32 [%frame+176],%r214; setp.gt.s32 %r929,%r214,7; @ %r929 bra $L147; add.u64 %r322,%r322,16; bra $L146; $L147: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r934,[%value_in]; } setp.ne.u32 %r935,%r934,0; @ %r935 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L146: .loc 1 1697 0 setp.ne.u32 %r936,%r204,128; @ %r936 bra $L148; .loc 1 1698 0 sub.u32 %r347,%r315,%r320; setp.le.s32 %r937,%r347,0; @ %r937 bra $L148; ld.u32 %r470,[%frame+176]; setp.le.s32 %r938,%r347,16; @ ! %r938 bra $L358; cvta.const.u64 %r1319,zeroes$4103; bra $L149; $L358: cvta.const.u64 %r1319,zeroes$4103; $L152: st.u64 [%r322],%r1319; mov.u64 %r940,16; st.u64 [%r322+8],%r940; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r470,%r470,1; st.u32 [%frame+176],%r470; setp.gt.s32 %r941,%r470,7; @ %r941 bra $L150; add.u64 %r322,%r322,16; bra $L151; $L150: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r946,[%value_in]; } setp.ne.u32 %r947,%r946,0; @ %r947 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r470,[%frame+176]; mov.u64 %r322,%frame; $L151: add.u32 %r347,%r347,-16; setp.gt.s32 %r948,%r347,16; @ %r948 bra $L152; $L149: st.u64 [%r322],%r1319; cvt.s64.s32 %r218,%r347; st.u64 [%r322+8],%r218; add.u64 %r453,%r453,%r218; st.u64 [%frame+184],%r453; add.u32 %r219,%r470,1; st.u32 [%frame+176],%r219; setp.gt.s32 %r950,%r219,7; @ %r950 bra $L153; add.u64 %r322,%r322,16; bra $L148; $L153: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r955,[%value_in]; } setp.ne.u32 %r956,%r955,0; @ %r956 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L148: .loc 1 1701 0 sub.u32 %r356,%r316,%r321; setp.le.s32 %r957,%r356,0; @ %r957 bra $L154; ld.u32 %r469,[%frame+176]; setp.le.s32 %r958,%r356,16; @ ! %r958 bra $L359; cvta.const.u64 %r1319,zeroes$4103; bra $L155; $L359: cvta.const.u64 %r1319,zeroes$4103; $L158: st.u64 [%r322],%r1319; mov.u64 %r960,16; st.u64 [%r322+8],%r960; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r469,%r469,1; st.u32 [%frame+176],%r469; setp.gt.s32 %r961,%r469,7; @ %r961 bra $L156; add.u64 %r322,%r322,16; bra $L157; $L156: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r966,[%value_in]; } setp.ne.u32 %r967,%r966,0; @ %r967 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r469,[%frame+176]; mov.u64 %r322,%frame; $L157: add.u32 %r356,%r356,-16; setp.gt.s32 %r968,%r356,16; @ %r968 bra $L158; $L155: st.u64 [%r322],%r1319; cvt.s64.s32 %r223,%r356; st.u64 [%r322+8],%r223; add.u64 %r453,%r453,%r223; st.u64 [%frame+184],%r453; add.u32 %r224,%r469,1; st.u32 [%frame+176],%r224; setp.gt.s32 %r970,%r224,7; @ %r970 bra $L159; add.u64 %r322,%r322,16; bra $L154; $L159: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r975,[%value_in]; } setp.ne.u32 %r976,%r975,0; @ %r976 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L154: .loc 1 1705 0 and.b32 %r977,%r314,256; setp.ne.u32 %r978,%r977,0; @ %r978 bra $L160; .loc 1 1706 0 st.u64 [%r322],%r313; cvt.s64.s32 %r227,%r321; st.u64 [%r322+8],%r227; add.u64 %r453,%r453,%r227; st.u64 [%frame+184],%r453; ld.u32 %r979,[%frame+176]; add.u32 %r230,%r979,1; st.u32 [%frame+176],%r230; setp.gt.s32 %r980,%r230,7; @ %r980 bra $L161; add.u64 %r322,%r322,16; bra $L162; $L161: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r985,[%value_in]; } setp.ne.u32 %r986,%r985,0; @ %r986 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L160: .loc 1 1708 0 setp.le.s32 %r987,%r311,101; @ %r987 bra $L163; .loc 1 1709 0 setp.neu.f64 %r988,%r335,0d0000000000000000; @ %r988 bra $L164; .loc 1 1711 0 cvta.const.u64 %r989,$LC7; st.u64 [%r322],%r989; mov.u64 %r990,1; st.u64 [%r322+8],%r990; add.u64 %r991,%r453,1; st.u64 [%frame+184],%r991; ld.u32 %r992,[%frame+176]; add.u32 %r234,%r992,1; st.u32 [%frame+176],%r234; setp.gt.s32 %r993,%r234,7; @ %r993 bra $L165; add.u64 %r322,%r322,16; bra $L166; $L165: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r998,[%value_in]; } setp.ne.u32 %r999,%r998,0; @ %r999 bra $L10; mov.u64 %r322,%frame; $L166: .loc 1 1712 0 ld.u32 %r1000,[%frame+212]; setp.lt.s32 %r1001,%r1000,%r401; @ %r1001 bra $L167; and.b32 %r1002,%r314,1; setp.ne.u32 %r1003,%r1002,0; @ %r1003 bra $L167; ld.u64 %r453,[%frame+184]; bra $L162; $L167: .loc 1 1713 0 st.u64 [%r322],%r327; st.u64 [%r322+8],%r507; ld.u64 %r1004,[%frame+184]; add.u64 %r453,%r507,%r1004; st.u64 [%frame+184],%r453; ld.u32 %r1005,[%frame+176]; add.u32 %r240,%r1005,1; st.u32 [%frame+176],%r240; setp.gt.s32 %r1006,%r240,7; @ %r1006 bra $L168; add.u64 %r322,%r322,16; bra $L169; $L168: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1011,[%value_in]; } setp.ne.u32 %r1012,%r1011,0; @ %r1012 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L169: .loc 1 1714 0 add.u32 %r284,%r401,-1; setp.le.s32 %r1013,%r284,0; @ %r1013 bra $L162; ld.u32 %r468,[%frame+176]; setp.le.s32 %r1014,%r284,16; @ ! %r1014 bra $L360; cvta.const.u64 %r1319,zeroes$4103; bra $L170; $L360: cvta.const.u64 %r1319,zeroes$4103; $L173: st.u64 [%r322],%r1319; mov.u64 %r1016,16; st.u64 [%r322+8],%r1016; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r468,%r468,1; st.u32 [%frame+176],%r468; setp.gt.s32 %r1017,%r468,7; @ %r1017 bra $L171; add.u64 %r322,%r322,16; bra $L172; $L171: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1022,[%value_in]; } setp.ne.u32 %r1023,%r1022,0; @ %r1023 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r468,[%frame+176]; mov.u64 %r322,%frame; $L172: add.u32 %r284,%r284,-16; setp.gt.s32 %r1024,%r284,16; @ %r1024 bra $L173; $L170: st.u64 [%r322],%r1319; cvt.s64.s32 %r244,%r284; st.u64 [%r322+8],%r244; add.u64 %r453,%r453,%r244; st.u64 [%frame+184],%r453; add.u32 %r245,%r468,1; st.u32 [%frame+176],%r245; setp.gt.s32 %r1026,%r245,7; @ %r1026 bra $L174; add.u64 %r322,%r322,16; bra $L162; $L174: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1031,[%value_in]; } setp.ne.u32 %r1032,%r1031,0; @ %r1032 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L164: .loc 1 1716 0 ld.u32 %r247,[%frame+212]; setp.gt.s32 %r1033,%r247,0; @ %r1033 bra $L175; .loc 1 1717 0 cvta.const.u64 %r1034,$LC7; st.u64 [%r322],%r1034; mov.u64 %r1035,1; st.u64 [%r322+8],%r1035; add.u64 %r453,%r453,1; st.u64 [%frame+184],%r453; ld.u32 %r1036,[%frame+176]; add.u32 %r249,%r1036,1; st.u32 [%frame+176],%r249; setp.gt.s32 %r1037,%r249,7; @ %r1037 bra $L176; add.u64 %r322,%r322,16; bra $L177; $L176: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1042,[%value_in]; } setp.ne.u32 %r1043,%r1042,0; @ %r1043 bra $L10; ld.u32 %r247,[%frame+212]; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L177: .loc 1 1718 0 or.b32 %r1044,%r401,%r247; setp.ne.u32 %r1045,%r1044,0; @ %r1045 bra $L178; and.b32 %r1046,%r314,1; setp.eq.u32 %r1047,%r1046,0; @ %r1047 bra $L162; $L178: .loc 1 1719 0 st.u64 [%r322],%r327; st.u64 [%r322+8],%r507; add.u64 %r466,%r507,%r453; st.u64 [%frame+184],%r466; ld.u32 %r1048,[%frame+176]; add.u32 %r467,%r1048,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1049,%r467,7; @ %r1049 bra $L179; add.u64 %r324,%r322,16; bra $L180; $L179: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1054,[%value_in]; } setp.ne.u32 %r1055,%r1054,0; @ %r1055 bra $L10; ld.u32 %r247,[%frame+212]; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r324,%frame; $L180: .loc 1 1720 0 setp.ge.s32 %r1056,%r247,0; @ %r1056 bra $L181; neg.s32 %r153,%r247; setp.ge.s32 %r1057,%r247,-16; @ ! %r1057 bra $L361; cvta.const.u64 %r1319,zeroes$4103; bra $L182; $L361: cvta.const.u64 %r1319,zeroes$4103; $L185: st.u64 [%r324],%r1319; mov.u64 %r1059,16; st.u64 [%r324+8],%r1059; add.u64 %r466,%r466,16; st.u64 [%frame+184],%r466; add.u32 %r467,%r467,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1060,%r467,7; @ %r1060 bra $L183; add.u64 %r324,%r324,16; bra $L184; $L183: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1065,[%value_in]; } setp.ne.u32 %r1066,%r1065,0; @ %r1066 bra $L10; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r324,%frame; $L184: add.u32 %r153,%r153,-16; setp.gt.s32 %r1067,%r153,16; @ %r1067 bra $L185; $L182: st.u64 [%r324],%r1319; cvt.s64.s32 %r255,%r153; st.u64 [%r324+8],%r255; add.u64 %r466,%r466,%r255; st.u64 [%frame+184],%r466; add.u32 %r467,%r467,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1069,%r467,7; @ %r1069 bra $L186; add.u64 %r324,%r324,16; bra $L181; $L186: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1074,[%value_in]; } setp.ne.u32 %r1075,%r1074,0; @ %r1075 bra $L10; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r324,%frame; $L181: .loc 1 1721 0 st.u64 [%r324],%r313; cvt.s64.s32 %r258,%r401; st.u64 [%r324+8],%r258; add.u64 %r453,%r258,%r466; st.u64 [%frame+184],%r453; add.u32 %r259,%r467,1; st.u32 [%frame+176],%r259; setp.gt.s32 %r1076,%r259,7; @ %r1076 bra $L187; add.u64 %r322,%r324,16; bra $L162; $L187: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1081,[%value_in]; } setp.ne.u32 %r1082,%r1081,0; @ %r1082 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L175: min.s32 %r334,%r150,%r401; .loc 1 1725 0 setp.le.s32 %r1083,%r334,0; @ %r1083 bra $L188; st.u64 [%r322],%r313; cvt.s64.s32 %r261,%r334; st.u64 [%r322+8],%r261; add.u64 %r453,%r453,%r261; st.u64 [%frame+184],%r453; ld.u32 %r1084,[%frame+176]; add.u32 %r263,%r1084,1; st.u32 [%frame+176],%r263; setp.gt.s32 %r1085,%r263,7; @ %r1085 bra $L189; add.u64 %r322,%r322,16; bra $L188; $L189: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1090,[%value_in]; } setp.ne.u32 %r1091,%r1090,0; @ %r1091 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L188: max.s32 %r265,%r334,0; sub.u32 %r228,%r150,%r265; setp.le.s32 %r1092,%r228,0; @ %r1092 bra $L190; ld.u32 %r465,[%frame+176]; setp.le.s32 %r1093,%r228,16; @ ! %r1093 bra $L362; cvta.const.u64 %r1319,zeroes$4103; bra $L191; $L362: cvta.const.u64 %r1319,zeroes$4103; $L194: st.u64 [%r322],%r1319; mov.u64 %r1095,16; st.u64 [%r322+8],%r1095; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r465,%r465,1; st.u32 [%frame+176],%r465; setp.gt.s32 %r1096,%r465,7; @ %r1096 bra $L192; add.u64 %r322,%r322,16; bra $L193; $L192: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1101,[%value_in]; } setp.ne.u32 %r1102,%r1101,0; @ %r1102 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r465,[%frame+176]; mov.u64 %r322,%frame; $L193: add.u32 %r228,%r228,-16; setp.gt.s32 %r1103,%r228,16; @ %r1103 bra $L194; $L191: st.u64 [%r322],%r1319; cvt.s64.s32 %r267,%r228; st.u64 [%r322+8],%r267; add.u64 %r453,%r453,%r267; st.u64 [%frame+184],%r453; add.u32 %r268,%r465,1; st.u32 [%frame+176],%r268; setp.gt.s32 %r1105,%r268,7; @ %r1105 bra $L195; add.u64 %r322,%r322,16; bra $L190; $L195: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1110,[%value_in]; } setp.ne.u32 %r1111,%r1110,0; @ %r1111 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L190: .loc 1 1746 0 ld.u32 %r271,[%frame+212]; setp.lt.s32 %r1112,%r271,%r401; @ %r1112 bra $L196; and.b32 %r1113,%r314,1; setp.eq.u32 %r1114,%r1113,0; @ %r1114 bra $L197; $L196: .loc 1 1747 0 st.u64 [%r322],%r327; st.u64 [%r322+8],%r507; add.u64 %r453,%r453,%r507; st.u64 [%frame+184],%r453; ld.u32 %r1115,[%frame+176]; add.u32 %r274,%r1115,1; st.u32 [%frame+176],%r274; setp.gt.s32 %r1116,%r274,7; @ %r1116 bra $L198; add.u64 %r322,%r322,16; bra $L197; $L198: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1121,[%value_in]; } setp.ne.u32 %r1122,%r1121,0; @ %r1122 bra $L10; ld.u32 %r271,[%frame+212]; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L197: .loc 1 1748 0 sub.u32 %r361,%r401,%r150; sub.u32 %r277,%r401,%r271; min.s32 %r340,%r277,%r361; setp.le.s32 %r1123,%r340,0; @ %r1123 bra $L199; .loc 1 1727 0 cvt.s64.s32 %r1124,%r150; add.u64 %r1125,%r313,%r1124; .loc 1 1748 0 st.u64 [%r322],%r1125; cvt.s64.s32 %r279,%r340; st.u64 [%r322+8],%r279; add.u64 %r453,%r453,%r279; st.u64 [%frame+184],%r453; ld.u32 %r1126,[%frame+176]; add.u32 %r281,%r1126,1; st.u32 [%frame+176],%r281; setp.gt.s32 %r1127,%r281,7; @ %r1127 bra $L200; add.u64 %r322,%r322,16; bra $L199; $L200: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1132,[%value_in]; } setp.ne.u32 %r1133,%r1132,0; @ %r1133 bra $L10; ld.u32 %r1134,[%frame+212]; sub.u32 %r277,%r401,%r1134; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L199: max.s32 %r283,%r340,0; sub.u32 %r354,%r277,%r283; setp.le.s32 %r1135,%r354,0; @ %r1135 bra $L162; ld.u32 %r464,[%frame+176]; setp.le.s32 %r1136,%r354,16; @ ! %r1136 bra $L363; cvta.const.u64 %r1319,zeroes$4103; bra $L201; $L363: cvta.const.u64 %r1319,zeroes$4103; $L204: st.u64 [%r322],%r1319; mov.u64 %r1138,16; st.u64 [%r322+8],%r1138; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r464,%r464,1; st.u32 [%frame+176],%r464; setp.gt.s32 %r1139,%r464,7; @ %r1139 bra $L202; add.u64 %r322,%r322,16; bra $L203; $L202: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1144,[%value_in]; } setp.ne.u32 %r1145,%r1144,0; @ %r1145 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r464,[%frame+176]; mov.u64 %r322,%frame; $L203: add.u32 %r354,%r354,-16; setp.gt.s32 %r1146,%r354,16; @ %r1146 bra $L204; $L201: st.u64 [%r322],%r1319; cvt.s64.s32 %r286,%r354; st.u64 [%r322+8],%r286; add.u64 %r453,%r453,%r286; st.u64 [%frame+184],%r453; add.u32 %r287,%r464,1; st.u32 [%frame+176],%r287; setp.gt.s32 %r1148,%r287,7; @ %r1148 bra $L205; add.u64 %r322,%r322,16; bra $L162; $L205: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1153,[%value_in]; } setp.ne.u32 %r1154,%r1153,0; @ %r1154 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; bra $L162; $L163: add.u64 %r460,%r453,1; ld.u32 %r485,[%frame+176]; add.u32 %r458,%r485,1; add.u64 %r293,%r322,16; .loc 1 1752 0 setp.gt.s32 %r1155,%r401,1; @ %r1155 bra $L206; and.b32 %r1156,%r314,1; setp.eq.u32 %r1157,%r1156,0; @ %r1157 bra $L207; $L206: .loc 1 1753 0 st.u64 [%r322],%r313; mov.u64 %r1158,1; st.u64 [%r322+8],%r1158; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r458; setp.le.s32 %r1159,%r458,7; @ %r1159 bra $L208; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1164,[%value_in]; } setp.ne.u32 %r1165,%r1164,0; @ %r1165 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r458,[%frame+176]; mov.u64 %r293,%frame; $L208: .loc 1 1755 0 st.u64 [%r293],%r327; st.u64 [%r293+8],%r507; add.u64 %r460,%r460,%r507; st.u64 [%frame+184],%r460; add.u32 %r461,%r458,1; st.u32 [%frame+176],%r461; setp.gt.s32 %r1166,%r461,7; @ %r1166 bra $L209; add.u64 %r293,%r293,16; bra $L210; $L209: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1171,[%value_in]; } setp.ne.u32 %r1172,%r1171,0; @ %r1172 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r461,[%frame+176]; mov.u64 %r293,%frame; $L210: add.u32 %r459,%r461,1; mov.u32 %r1327,%r459; add.u32 %r221,%r401,-1; add.u64 %r322,%r293,16; .loc 1 1756 0 setp.eq.f64 %r1173,%r335,0d0000000000000000; @ %r1173 bra $L211; .loc 1 1754 0 add.u64 %r1174,%r313,1; .loc 1 1757 0 st.u64 [%r293],%r1174; cvt.s64.s32 %r292,%r221; st.u64 [%r293+8],%r292; add.u64 %r460,%r460,%r292; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r459; setp.gt.s32 %r1175,%r459,7; @ %r1175 bra $L212; add.u32 %r459,%r461,2; add.u64 %r486,%r293,32; mov.u64 %r293,%r322; mov.u64 %r322,%r486; bra $L213; $L212: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1180,[%value_in]; } setp.ne.u32 %r1181,%r1180,0; @ %r1181 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r1182,[%frame+176]; add.u32 %r459,%r1182,1; add.u64 %r322,%frame,16; mov.u64 %r293,%frame; bra $L213; $L211: .loc 1 1760 0 setp.le.s32 %r1183,%r221,0; @ %r1183 bra $L213; setp.le.s32 %r1184,%r221,16; @ %r1184 bra $L256; cvta.const.u64 %r1319,zeroes$4103; $L217: st.u64 [%r293],%r1319; mov.u64 %r1186,16; st.u64 [%r293+8],%r1186; add.u64 %r460,%r460,16; st.u64 [%frame+184],%r460; mov.u32 %r461,%r1327; st.u32 [%frame+176],%r461; setp.gt.s32 %r1187,%r461,7; @ %r1187 bra $L215; add.u64 %r293,%r293,16; bra $L216; $L215: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1192,[%value_in]; } setp.ne.u32 %r1193,%r1192,0; @ %r1193 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r461,[%frame+176]; mov.u64 %r293,%frame; $L216: add.u32 %r221,%r221,-16; setp.gt.s32 %r1194,%r221,16; @ ! %r1194 bra $L364; add.u32 %r1327,%r461,1; bra $L217; $L364: add.u32 %r459,%r461,1; add.u64 %r462,%r293,16; bra $L214; $L256: mov.u64 %r462,%r322; cvta.const.u64 %r1319,zeroes$4103; $L214: st.u64 [%r293],%r1319; cvt.s64.s32 %r297,%r221; st.u64 [%r293+8],%r297; add.u64 %r460,%r460,%r297; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r459; setp.gt.s32 %r1196,%r459,7; @ %r1196 bra $L218; add.u32 %r459,%r459,1; add.u64 %r322,%r462,16; mov.u64 %r293,%r462; bra $L213; $L218: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1201,[%value_in]; } setp.ne.u32 %r1202,%r1201,0; @ %r1202 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r1203,[%frame+176]; add.u32 %r459,%r1203,1; add.u64 %r322,%frame,16; mov.u64 %r293,%frame; bra $L213; $L207: .loc 1 1762 0 st.u64 [%r322],%r313; mov.u64 %r1204,1; st.u64 [%r322+8],%r1204; st.u64 [%frame+184],%r460; st.u32 [%frame+176],%r458; setp.gt.s32 %r1205,%r458,7; @ %r1205 bra $L219; add.u32 %r459,%r485,2; add.u64 %r322,%r322,32; bra $L213; $L219: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1210,[%value_in]; } setp.ne.u32 %r1211,%r1210,0; @ %r1211 bra $L10; ld.u64 %r460,[%frame+184]; ld.u32 %r1212,[%frame+176]; add.u32 %r459,%r1212,1; add.u64 %r322,%frame,16; mov.u64 %r293,%frame; $L213: .loc 1 1763 0 st.u64 [%r293],%r1354; cvt.s64.s32 %r300,%r317; st.u64 [%r293+8],%r300; add.u64 %r453,%r300,%r460; st.u64 [%frame+184],%r453; st.u32 [%frame+176],%r459; setp.le.s32 %r1214,%r459,7; @ %r1214 bra $L162; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1219,[%value_in]; } setp.ne.u32 %r1220,%r1219,0; @ %r1220 bra $L10; ld.u64 %r453,[%frame+184]; mov.u64 %r322,%frame; $L162: .loc 1 1770 0 and.b32 %r1221,%r314,4; setp.eq.u32 %r1222,%r1221,0; @ %r1222 bra $L220; .loc 1 1771 0 sub.u32 %r152,%r315,%r320; setp.le.s32 %r1223,%r152,0; @ %r1223 bra $L220; ld.u32 %r454,[%frame+176]; setp.le.s32 %r1224,%r152,16; @ ! %r1224 bra $L365; cvta.const.u64 %r1318,blanks$4102; bra $L221; $L365: cvta.const.u64 %r1318,blanks$4102; $L224: st.u64 [%r322],%r1318; mov.u64 %r1226,16; st.u64 [%r322+8],%r1226; add.u64 %r453,%r453,16; st.u64 [%frame+184],%r453; add.u32 %r454,%r454,1; st.u32 [%frame+176],%r454; setp.gt.s32 %r1227,%r454,7; @ %r1227 bra $L222; add.u64 %r322,%r322,16; bra $L223; $L222: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1232,[%value_in]; } setp.ne.u32 %r1233,%r1232,0; @ %r1233 bra $L10; ld.u64 %r453,[%frame+184]; ld.u32 %r454,[%frame+176]; mov.u64 %r322,%frame; $L223: add.u32 %r152,%r152,-16; setp.gt.s32 %r1234,%r152,16; @ %r1234 bra $L224; $L221: st.u64 [%r322],%r1318; cvt.s64.s32 %r304,%r152; st.u64 [%r322+8],%r304; add.u64 %r453,%r453,%r304; st.u64 [%frame+184],%r453; add.u32 %r305,%r454,1; st.u32 [%frame+176],%r305; setp.le.s32 %r1236,%r305,7; @ %r1236 bra $L220; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1241,[%value_in]; } setp.ne.u32 %r1242,%r1241,0; @ %r1242 bra $L10; ld.u64 %r453,[%frame+184]; $L220: .loc 1 1774 0 max.s32 %r1243,%r315,%r320; add.u32 %r489,%r489,%r1243; .loc 1 1776 0 setp.ne.u64 %r1244,%r453,0; @ %r1244 bra $L225; $L226: mov.u32 %r1245,0; st.u32 [%frame+176],%r1245; mov.u64 %r322,%frame; bra $L5; $L225: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1353; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1250,[%value_in]; } setp.ne.u32 %r1251,%r1250,0; @ ! %r1251 bra $L226; .loc 1 1785 0 bra $L10; $L11: .loc 1 1784 0 ld.u64 %r1252,[%frame+184]; setp.eq.u64 %r1253,%r1252,0; @ %r1253 bra $L10; add.u64 %r1257,%frame,168; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r491; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1257; call (%value_in),__ssprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1258,[%value_in]; } $L10: .loc 1 1791 0 ld.u16 %r1260,[%r491+16]; and.b16 %r1259,%r1260,64; setp.ne.u16 %r1261,%r1259,0; selp.u32 %r489,-1,%r489,%r1261; bra $L1; $L258: .loc 1 1882 0 mov.u32 %r371,%r316; $L79: .loc 1 1883 0 cvt.s64.s32 %r1263,%r371; add.u64 %r375,%r313,%r1263; bra $L227; $L78: .loc 1 1880 0 mov.u32 %r1266,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r368; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1266; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r316; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1359; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1358; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1357; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1274,[%value_in]; } mov.u64 %r313,%r1274; .loc 1 1882 0 setp.ne.u32 %r1329,%r448,71; @ ! %r1329 bra $L366; bra $L258; $L77: .loc 1 1880 0 mov.u32 %r1278,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r490; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r368; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1278; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r316; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1359; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1358; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1357; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1286,[%value_in]; } mov.u64 %r313,%r1286; .loc 1 1883 0 cvt.s64.s32 %r353,%r316; .loc 1 1885 0 ld.s8 %r1289,[%r1286]; cvt.u16.u32 %r1288,%r1289; set.u32.eq.u16 %r1290,%r1288,48; neg.s32 %r1291,%r1290; set.u32.neu.f64 %r1293,%r368,0d0000000000000000; neg.s32 %r1294,%r1293; cvt.u16.u32 %r1296,%r1291; cvt.u16.u32 %r1297,%r1294; and.b16 %r1295,%r1296,%r1297; cvt.u32.u16 %r1298,%r1295; cvt.u16.u8 %r1299,%r1298; setp.ne.u16 %r1300,%r1299,0; @ ! %r1300 bra $L367; bra $L229; $L65: .loc 1 1565 0 setp.ne.u32 %r1302,%r316,-1; @ %r1302 bra $L231; ld.s8 %r452,[%frame+218]; bra $L128; $L232: .loc 1 1883 0 cvt.s64.s32 %r1303,%r316; add.u64 %r375,%r313,%r1303; bra $L227; $L366: .loc 1 1882 0 and.b32 %r1304,%r314,1; setp.ne.u32 %r1305,%r1304,0; @ %r1305 bra $L232; bra $L368; $L231: .loc 1 1566 0 and.b32 %r350,%r314,-129; .loc 1 1574 0 set.u32.ne.u32 %r1307,%r316,0; neg.s32 %r1308,%r1307; set.u32.ne.u64 %r1310,%r318,0; neg.s32 %r1311,%r1310; cvt.u16.u32 %r1313,%r1308; cvt.u16.u32 %r1314,%r1311; or.b16 %r1312,%r1313,%r1314; cvt.u32.u16 %r1315,%r1312; cvt.u16.u8 %r1316,%r1315; setp.ne.u16 %r1317,%r1316,0; @ ! %r1317 bra $L235; bra $L259; $L1: .loc 1 1793 0 mov.u32 %value,%r489; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } lib_a-swab.o/ 0 0 0 644 1674 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: swab .visible .func swab (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/swab.c" // BEGIN GLOBAL FUNCTION DEF: swab .visible .func swab (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u32 %r55; .reg .u64 %r56; .reg .u64 %r57; .reg .u64 %r58; .reg .u64 %r60; .reg .u64 %r62; .reg .u64 %r67; .reg .u64 %r70; .reg .u64 %r73; .reg .u64 %r74; .reg .u64 %r75; .reg .pred %r76; .reg .u64 %r77; .reg .u64 %r78; .reg .u32 %r79; .reg .u32 %r80; .reg .pred %r81; .reg .u64 %r83; .reg .pred %r84; .reg .u64 %r85; .reg .u64 %r86; .reg .u32 %r87; mov.u64 %r73,%ar0; mov.u64 %r74,%ar1; mov.u64 %r75,%ar2; .loc 1 35 0 setp.le.s64 %r76,%r75,1; @ %r76 bra $L5; mov.u64 %r58,%r73; mov.u64 %r57,%r74; add.u64 %r60,%r58,1; add.u64 %r62,%r74,1; add.u64 %r67,%r75,-2; and.b64 %r77,%r67,-2; add.u64 %r78,%r77,%r74; add.u64 %r70,%r78,2; $L3: .loc 1 38 0 ld.s8 %r55,[%r58]; .loc 1 39 0 ld.u8 %r79,[%r60]; st.u8 [%r57],%r79; .loc 1 40 0 cvt.u32.u32 %r80,%r55; st.u8 [%r62],%r80; add.u64 %r58,%r58,2; add.u64 %r57,%r57,2; add.u64 %r60,%r60,2; add.u64 %r62,%r62,2; .loc 1 35 0 setp.ne.u64 %r81,%r57,%r70; @ %r81 bra $L3; and.b64 %r83,%r67,-2; add.u64 %r56,%r83,3; bra $L2; $L5: mov.u64 %r56,1; $L2: .loc 1 42 0 setp.ne.u64 %r84,%r75,%r56; @ %r84 bra $L1; .loc 1 43 0 add.u64 %r85,%r74,%r75; add.u64 %r86,%r85,-1; mov.u32 %r87,0; st.u8 [%r86],%r87; $L1: .loc 1 44 0 ret; } /866 0 0 0 644 7292 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: __get_current_time_locale .visible .func (.param .u64 %value_out) __get_current_time_locale; .file 1 "../../../../../../newlib/libc/locale/timelocal.c" // BEGIN GLOBAL FUNCTION DECL: __time_load_locale .visible .func (.param .u32 %value_out) __time_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __part_load_locale .extern .func (.param .u32 %value_out) __part_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u32 %in_ar4, .param .u32 %in_ar5, .param .u64 %in_ar6); // BEGIN VAR DEF: _time_locale .global .align 8 .u64 _time_locale[63]; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {77,97,114,0 }; // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[8] = {76,67,95,84,73,77,69,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {74,97,110,0 }; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[4] = {70,101,98,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[4] = {65,112,114,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[4] = {77,97,121,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[4] = {74,117,110,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[4] = {74,117,108,0 }; // BEGIN VAR DEF: $LC8 .const .align 1 .u8 $LC8[4] = {65,117,103,0 }; // BEGIN VAR DEF: $LC9 .const .align 1 .u8 $LC9[4] = {83,101,112,0 }; // BEGIN VAR DEF: $LC10 .const .align 1 .u8 $LC10[4] = {79,99,116,0 }; // BEGIN VAR DEF: $LC11 .const .align 1 .u8 $LC11[4] = {78,111,118,0 }; // BEGIN VAR DEF: $LC12 .const .align 1 .u8 $LC12[4] = {68,101,99,0 }; // BEGIN VAR DEF: $LC13 .const .align 1 .u8 $LC13[8] = {74,97,110,117,97,114,121,0 }; // BEGIN VAR DEF: $LC14 .const .align 1 .u8 $LC14[9] = {70,101,98,114,117,97,114,121,0 }; // BEGIN VAR DEF: $LC15 .const .align 1 .u8 $LC15[6] = {77,97,114,99,104,0 }; // BEGIN VAR DEF: $LC16 .const .align 1 .u8 $LC16[6] = {65,112,114,105,108,0 }; // BEGIN VAR DEF: $LC17 .const .align 1 .u8 $LC17[5] = {74,117,110,101,0 }; // BEGIN VAR DEF: $LC18 .const .align 1 .u8 $LC18[5] = {74,117,108,121,0 }; // BEGIN VAR DEF: $LC19 .const .align 1 .u8 $LC19[7] = {65,117,103,117,115,116,0 }; // BEGIN VAR DEF: $LC20 .const .align 1 .u8 $LC20[10] = {83,101,112,116,101,109,98,101,114,0 }; // BEGIN VAR DEF: $LC21 .const .align 1 .u8 $LC21[8] = {79,99,116,111,98,101,114,0 }; // BEGIN VAR DEF: $LC22 .const .align 1 .u8 $LC22[9] = {78,111,118,101,109,98,101,114,0 }; // BEGIN VAR DEF: $LC23 .const .align 1 .u8 $LC23[9] = {68,101,99,101,109,98,101,114,0 }; // BEGIN VAR DEF: $LC24 .const .align 1 .u8 $LC24[4] = {83,117,110,0 }; // BEGIN VAR DEF: $LC25 .const .align 1 .u8 $LC25[4] = {77,111,110,0 }; // BEGIN VAR DEF: $LC26 .const .align 1 .u8 $LC26[4] = {84,117,101,0 }; // BEGIN VAR DEF: $LC27 .const .align 1 .u8 $LC27[4] = {87,101,100,0 }; // BEGIN VAR DEF: $LC28 .const .align 1 .u8 $LC28[4] = {84,104,117,0 }; // BEGIN VAR DEF: $LC29 .const .align 1 .u8 $LC29[4] = {70,114,105,0 }; // BEGIN VAR DEF: $LC30 .const .align 1 .u8 $LC30[4] = {83,97,116,0 }; // BEGIN VAR DEF: $LC31 .const .align 1 .u8 $LC31[7] = {83,117,110,100,97,121,0 }; // BEGIN VAR DEF: $LC32 .const .align 1 .u8 $LC32[7] = {77,111,110,100,97,121,0 }; // BEGIN VAR DEF: $LC33 .const .align 1 .u8 $LC33[8] = {84,117,101,115,100,97,121,0 }; // BEGIN VAR DEF: $LC34 .const .align 1 .u8 $LC34[10] = {87,101,100,110,101,115,100,97,121,0 }; // BEGIN VAR DEF: $LC35 .const .align 1 .u8 $LC35[9] = {84,104,117,114,115,100,97,121,0 }; // BEGIN VAR DEF: $LC36 .const .align 1 .u8 $LC36[7] = {70,114,105,100,97,121,0 }; // BEGIN VAR DEF: $LC37 .const .align 1 .u8 $LC37[9] = {83,97,116,117,114,100,97,121,0 }; // BEGIN VAR DEF: $LC38 .const .align 1 .u8 $LC38[9] = {37,72,58,37,77,58,37,83,0 }; // BEGIN VAR DEF: $LC39 .const .align 1 .u8 $LC39[9] = {37,109,47,37,100,47,37,121,0 }; // BEGIN VAR DEF: $LC40 .const .align 1 .u8 $LC40[21] = {37,97,32,37,98,32,37,101,32,37,72,58,37,77,58,37,83,32,37,89,0 }; // BEGIN VAR DEF: $LC41 .const .align 1 .u8 $LC41[3] = {65,77,0 }; // BEGIN VAR DEF: $LC42 .const .align 1 .u8 $LC42[3] = {80,77,0 }; // BEGIN VAR DEF: $LC43 .const .align 1 .u8 $LC43[24] = {37,97,32,37,98,32,37,101,32,37,72,58,37,77,58,37,83,32,37,90,32,37,89,0 }; // BEGIN VAR DEF: $LC44 .const .align 1 .u8 $LC44[3] = {109,100,0 }; // BEGIN VAR DEF: $LC45 .const .align 1 .u8 $LC45[12] = {37,73,58,37,77,58,37,83,32,37,112,0 }; // BEGIN VAR DEF: $LC46 .const .align 1 .u8 $LC46[1] = {0 }; // BEGIN VAR DEF: _C_time_locale .const .align 8 .u64 _C_time_locale[63] = {generic($LC1),generic($LC2),generic($LC3),generic($LC4),generic($LC5),generic($LC6),generic($LC7),generic($LC8),generic($LC9),generic($LC10),generic($LC11),generic($LC12),generic($LC13),generic($LC14),generic($LC15),generic($LC16),generic($LC5),generic($LC17),generic($LC18),generic($LC19),generic($LC20),generic($LC21),generic($LC22),generic($LC23),generic($LC24),generic($LC25),generic($LC26),generic($LC27),generic($LC28),generic($LC29),generic($LC30),generic($LC31),generic($LC32),generic($LC33),generic($LC34),generic($LC35),generic($LC36),generic($LC37),generic($LC38),generic($LC39),generic($LC40),generic($LC41),generic($LC42),generic($LC43),generic($LC13),generic($LC14),generic($LC15),generic($LC16),generic($LC5),generic($LC17),generic($LC18),generic($LC19),generic($LC20),generic($LC21),generic($LC22),generic($LC23),generic($LC44),generic($LC45),generic($LC46),generic($LC46),generic($LC46),generic($LC46),generic($LC46) }; // BEGIN VAR DEF: _time_using_locale .global .align 4 .u32 _time_using_locale[1]; // BEGIN GLOBAL FUNCTION DEF: __get_current_time_locale .visible .func (.param .u64 %value_out) __get_current_time_locale { .reg .u64 %value; .reg .u64 %r23; .reg .u32 %r24; .reg .pred %r25; .loc 1 156 0 ld.global.u32 %r24,[_time_using_locale]; setp.ne.u32 %r25,%r24,0; @ %r25 bra $L3; cvta.const.u64 %r23,_C_time_locale; bra $L1; $L3: cvta.global.u64 %r23,_time_locale; $L1: .loc 1 157 0 mov.u64 %value,%r23; st.param.u64 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: __time_load_locale .visible .func (.param .u32 %value_out) __time_load_locale (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r23; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u32 %r31; .reg .u64 %r32; .reg .u32 %r33; mov.u64 %r23,%ar0; .loc 1 182 0 cvta.global.u64 %r32,_time_locale; mov.u32 %r31,63; cvta.const.u64 %r29,$LC0; mov.u64 %r28,0; cvta.global.u64 %r27,_time_using_locale; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r27; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r28; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r29; .param .u32 %out_arg5; st.param.u32 [%out_arg5],%r31; .param .u32 %out_arg6; st.param.u32 [%out_arg6],%r31; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r32; call (%value_in),__part_load_locale,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u32 %r33,[%value_in]; } .loc 1 188 0 mov.u32 %value,%r33; st.param.u32 [%value_out],%value; ret; } lib_a-tolower.o/0 0 0 644 1067 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: tolower .visible .func (.param .u32 %value_out) tolower (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/tolower.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: tolower .visible .func (.param .u32 %value_out) tolower (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u16 %r42; mov.u32 %r29,%ar0; .loc 1 74 0 cvt.s64.s32 %r30,%r29; ld.global.u64 %r31,[__ctype_ptr__]; add.u64 %r32,%r31,%r30; ld.u8 %r42,[%r32+1]; mov.u16 %r36,%r42; and.b16 %r35,%r36,3; cvt.u32.u16 %r39,%r35; cvt.s32.s8 %r38,%r39; cvt.u16.u32 %r37,%r38; setp.ne.u16 %r40,%r37,1; @ %r40 bra $L2; add.u32 %r29,%r29,32; $L2: .loc 1 76 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } lib_a-toupper.o/0 0 0 644 1068 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: toupper .visible .func (.param .u32 %value_out) toupper (.param .u32 %in_ar0); .file 1 "../../../../../../newlib/libc/ctype/toupper.c" // BEGIN GLOBAL VAR DECL: __ctype_ptr__ .extern .global .align 8 .u64 __ctype_ptr__[1]; // BEGIN GLOBAL FUNCTION DEF: toupper .visible .func (.param .u32 %value_out) toupper (.param .u32 %in_ar0) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .u64 %r32; .reg .u16 %r35; .reg .u16 %r36; .reg .u16 %r37; .reg .u32 %r38; .reg .u32 %r39; .reg .pred %r40; .reg .u16 %r42; mov.u32 %r29,%ar0; .loc 1 73 0 cvt.s64.s32 %r30,%r29; ld.global.u64 %r31,[__ctype_ptr__]; add.u64 %r32,%r31,%r30; ld.u8 %r42,[%r32+1]; mov.u16 %r36,%r42; and.b16 %r35,%r36,3; cvt.u32.u16 %r39,%r35; cvt.s32.s8 %r38,%r39; cvt.u16.u32 %r37,%r38; setp.ne.u16 %r40,%r37,2; @ %r40 bra $L2; add.u32 %r29,%r29,-32; $L2: .loc 1 75 0 mov.u32 %value,%r29; st.param.u32 [%value_out],%value; ret; } /885 0 0 0 644 703 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _user_strerror .visible .func (.param .u64 %value_out) _user_strerror (.param .u32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../newlib/libc/string/u_strerr.c" // BEGIN GLOBAL FUNCTION DEF: _user_strerror .visible .func (.param .u64 %value_out) _user_strerror (.param .u32 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2) { .reg .u64 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u32 %ar1; ld.param.u32 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .loc 1 9 0 mov.u64 %value,0; .loc 1 10 0 st.param.u64 [%value_out],%value; ret; } /903 0 0 0 644 80325 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: _vfprintf_r .visible .func (.param .u32 %value_out) _vfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdio/vfprintf.c" // BEGIN GLOBAL FUNCTION DECL: vfprintf .visible .func (.param .u32 %value_out) vfprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN FUNCTION DECL: __sbprintf .func (.param .u32 %value_out) __sbprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _localeconv_r .extern .func (.param .u64 %value_out) _localeconv_r (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __sinit .extern .func __sinit (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __swsetup_r .extern .func (.param .u32 %value_out) __swsetup_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DECL: __sprint_r .extern .func (.param .u32 %value_out) __sprint_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: __fpclassifyd .extern .func (.param .u32 %value_out) __fpclassifyd (.param .f64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: _dtoa_r .extern .func (.param .u64 %value_out) _dtoa_r (.param .u64 %in_ar0, .param .f64 %in_ar1, .param .u32 %in_ar2, .param .u32 %in_ar3, .param .u64 %in_ar4, .param .u64 %in_ar5, .param .u64 %in_ar6); // BEGIN GLOBAL FUNCTION DECL: memchr .extern .func (.param .u64 %value_out) memchr (.param .u64 %in_ar0, .param .u32 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL FUNCTION DECL: _fflush_r .extern .func (.param .u32 %value_out) _fflush_r (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN VAR DEF: $LC2 .const .align 1 .u8 $LC2[4] = {78,65,78,0 }; // BEGIN VAR DEF: blanks$4117 .const .align 1 .u8 blanks$4117[16] = {32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 }; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[4] = {73,78,70,0 }; // BEGIN VAR DEF: $LC1 .const .align 1 .u8 $LC1[4] = {105,110,102,0 }; // BEGIN VAR DEF: zeroes$4118 .const .align 1 .u8 zeroes$4118[16] = {48,48,48,48,48,48,48,48,48,48,48,48,48,48,48,48 }; // BEGIN VAR DEF: $LC3 .const .align 1 .u8 $LC3[4] = {110,97,110,0 }; // BEGIN VAR DEF: $LC4 .const .align 1 .u8 $LC4[17] = {48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,0 }; // BEGIN VAR DEF: $LC5 .const .align 1 .u8 $LC5[17] = {48,49,50,51,52,53,54,55,56,57,97,98,99,100,101,102,0 }; // BEGIN VAR DEF: $LC6 .const .align 1 .u8 $LC6[7] = {40,110,117,108,108,41,0 }; // BEGIN VAR DEF: $LC7 .const .align 1 .u8 $LC7[2] = {48,0 }; // BEGIN GLOBAL FUNCTION DEF: _vfprintf_r .visible .func (.param .u32 %value_out) _vfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,224; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r116; .reg .u64 %r117; .reg .u64 %r126; .reg .u32 %r130; .reg .u32 %r133; .reg .u32 %r156; .reg .u32 %r158; .reg .u32 %r159; .reg .u32 %r195; .reg .u64 %r206; .reg .u32 %r208; .reg .u32 %r209; .reg .u64 %r211; .reg .u32 %r212; .reg .u32 %r215; .reg .u32 %r219; .reg .u64 %r222; .reg .u32 %r224; .reg .u64 %r227; .reg .u32 %r228; .reg .u64 %r231; .reg .u32 %r233; .reg .u32 %r234; .reg .u32 %r238; .reg .u32 %r244; .reg .u64 %r247; .reg .u32 %r249; .reg .u32 %r251; .reg .u32 %r253; .reg .u32 %r254; .reg .u64 %r260; .reg .u32 %r261; .reg .u64 %r263; .reg .u32 %r264; .reg .u64 %r266; .reg .u32 %r268; .reg .u32 %r270; .reg .u64 %r272; .reg .u32 %r273; .reg .u32 %r276; .reg .u32 %r279; .reg .u32 %r281; .reg .u32 %r282; .reg .u32 %r283; .reg .u64 %r284; .reg .u32 %r286; .reg .u32 %r288; .reg .u64 %r290; .reg .u32 %r291; .reg .u64 %r296; .reg .u64 %r298; .reg .u64 %r301; .reg .u64 %r305; .reg .u64 %r309; .reg .u32 %r310; .reg .u32 %r316; .reg .u64 %r317; .reg .u64 %r318; .reg .u64 %r319; .reg .u32 %r320; .reg .u32 %r321; .reg .u32 %r322; .reg .u32 %r323; .reg .u64 %r324; .reg .u32 %r325; .reg .u32 %r326; .reg .u32 %r327; .reg .u64 %r328; .reg .u32 %r329; .reg .u64 %r330; .reg .u32 %r332; .reg .u64 %r334; .reg .u64 %r337; .reg .u32 %r342; .reg .f64 %r343; .reg .u32 %r348; .reg .u32 %r350; .reg .u64 %r351; .reg .u32 %r355; .reg .u32 %r357; .reg .u64 %r359; .reg .u64 %r360; .reg .u64 %r361; .reg .u64 %r362; .reg .u32 %r363; .reg .u32 %r365; .reg .u32 %r368; .reg .f64 %r375; .reg .u64 %r376; .reg .u64 %r377; .reg .u32 %r378; .reg .u64 %r382; .reg .u32 %r388; .reg .u64 %r392; .reg .u32 %r397; .reg .u64 %r401; .reg .u64 %r405; .reg .u32 %r406; .reg .u32 %r407; .reg .u64 %r408; .reg .u64 %r409; .reg .u64 %r410; .reg .u64 %r412; .reg .u64 %r413; .reg .u64 %r414; .reg .u64 %r415; .reg .u64 %r416; .reg .u64 %r417; .reg .u64 %r418; .reg .u64 %r421; .reg .u64 %r425; .reg .u64 %r426; .reg .u64 %r428; .reg .u64 %r429; .reg .u64 %r430; .reg .u64 %r431; .reg .u64 %r433; .reg .u64 %r440; .reg .u32 %r447; .reg .u64 %r449; .reg .u64 %r450; .reg .u64 %r453; .reg .u32 %r454; .reg .u32 %r456; .reg .u32 %r457; .reg .u32 %r458; .reg .u64 %r459; .reg .u32 %r460; .reg .u32 %r464; .reg .u32 %r465; .reg .u64 %r466; .reg .u32 %r467; .reg .u64 %r468; .reg .u32 %r470; .reg .u32 %r471; .reg .u64 %r472; .reg .u32 %r473; .reg .u32 %r474; .reg .u32 %r475; .reg .u32 %r476; .reg .u32 %r477; .reg .u32 %r486; .reg .u32 %r487; .reg .u32 %r488; .reg .u32 %r489; .reg .u32 %r490; .reg .u32 %r491; .reg .u64 %r492; .reg .u32 %r495; .reg .u64 %r496; .reg .u64 %r497; .reg .u64 %r498; .reg .u64 %r499; .reg .u64 %r511; .reg .u64 %r513; .reg .pred %r514; .reg .u32 %r515; .reg .pred %r516; .reg .u16 %r518; .reg .u16 %r519; .reg .pred %r520; .reg .u16 %r521; .reg .u32 %r524; .reg .u32 %r525; .reg .u16 %r526; .reg .u16 %r527; .reg .pred %r528; .reg .u64 %r529; .reg .pred %r530; .reg .u32 %r533; .reg .pred %r534; .reg .u16 %r535; .reg .u16 %r536; .reg .pred %r537; .reg .u16 %r538; .reg .pred %r539; .reg .u32 %r544; .reg .u64 %r545; .reg .u32 %r546; .reg .u16 %r548; .reg .u32 %r549; .reg .u32 %r550; .reg .u32 %r553; .reg .u32 %r554; .reg .u16 %r555; .reg .u16 %r556; .reg .u16 %r557; .reg .u32 %r558; .reg .u16 %r559; .reg .pred %r560; .reg .u16 %r562; .reg .u32 %r563; .reg .u32 %r564; .reg .u32 %r567; .reg .u32 %r568; .reg .u16 %r569; .reg .u16 %r570; .reg .u16 %r571; .reg .u32 %r572; .reg .u16 %r573; .reg .pred %r574; .reg .u64 %r575; .reg .pred %r576; .reg .u64 %r577; .reg .u64 %r578; .reg .u32 %r579; .reg .pred %r580; .reg .u32 %r585; .reg .pred %r586; .reg .u16 %r587; .reg .u32 %r588; .reg .pred %r589; .reg .u32 %r590; .reg .pred %r591; .reg .pred %r592; .reg .pred %r593; .reg .pred %r594; .reg .pred %r595; .reg .pred %r596; .reg .pred %r597; .reg .pred %r598; .reg .pred %r599; .reg .pred %r600; .reg .pred %r601; .reg .pred %r602; .reg .pred %r603; .reg .pred %r604; .reg .pred %r605; .reg .pred %r606; .reg .pred %r607; .reg .pred %r608; .reg .pred %r609; .reg .pred %r610; .reg .pred %r611; .reg .pred %r612; .reg .pred %r613; .reg .pred %r614; .reg .pred %r615; .reg .pred %r616; .reg .pred %r617; .reg .pred %r618; .reg .pred %r619; .reg .pred %r620; .reg .pred %r621; .reg .pred %r622; .reg .pred %r623; .reg .pred %r624; .reg .pred %r625; .reg .pred %r626; .reg .u32 %r627; .reg .pred %r628; .reg .u32 %r629; .reg .pred %r630; .reg .pred %r631; .reg .pred %r632; .reg .pred %r633; .reg .u32 %r634; .reg .u32 %r636; .reg .u32 %r637; .reg .u32 %r638; .reg .pred %r639; .reg .u32 %r641; .reg .u32 %r642; .reg .u32 %r643; .reg .pred %r646; .reg .u16 %r647; .reg .pred %r648; .reg .u32 %r649; .reg .u32 %r650; .reg .pred %r651; .reg .u32 %r652; .reg .u32 %r653; .reg .pred %r654; .reg .u32 %r655; .reg .pred %r656; .reg .u32 %r657; .reg .pred %r658; .reg .u16 %r659; .reg .pred %r660; .reg .u32 %r661; .reg .pred %r662; .reg .u32 %r663; .reg .u64 %r664; .reg .u32 %r668; .reg .pred %r669; .reg .pred %r670; .reg .u32 %r671; .reg .pred %r672; .reg .u32 %r674; .reg .pred %r675; .reg .pred %r676; .reg .pred %r677; .reg .u32 %r679; .reg .u32 %r680; .reg .u32 %r682; .reg .u32 %r683; .reg .u16 %r684; .reg .u16 %r685; .reg .u16 %r686; .reg .u32 %r687; .reg .u16 %r688; .reg .pred %r689; .reg .u64 %r690; .reg .u64 %r691; .reg .u32 %r692; .reg .pred %r693; .reg .pred %r694; .reg .pred %r695; .reg .u32 %r698; .reg .u64 %r706; .reg .u32 %r707; .reg .u64 %r708; .reg .u64 %r709; .reg .pred %r710; .reg .u64 %r711; .reg .u32 %r712; .reg .pred %r713; .reg .pred %r714; .reg .u64 %r715; .reg .u32 %r718; .reg .u32 %r719; .reg .u32 %r721; .reg .u32 %r722; .reg .u16 %r723; .reg .u16 %r724; .reg .u16 %r725; .reg .u32 %r726; .reg .u16 %r727; .reg .pred %r728; .reg .pred %r729; .reg .pred %r730; .reg .u32 %r731; .reg .u32 %r732; .reg .u32 %r733; .reg .pred %r734; .reg .u32 %r738; .reg .u16 %r740; .reg .u16 %r741; .reg .u32 %r742; .reg .pred %r747; .reg .u16 %r749; .reg .u16 %r750; .reg .u32 %r751; .reg .pred %r755; .reg .u32 %r757; .reg .pred %r760; .reg .u64 %r767; .reg .u32 %r768; .reg .u16 %r770; .reg .u16 %r771; .reg .u32 %r772; .reg .u64 %r774; .reg .pred %r775; .reg .pred %r776; .reg .pred %r777; .reg .pred %r778; .reg .u32 %r779; .reg .pred %r780; .reg .u32 %r781; .reg .pred %r782; .reg .u32 %r783; .reg .pred %r784; .reg .pred %r785; .reg .u32 %r786; .reg .pred %r787; .reg .pred %r788; .reg .u32 %r789; .reg .pred %r790; .reg .u32 %r791; .reg .pred %r792; .reg .u32 %r793; .reg .u64 %r794; .reg .u32 %r795; .reg .pred %r796; .reg .u64 %r797; .reg .u32 %r798; .reg .pred %r799; .reg .u64 %r800; .reg .u32 %r801; .reg .pred %r802; .reg .u32 %r803; .reg .pred %r804; .reg .u32 %r805; .reg .pred %r806; .reg .u32 %r807; .reg .pred %r808; .reg .u16 %r809; .reg .u32 %r810; .reg .u32 %r811; .reg .u32 %r812; .reg .pred %r813; .reg .pred %r814; .reg .u32 %r816; .reg .u64 %r818; .reg .u64 %r819; .reg .pred %r820; .reg .u64 %r821; .reg .u32 %r822; .reg .u64 %r824; .reg .u32 %r825; .reg .pred %r826; .reg .u32 %r827; .reg .pred %r828; .reg .u32 %r829; .reg .pred %r830; .reg .u16 %r831; .reg .pred %r832; .reg .u32 %r833; .reg .u32 %r834; .reg .pred %r835; .reg .u32 %r836; .reg .pred %r837; .reg .u32 %r838; .reg .pred %r839; .reg .u16 %r840; .reg .u32 %r841; .reg .pred %r842; .reg .pred %r843; .reg .u32 %r844; .reg .u32 %r845; .reg .pred %r847; .reg .u32 %r849; .reg .u32 %r850; .reg .u32 %r852; .reg .u32 %r853; .reg .u16 %r854; .reg .u16 %r855; .reg .u16 %r856; .reg .u32 %r857; .reg .u16 %r858; .reg .pred %r859; .reg .u16 %r860; .reg .pred %r861; .reg .pred %r863; .reg .u16 %r865; .reg .u16 %r866; .reg .u16 %r868; .reg .u32 %r870; .reg .pred %r872; .reg .u16 %r874; .reg .u32 %r875; .reg .u32 %r876; .reg .u16 %r878; .reg .u16 %r879; .reg .u16 %r881; .reg .u16 %r882; .reg .u32 %r884; .reg .u16 %r885; .reg .pred %r886; .reg .u64 %r887; .reg .u32 %r888; .reg .u64 %r889; .reg .pred %r890; .reg .u16 %r892; .reg .u16 %r893; .reg .u32 %r894; .reg .u64 %r896; .reg .u16 %r898; .reg .u16 %r899; .reg .u32 %r900; .reg .pred %r903; .reg .u64 %r904; .reg .u64 %r905; .reg .u64 %r906; .reg .u32 %r907; .reg .pred %r908; .reg .u64 %r909; .reg .pred %r910; .reg .pred %r911; .reg .u32 %r912; .reg .pred %r913; .reg .u32 %r914; .reg .pred %r915; .reg .u32 %r916; .reg .pred %r919; .reg .pred %r920; .reg .pred %r921; .reg .u64 %r923; .reg .pred %r924; .reg .u32 %r929; .reg .pred %r930; .reg .pred %r931; .reg .pred %r933; .reg .u32 %r938; .reg .pred %r939; .reg .u64 %r942; .reg .u32 %r943; .reg .pred %r944; .reg .u32 %r949; .reg .pred %r950; .reg .u64 %r953; .reg .u32 %r954; .reg .pred %r955; .reg .u32 %r960; .reg .pred %r961; .reg .pred %r962; .reg .pred %r963; .reg .pred %r964; .reg .u64 %r966; .reg .pred %r967; .reg .u32 %r972; .reg .pred %r973; .reg .pred %r974; .reg .pred %r976; .reg .u32 %r981; .reg .pred %r982; .reg .pred %r983; .reg .pred %r984; .reg .u64 %r986; .reg .pred %r987; .reg .u32 %r992; .reg .pred %r993; .reg .pred %r994; .reg .pred %r996; .reg .u32 %r1001; .reg .pred %r1002; .reg .u32 %r1003; .reg .pred %r1004; .reg .u32 %r1005; .reg .pred %r1006; .reg .u32 %r1011; .reg .pred %r1012; .reg .pred %r1013; .reg .pred %r1014; .reg .u64 %r1015; .reg .u64 %r1016; .reg .u64 %r1017; .reg .u32 %r1018; .reg .pred %r1019; .reg .u32 %r1024; .reg .pred %r1025; .reg .u32 %r1026; .reg .pred %r1027; .reg .u32 %r1028; .reg .pred %r1029; .reg .u64 %r1030; .reg .u32 %r1031; .reg .pred %r1032; .reg .u32 %r1037; .reg .pred %r1038; .reg .pred %r1039; .reg .pred %r1040; .reg .u64 %r1042; .reg .pred %r1043; .reg .u32 %r1048; .reg .pred %r1049; .reg .pred %r1050; .reg .pred %r1052; .reg .u32 %r1057; .reg .pred %r1058; .reg .pred %r1059; .reg .u64 %r1060; .reg .u64 %r1061; .reg .u32 %r1062; .reg .pred %r1063; .reg .u32 %r1068; .reg .pred %r1069; .reg .u32 %r1070; .reg .pred %r1071; .reg .u32 %r1072; .reg .pred %r1073; .reg .u32 %r1074; .reg .pred %r1075; .reg .u32 %r1080; .reg .pred %r1081; .reg .pred %r1082; .reg .pred %r1083; .reg .u64 %r1085; .reg .pred %r1086; .reg .u32 %r1091; .reg .pred %r1092; .reg .pred %r1093; .reg .pred %r1095; .reg .u32 %r1100; .reg .pred %r1101; .reg .pred %r1102; .reg .u32 %r1107; .reg .pred %r1108; .reg .pred %r1109; .reg .u32 %r1110; .reg .pred %r1111; .reg .u32 %r1116; .reg .pred %r1117; .reg .pred %r1118; .reg .pred %r1119; .reg .u64 %r1121; .reg .pred %r1122; .reg .u32 %r1127; .reg .pred %r1128; .reg .pred %r1129; .reg .pred %r1131; .reg .u32 %r1136; .reg .pred %r1137; .reg .pred %r1138; .reg .u32 %r1139; .reg .pred %r1140; .reg .u32 %r1141; .reg .pred %r1142; .reg .u32 %r1147; .reg .pred %r1148; .reg .pred %r1149; .reg .u64 %r1150; .reg .u64 %r1151; .reg .u32 %r1152; .reg .pred %r1153; .reg .u32 %r1158; .reg .pred %r1159; .reg .u32 %r1160; .reg .pred %r1161; .reg .pred %r1162; .reg .u64 %r1164; .reg .pred %r1165; .reg .u32 %r1170; .reg .pred %r1171; .reg .pred %r1172; .reg .pred %r1174; .reg .u32 %r1179; .reg .pred %r1180; .reg .pred %r1181; .reg .u32 %r1182; .reg .pred %r1183; .reg .u64 %r1184; .reg .pred %r1185; .reg .u32 %r1190; .reg .pred %r1191; .reg .pred %r1192; .reg .u32 %r1197; .reg .pred %r1198; .reg .pred %r1199; .reg .u64 %r1200; .reg .pred %r1201; .reg .u32 %r1206; .reg .pred %r1207; .reg .u32 %r1208; .reg .pred %r1209; .reg .pred %r1210; .reg .u64 %r1212; .reg .pred %r1213; .reg .u32 %r1218; .reg .pred %r1219; .reg .pred %r1220; .reg .pred %r1222; .reg .u32 %r1227; .reg .pred %r1228; .reg .u32 %r1229; .reg .u64 %r1230; .reg .pred %r1231; .reg .u32 %r1236; .reg .pred %r1237; .reg .u32 %r1238; .reg .pred %r1240; .reg .u32 %r1245; .reg .pred %r1246; .reg .u32 %r1247; .reg .pred %r1248; .reg .pred %r1249; .reg .pred %r1250; .reg .u64 %r1252; .reg .pred %r1253; .reg .u32 %r1258; .reg .pred %r1259; .reg .pred %r1260; .reg .pred %r1262; .reg .u32 %r1267; .reg .pred %r1268; .reg .u32 %r1269; .reg .pred %r1270; .reg .u32 %r1271; .reg .u32 %r1276; .reg .pred %r1277; .reg .u64 %r1278; .reg .pred %r1279; .reg .u64 %r1283; .reg .u32 %r1284; .reg .u16 %r1285; .reg .u16 %r1286; .reg .pred %r1287; .reg .u64 %r1289; .reg .u32 %r1292; .reg .u64 %r1300; .reg .u32 %r1304; .reg .u64 %r1312; .reg .u16 %r1314; .reg .u32 %r1315; .reg .u32 %r1316; .reg .u32 %r1317; .reg .u32 %r1319; .reg .u32 %r1320; .reg .u16 %r1321; .reg .u16 %r1322; .reg .u16 %r1323; .reg .u32 %r1324; .reg .u16 %r1325; .reg .pred %r1326; .reg .pred %r1328; .reg .u64 %r1329; .reg .u32 %r1330; .reg .pred %r1331; .reg .u32 %r1333; .reg .u32 %r1334; .reg .u32 %r1336; .reg .u32 %r1337; .reg .u16 %r1338; .reg .u16 %r1339; .reg .u16 %r1340; .reg .u32 %r1341; .reg .u16 %r1342; .reg .pred %r1343; .reg .pred %r1348; .reg .u64 %r1349; .reg .u32 %r1350; .reg .u64 %r1351; .reg .u32 %r1352; .reg .pred %r1353; .reg .pred %r1354; .reg .u64 %r1355; .reg .u64 %r1379; .reg .u64 %r1380; .reg .u64 %r1381; .reg .u64 %r1382; .reg .u64 %r1383; .reg .u64 %r1384; .reg .u64 %r1385; .reg .u64 %r1386; .reg .u64 %r1387; .reg .u64 %r1388; mov.u64 %r496,%ar0; mov.u64 %r497,%ar1; mov.u64 %r498,%ar2; mov.u64 %r499,%ar3; .loc 1 696 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; call (%value_in),_localeconv_r,(%out_arg1); ld.param.u64 %r511,[%value_in]; } ld.u64 %r334,[%r511]; .loc 1 697 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r334; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r513,[%value_in]; } .loc 1 859 0 setp.eq.u64 %r514,%r496,0; @ %r514 bra $L2; ld.u32 %r515,[%r496+80]; setp.ne.u32 %r516,%r515,0; @ %r516 bra $L2; { .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; call __sinit,(%out_arg1); } $L2: .loc 1 862 0 ld.s16 %r116,[%r497+16]; cvt.u16.u32 %r519,%r116; and.b16 %r518,%r519,8192; setp.ne.u16 %r520,%r518,0; @ %r520 bra $L3; or.b16 %r521,%r519,8192; cvt.s32.s16 %r116,%r521; st.u16 [%r497+16],%r521; ld.u32 %r525,[%r497+172]; and.b32 %r524,%r525,-8193; st.u32 [%r497+172],%r524; $L3: .loc 1 865 0 cvt.u16.u32 %r527,%r116; and.b16 %r526,%r527,8; setp.eq.u16 %r528,%r526,0; @ %r528 bra $L4; ld.u64 %r529,[%r497+24]; setp.ne.u64 %r530,%r529,0; @ %r530 bra $L5; $L4: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; call (%value_in),__swsetup_r,(%out_arg1,%out_arg2); ld.param.u32 %r533,[%value_in]; } setp.ne.u32 %r534,%r533,0; @ %r534 bra $L6; ld.s16 %r116,[%r497+16]; $L5: .loc 1 872 0 cvt.u16.u32 %r536,%r116; and.b16 %r535,%r536,26; setp.ne.u16 %r537,%r535,10; @ %r537 bra $L7; ld.u16 %r538,[%r497+18]; setp.lt.s16 %r539,%r538,0; @ %r539 bra $L7; .loc 1 875 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r498; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r499; call (%value_in),__sbprintf,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r544,[%value_in]; } mov.u32 %r495,%r544; bra $L1; $L7: .loc 1 894 0 st.u64 [%frame+168],%frame; .loc 1 895 0 mov.u64 %r545,0; st.u64 [%frame+184],%r545; .loc 1 896 0 cvt.u32.u64 %r546,%r545; st.u32 [%frame+176],%r546; .loc 1 707 0 cvt.u32.u64 %r407,%r545; .loc 1 699 0 mov.f64 %r343,0d0000000000000000; .loc 1 894 0 mov.u64 %r328,%frame; .loc 1 718 0 mov.u64 %r117,%r545; .loc 1 702 0 cvt.u32.u64 %r323,%r117; .loc 1 898 0 cvt.u32.u64 %r495,%r117; .loc 1 929 0 add.u64 %r1379,%frame,168; .loc 1 1763 0 add.u64 %r1380,%frame,200; .loc 1 1694 0 add.u64 %r1381,%frame,216; .loc 1 1692 0 add.u64 %r1382,%frame,218; .loc 1 1880 0 add.u64 %r1383,%frame,192; add.u64 %r1384,%frame,208; add.u64 %r1385,%frame,212; .loc 1 1928 0 add.u64 %r1386,%frame,204; .loc 1 1917 0 add.u64 %r1387,%frame,199; .loc 1 1923 0 add.u64 %r1388,%frame,202; $L9: .loc 1 925 0 ld.s8 %r283,[%r498]; cvt.u16.u32 %r548,%r283; set.u32.ne.u16 %r549,%r548,37; neg.s32 %r550,%r549; set.u32.ne.u16 %r553,%r548,0; neg.s32 %r554,%r553; cvt.u16.u32 %r556,%r550; cvt.u16.u32 %r557,%r554; and.b16 %r555,%r556,%r557; cvt.u32.u16 %r558,%r555; cvt.u16.u8 %r559,%r558; setp.eq.u16 %r560,%r559,0; @ %r560 bra $L240; mov.u64 %r317,%r498; $L11: .loc 1 926 0 add.u64 %r317,%r317,1; .loc 1 925 0 ld.s8 %r342,[%r317]; cvt.u16.u32 %r562,%r342; set.u32.ne.u16 %r563,%r562,0; neg.s32 %r564,%r563; set.u32.ne.u16 %r567,%r562,37; neg.s32 %r568,%r567; cvt.u16.u32 %r570,%r564; cvt.u16.u32 %r571,%r568; and.b16 %r569,%r570,%r571; cvt.u32.u16 %r572,%r569; cvt.u16.u8 %r573,%r572; setp.ne.u16 %r574,%r573,0; @ %r574 bra $L11; sub.u64 %r575,%r317,%r498; cvt.u32.u64 %r447,%r575; .loc 1 928 0 setp.eq.u32 %r576,%r447,0; @ %r576 bra $L10; .loc 1 929 0 st.u64 [%r328],%r498; cvt.s64.s32 %r126,%r447; st.u64 [%r328+8],%r126; ld.u64 %r578,[%frame+184]; add.u64 %r577,%r578,%r126; st.u64 [%frame+184],%r577; ld.u32 %r579,[%frame+176]; add.u32 %r130,%r579,1; st.u32 [%frame+176],%r130; setp.gt.s32 %r580,%r130,7; @ %r580 bra $L12; add.u64 %r328,%r328,16; bra $L13; $L12: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r585,[%value_in]; } setp.ne.u32 %r586,%r585,0; @ %r586 bra $L14; mov.u64 %r328,%frame; $L13: .loc 1 930 0 add.u32 %r495,%r495,%r447; bra $L10; $L240: .loc 1 925 0 mov.u64 %r317,%r498; $L10: .loc 1 936 0 ld.s8 %r588,[%r317]; cvt.u16.u32 %r587,%r588; setp.eq.u16 %r589,%r587,0; @ %r589 bra $L15; .loc 1 940 0 add.u64 %r498,%r317,1; .loc 1 946 0 mov.u32 %r590,0; st.u8 [%frame+218],%r590; ld.s8 %r490,[%r317+1]; mov.u32 %r397,0; mov.u32 %r329,%r397; .loc 1 945 0 mov.u32 %r322,-1; .loc 1 944 0 mov.u32 %r321,%r397; .loc 1 942 0 mov.u32 %r320,%r397; bra $L16; $L241: .loc 1 1018 0 mov.u64 %r499,%r412; $L16: .loc 1 958 0 add.u64 %r498,%r498,1; mov.u32 %r316,%r490; $L17: .loc 1 959 0 setp.eq.u32 %r591,%r316,85; @ %r591 bra $L19; setp.gt.s32 %r592,%r316,85; @ %r592 bra $L20; setp.eq.u32 %r593,%r316,48; @ %r593 bra $L21; setp.gt.s32 %r594,%r316,48; @ %r594 bra $L22; setp.eq.u32 %r595,%r316,42; @ %r595 bra $L23; setp.gt.s32 %r596,%r316,42; @ %r596 bra $L24; setp.eq.u32 %r597,%r316,32; @ %r597 bra $L25; setp.eq.u32 %r598,%r316,35; @ %r598 bra $L26; bra $L18; $L24: setp.eq.u32 %r599,%r316,45; @ %r599 bra $L27; setp.eq.u32 %r600,%r316,46; @ %r600 bra $L28; setp.eq.u32 %r601,%r316,43; @ ! %r601 bra $L18; bra $L29; $L22: setp.eq.u32 %r602,%r316,69; @ %r602 bra $L30; setp.gt.s32 %r603,%r316,69; @ %r603 bra $L31; setp.le.s32 %r604,%r316,57; @ %r604 bra $L32; setp.eq.u32 %r605,%r316,68; @ %r605 bra $L33; bra $L18; $L31: setp.eq.u32 %r606,%r316,76; @ %r606 bra $L34; setp.eq.u32 %r607,%r316,79; @ %r607 bra $L35; setp.eq.u32 %r608,%r316,71; @ ! %r608 bra $L18; bra $L30; $L20: setp.eq.u32 %r609,%r316,108; @ %r609 bra $L36; setp.gt.s32 %r610,%r316,108; @ %r610 bra $L37; setp.gt.s32 %r611,%r316,103; @ %r611 bra $L38; setp.ge.s32 %r612,%r316,101; @ %r612 bra $L30; setp.eq.u32 %r613,%r316,99; @ %r613 bra $L39; setp.gt.s32 %r614,%r316,99; @ %r614 bra $L40; setp.eq.u32 %r615,%r316,88; @ %r615 bra $L41; bra $L18; $L38: setp.eq.u32 %r616,%r316,104; @ %r616 bra $L42; setp.eq.u32 %r617,%r316,105; @ %r617 bra $L40; bra $L18; $L37: setp.eq.u32 %r618,%r316,113; @ %r618 bra $L43; setp.gt.s32 %r619,%r316,113; @ %r619 bra $L44; setp.eq.u32 %r620,%r316,111; @ %r620 bra $L45; setp.gt.s32 %r621,%r316,111; @ %r621 bra $L46; setp.eq.u32 %r622,%r316,110; @ %r622 bra $L47; bra $L18; $L44: setp.eq.u32 %r623,%r316,117; @ %r623 bra $L48; setp.eq.u32 %r624,%r316,120; @ %r624 bra $L49; setp.eq.u32 %r625,%r316,115; @ ! %r625 bra $L18; bra $L50; $L27: ld.s8 %r490,[%r498]; bra $L51; $L41: setp.eq.u32 %r626,%r397,0; @ %r626 bra $L52; cvt.u32.u32 %r627,%r329; st.u8 [%frame+218],%r627; $L52: .loc 1 1542 0 cvta.const.u64 %r117,$LC4; bra $L53; $L40: setp.eq.u32 %r628,%r397,0; @ %r628 bra $L55; cvt.u32.u32 %r629,%r329; st.u8 [%frame+218],%r629; bra $L55; $L25: ld.s8 %r490,[%r498]; .loc 1 975 0 setp.ne.u32 %r630,%r329,0; selp.u32 %r397,%r397,1,%r630; selp.u32 %r329,%r329,32,%r630; bra $L16; $L26: .loc 1 979 0 or.b32 %r320,%r320,1; ld.s8 %r490,[%r498]; .loc 1 980 0 bra $L16; $L23: .loc 1 1018 0 add.u64 %r412,%r499,4; ld.u32 %r321,[%r499]; ld.s8 %r490,[%r498]; .loc 1 1022 0 setp.ge.s32 %r631,%r321,0; @ %r631 bra $L241; .loc 1 1024 0 neg.s32 %r321,%r321; .loc 1 1018 0 mov.u64 %r499,%r412; $L51: .loc 1 1027 0 or.b32 %r320,%r320,4; .loc 1 1028 0 bra $L16; $L29: ld.s8 %r490,[%r498]; .loc 1 1031 0 mov.u32 %r397,1; .loc 1 1030 0 mov.u32 %r329,%r316; .loc 1 1031 0 bra $L16; $L28: .loc 1 1033 0 add.u64 %r362,%r498,1; ld.s8 %r316,[%r498]; setp.eq.u32 %r632,%r316,42; @ %r632 bra $L57; .loc 1 1072 0 add.u32 %r1350,%r316,-48; setp.le.u32 %r633,%r1350,9; @ %r633 bra $L58; .loc 1 1033 0 mov.u64 %r498,%r362; .loc 1 1071 0 mov.u32 %r322,0; bra $L17; $L57: ld.u32 %r634,[%r499]; max.s32 %r322,%r634,-1; ld.s8 %r490,[%r498+1]; .loc 1 1063 0 add.u64 %r499,%r499,4; .loc 1 1033 0 mov.u64 %r498,%r362; bra $L16; $L58: mov.u64 %r377,%r362; .loc 1 1071 0 mov.u32 %r322,0; $L60: .loc 1 1073 0 shl.b32 %r636,%r322,2; add.u32 %r637,%r636,%r322; add.u32 %r638,%r637,%r637; add.u32 %r322,%r638,%r1350; add.u64 %r498,%r377,1; .loc 1 1074 0 ld.s8 %r316,[%r377]; .loc 1 1072 0 add.u32 %r1350,%r316,-48; mov.u64 %r377,%r498; setp.le.u32 %r639,%r1350,9; @ %r639 bra $L60; bra $L17; $L21: .loc 1 1084 0 or.b32 %r320,%r320,128; ld.s8 %r490,[%r498]; .loc 1 1085 0 bra $L16; $L32: mov.u64 %r376,%r498; .loc 1 1088 0 mov.u32 %r321,0; add.u32 %r1350,%r316,-48; $L61: .loc 1 1090 0 shl.b32 %r641,%r321,2; add.u32 %r642,%r641,%r321; add.u32 %r643,%r642,%r642; add.u32 %r321,%r1350,%r643; add.u64 %r498,%r498,1; .loc 1 1091 0 ld.s8 %r316,[%r376]; mov.u64 %r376,%r498; .loc 1 1092 0 add.u32 %r1350,%r316,-48; setp.le.u32 %r646,%r1350,9; @ %r646 bra $L61; bra $L17; $L34: .loc 1 1108 0 or.b32 %r320,%r320,8; ld.s8 %r490,[%r498]; .loc 1 1109 0 bra $L16; $L42: .loc 1 1118 0 or.b32 %r320,%r320,64; ld.s8 %r490,[%r498]; .loc 1 1119 0 bra $L16; $L36: .loc 1 1122 0 ld.s8 %r490,[%r498]; cvt.u16.u32 %r647,%r490; setp.ne.u16 %r648,%r647,108; @ %r648 bra $L62; .loc 1 1124 0 or.b32 %r320,%r320,32; ld.s8 %r490,[%r498+1]; .loc 1 1123 0 add.u64 %r498,%r498,1; bra $L16; $L62: .loc 1 1127 0 or.b32 %r320,%r320,16; bra $L16; $L43: .loc 1 1130 0 or.b32 %r320,%r320,32; ld.s8 %r490,[%r498]; .loc 1 1131 0 bra $L16; $L39: .loc 1 1189 0 ld.u32 %r649,[%r499]; st.u8 [%frame+128],%r649; .loc 1 1192 0 mov.u32 %r650,0; st.u8 [%frame+218],%r650; .loc 1 1189 0 add.u64 %r499,%r499,4; .loc 1 1193 0 mov.u32 %r326,1; .loc 1 1190 0 mov.u32 %r327,%r326; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1173 0 add.u64 %r319,%frame,128; setp.eq.u32 %r1353,1,1; .loc 1 1193 0 bra $L140; $L33: setp.eq.u32 %r651,%r397,0; @ %r651 bra $L64; cvt.u32.u32 %r652,%r329; st.u8 [%frame+218],%r652; $L64: .loc 1 1195 0 or.b32 %r320,%r320,16; $L55: .loc 1 1199 0 and.b32 %r653,%r320,32; setp.eq.u32 %r654,%r653,0; @ %r654 bra $L65; add.u64 %r430,%r499,7; and.b64 %r408,%r430,-8; add.u64 %r499,%r408,8; ld.u64 %r324,[%r408]; bra $L66; $L65: and.b32 %r655,%r320,16; setp.eq.u32 %r656,%r655,0; @ %r656 bra $L67; add.u64 %r417,%r499,7; and.b64 %r413,%r417,-8; add.u64 %r499,%r413,8; ld.u64 %r324,[%r413]; bra $L66; $L67: ld.u32 %r489,[%r499]; add.u64 %r499,%r499,4; and.b32 %r657,%r320,64; setp.eq.u32 %r658,%r657,0; @ %r658 bra $L68; cvt.u16.u32 %r659,%r489; cvt.s64.s16 %r324,%r659; bra $L66; $L68: cvt.s64.s32 %r324,%r489; $L66: .loc 1 1201 0 setp.ge.s64 %r660,%r324,0; @ %r660 bra $L69; .loc 1 1207 0 neg.s64 %r324,%r324; .loc 1 1208 0 mov.u32 %r661,45; st.u8 [%frame+218],%r661; bra $L69; $L30: setp.eq.u32 %r662,%r397,0; @ %r662 bra $L70; cvt.u32.u32 %r663,%r329; st.u8 [%frame+218],%r663; $L70: add.u64 %r664,%r499,7; and.b64 %r453,%r664,-8; add.u64 %r499,%r453,8; .loc 1 1225 0 ld.f64 %r343,[%r453]; .loc 1 1236 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r343; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r668,[%value_in]; } setp.ne.u32 %r669,%r668,1; @ %r669 bra $L73; .loc 1 1237 0 setp.lt.f64 %r670,%r343,0d0000000000000000; @ %r670 bra $L74; ld.s8 %r458,[%frame+218]; bra $L75; $L74: .loc 1 1238 0 mov.u32 %r671,45; st.u8 [%frame+218],%r671; mov.u32 %r458,45; $L75: .loc 1 1239 0 setp.gt.s32 %r672,%r316,71; @ %r672 bra $L242; .loc 1 1240 0 cvta.const.u64 %r319,$LC0; bra $L76; $L242: .loc 1 1242 0 cvta.const.u64 %r319,$LC1; $L76: .loc 1 1244 0 and.b32 %r320,%r320,-129; .loc 1 1245 0 mov.u32 %r326,3; .loc 1 1243 0 mov.u32 %r327,%r326; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1245 0 bra $L63; $L73: .loc 1 1247 0 { .param .u32 %value_in; .param .f64 %out_arg1; st.param.f64 [%out_arg1],%r343; call (%value_in),__fpclassifyd,(%out_arg1); ld.param.u32 %r674,[%value_in]; } mov.u32 %r156,%r674; setp.ne.u32 %r675,%r674,0; @ %r675 bra $L77; .loc 1 1248 0 setp.gt.s32 %r676,%r316,71; @ %r676 bra $L243; .loc 1 1249 0 cvta.const.u64 %r319,$LC2; bra $L78; $L243: .loc 1 1251 0 cvta.const.u64 %r319,$LC3; $L78: .loc 1 1253 0 and.b32 %r320,%r320,-129; ld.s8 %r458,[%frame+218]; .loc 1 943 0 mov.u32 %r322,%r674; .loc 1 1254 0 mov.u32 %r326,3; .loc 1 1252 0 mov.u32 %r327,%r326; .loc 1 1254 0 bra $L63; $L77: and.b32 %r454,%r316,-33; .loc 1 1309 0 setp.eq.u32 %r677,%r322,-1; @ %r677 bra $L244; .loc 1 1311 0 set.u32.eq.u32 %r679,%r322,0; neg.s32 %r680,%r679; set.u32.eq.u32 %r682,%r454,71; neg.s32 %r683,%r682; cvt.u16.u32 %r685,%r680; cvt.u16.u32 %r686,%r683; and.b16 %r684,%r685,%r686; cvt.u32.u16 %r687,%r684; cvt.u16.u8 %r688,%r687; setp.ne.u16 %r689,%r688,0; .loc 1 1312 0 selp.u32 %r322,1,%r322,%r689; bra $L79; $L244: .loc 1 1310 0 mov.u32 %r322,6; $L79: .loc 1 1315 0 or.b32 %r350,%r320,256; .loc 1 1814 0 mov.b64 %r690,%r343; shr.u64 %r691,%r690,32; cvt.u32.u64 %r692,%r691; setp.ge.s32 %r693,%r692,0; @ %r693 bra $L246; .loc 1 1815 0 neg.f64 %r375,%r343; .loc 1 1816 0 mov.u32 %r406,45; bra $L80; $L246: .loc 1 1814 0 mov.f64 %r375,%r343; .loc 1 1818 0 mov.u32 %r406,0; $L80: .loc 1 1867 0 setp.eq.u32 %r694,%r454,70; @ %r694 bra $L81; .loc 1 1874 0 setp.ne.u32 %r695,%r454,69; @ %r695 bra $L82; .loc 1 1875 0 add.u32 %r378,%r322,1; .loc 1 1880 0 mov.u32 %r698,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r375; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r698; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r378; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1385; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1384; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1383; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r706,[%value_in]; } mov.u64 %r319,%r706; setp.eq.u32 %r1354,1,1; bra $L83; $L377: ld.u64 %r351,[%frame+192]; bra $L84; $L376: ld.u32 %r457,[%frame+212]; bra $L85; $L233: .loc 1 1886 0 mov.u32 %r707,1; sub.u32 %r457,%r707,%r322; st.u32 [%frame+212],%r457; $L85: .loc 1 1887 0 cvt.s64.s32 %r708,%r457; add.u64 %r709,%r708,%r360; add.u64 %r382,%r1312,%r709; setp.eq.u32 %r1354,1,1; $L231: .loc 1 1889 0 setp.eq.f64 %r710,%r375,0d0000000000000000; @ %r710 bra $L247; bra $L364; $L87: .loc 1 1892 0 add.u64 %r711,%r351,1; st.u64 [%frame+192],%r711; st.u8 [%r351],%r712; .loc 1 1891 0 ld.u64 %r351,[%frame+192]; setp.gt.u64 %r713,%r382,%r351; @ %r713 bra $L87; bra $L84; $L364: ld.u64 %r351,[%frame+192]; setp.lt.u64 %r714,%r351,%r382; @ ! %r714 bra $L84; .loc 1 1892 0 mov.u32 %r712,48; bra $L87; $L247: .loc 1 1889 0 mov.u64 %r351,%r382; $L84: .loc 1 1894 0 sub.u64 %r715,%r351,%r319; cvt.u32.u64 %r407,%r715; ld.u32 %r156,[%frame+212]; .loc 1 1320 0 @ %r1354 bra $L88; .loc 1 1321 0 set.u32.lt.s32 %r718,%r322,%r156; neg.s32 %r719,%r718; set.u32.lt.s32 %r721,%r156,-3; neg.s32 %r722,%r721; cvt.u16.u32 %r724,%r719; cvt.u16.u32 %r725,%r722; or.b16 %r723,%r724,%r725; cvt.u32.u16 %r726,%r723; cvt.u16.u8 %r727,%r726; setp.eq.u16 %r728,%r727,0; @ %r728 bra $L89; .loc 1 1322 0 add.u32 %r316,%r316,-2; bra $L90; $L88: .loc 1 1330 0 setp.eq.u32 %r729,%r316,102; @ %r729 bra $L91; $L90: .loc 1 1331 0 add.u32 %r388,%r156,-1; st.u32 [%frame+212],%r388; .loc 1 1910 0 st.u8 [%frame+200],%r316; .loc 1 1911 0 setp.ge.s32 %r730,%r388,0; @ %r730 bra $L92; .loc 1 1912 0 mov.u32 %r731,1; sub.u32 %r388,%r731,%r156; .loc 1 1913 0 mov.u32 %r732,45; st.u8 [%frame+201],%r732; bra $L93; $L92: .loc 1 1916 0 mov.u32 %r733,43; st.u8 [%frame+201],%r733; $L93: .loc 1 1918 0 setp.le.s32 %r734,%r388,9; @ %r734 bra $L94; .loc 1 1917 0 mov.u64 %r392,%r1387; bra $L95; $L248: .loc 1 1921 0 mov.u64 %r392,%r1351; $L95: .loc 1 1920 0 add.u64 %r1351,%r392,-1; rem.s32 %r738,%r388,10; cvt.u16.u32 %r741,%r738; add.u16 %r740,%r741,48; cvt.u32.u16 %r742,%r740; st.u8 [%r1351],%r742; .loc 1 1921 0 div.s32 %r388,%r388,10; setp.gt.s32 %r747,%r388,9; @ %r747 bra $L248; .loc 1 1922 0 add.u64 %r361,%r392,-2; cvt.u16.u32 %r750,%r388; add.u16 %r749,%r750,48; cvt.u32.u16 %r751,%r749; cvt.s32.s8 %r456,%r751; st.u8 [%r1351+-1],%r751; .loc 1 1923 0 setp.ge.u64 %r755,%r361,%r1387; @ %r755 bra $L249; mov.u64 %r440,%r1388; $L98: add.u64 %r361,%r361,1; cvt.u32.u32 %r757,%r456; st.u8 [%r440],%r757; add.u64 %r440,%r440,1; setp.ne.u64 %r760,%r361,%r1387; @ %r760 bra $L97; sub.u64 %r767,%r1380,%r1351; add.u64 %r401,%r1388,%r767; bra $L96; $L97: ld.s8 %r456,[%r361]; bra $L98; $L94: .loc 1 1927 0 mov.u32 %r768,48; st.u8 [%frame+202],%r768; .loc 1 1928 0 cvt.u16.u32 %r771,%r388; add.u16 %r770,%r771,48; cvt.u32.u16 %r772,%r770; st.u8 [%frame+203],%r772; mov.u64 %r401,%r1386; bra $L96; $L249: .loc 1 1923 0 mov.u64 %r401,%r1388; $L96: .loc 1 1930 0 sub.u64 %r774,%r401,%r1380; cvt.u32.u64 %r323,%r774; .loc 1 1333 0 add.u32 %r327,%r407,%r323; .loc 1 1334 0 setp.gt.s32 %r775,%r407,1; @ %r775 bra $L99; and.b32 %r156,%r320,1; setp.ne.u32 %r776,%r156,0; @ %r776 bra $L99; max.s32 %r326,%r327,0; bra $L100; $L99: .loc 1 1335 0 add.u32 %r327,%r327,1; max.s32 %r326,%r327,0; .loc 1 948 0 mov.u32 %r156,0; bra $L100; $L91: .loc 1 1341 0 setp.le.s32 %r777,%r156,0; @ %r777 bra $L101; .loc 1 1343 0 setp.ne.u32 %r778,%r322,0; @ %r778 bra $L102; and.b32 %r779,%r320,1; setp.eq.u32 %r780,%r779,0; @ %r780 bra $L250; $L102: .loc 1 1344 0 add.u32 %r781,%r322,1; add.u32 %r327,%r781,%r156; mov.u32 %r326,%r327; bra $L100; $L101: .loc 1 1348 0 setp.ne.u32 %r782,%r322,0; @ %r782 bra $L104; .loc 1 1346 0 and.b32 %r783,%r320,1; setp.eq.u32 %r784,%r783,0; @ %r784 bra $L251; $L104: .loc 1 1348 0 add.u32 %r327,%r322,2; mov.u32 %r326,%r327; bra $L100; $L89: .loc 1 1349 0 setp.gt.s32 %r785,%r407,%r156; @ %r785 bra $L105; .loc 1 1351 0 and.b32 %r786,%r320,1; setp.ne.u32 %r787,%r786,0; @ %r787 bra $L106; max.s32 %r326,%r156,0; mov.u32 %r327,%r156; mov.u32 %r316,103; bra $L100; $L106: .loc 1 1352 0 add.u32 %r327,%r156,1; max.s32 %r326,%r327,0; mov.u32 %r316,103; bra $L100; $L105: .loc 1 1355 0 setp.gt.s32 %r788,%r156,0; @ %r788 bra $L252; mov.u32 %r789,2; sub.u32 %r332,%r789,%r156; bra $L107; $L252: mov.u32 %r332,1; $L107: .loc 1 1354 0 add.u32 %r327,%r332,%r407; max.s32 %r326,%r327,0; mov.u32 %r316,103; bra $L100; $L250: mov.u32 %r326,%r156; mov.u32 %r327,%r156; bra $L100; $L251: mov.u32 %r326,1; .loc 1 1348 0 mov.u32 %r327,%r326; $L100: .loc 1 1377 0 setp.ne.u32 %r790,%r406,0; @ %r790 bra $L108; ld.s8 %r458,[%frame+218]; .loc 1 1315 0 mov.u32 %r320,%r350; .loc 1 943 0 mov.u32 %r322,%r406; bra $L63; $L108: .loc 1 1378 0 mov.u32 %r791,45; st.u8 [%frame+218],%r791; .loc 1 1315 0 mov.u32 %r320,%r350; .loc 1 943 0 mov.u32 %r322,0; setp.eq.u32 %r1353,1,0; bra $L365; $L47: setp.eq.u32 %r792,%r397,0; @ %r792 bra $L109; cvt.u32.u32 %r793,%r329; st.u8 [%frame+218],%r793; $L109: add.u64 %r794,%r499,7; and.b64 %r449,%r794,-8; add.u64 %r499,%r449,8; ld.u64 %r450,[%r449]; .loc 1 1392 0 and.b32 %r795,%r320,32; setp.eq.u32 %r796,%r795,0; @ %r796 bra $L110; .loc 1 1393 0 cvt.s64.s32 %r797,%r495; st.u64 [%r450],%r797; bra $L9; $L110: .loc 1 1396 0 and.b32 %r798,%r320,16; setp.eq.u32 %r799,%r798,0; @ %r799 bra $L112; .loc 1 1397 0 cvt.s64.s32 %r800,%r495; st.u64 [%r450],%r800; bra $L9; $L112: .loc 1 1398 0 and.b32 %r801,%r320,64; setp.eq.u32 %r802,%r801,0; @ %r802 bra $L113; .loc 1 1399 0 st.u16 [%r450],%r495; bra $L9; $L113: .loc 1 1405 0 st.u32 [%r450],%r495; bra $L9; $L35: .loc 1 1408 0 or.b32 %r320,%r320,16; $L45: .loc 1 1411 0 and.b32 %r803,%r320,32; setp.eq.u32 %r804,%r803,0; @ %r804 bra $L114; add.u64 %r418,%r499,7; and.b64 %r414,%r418,-8; add.u64 %r499,%r414,8; ld.u64 %r324,[%r414]; .loc 1 1412 0 mov.u32 %r325,0; bra $L115; $L114: .loc 1 1411 0 and.b32 %r805,%r320,16; setp.eq.u32 %r806,%r805,0; @ %r806 bra $L116; add.u64 %r421,%r499,7; and.b64 %r409,%r421,-8; add.u64 %r499,%r409,8; ld.u64 %r324,[%r409]; .loc 1 1412 0 mov.u32 %r325,%r803; bra $L115; $L116: ld.u32 %r488,[%r499]; add.u64 %r499,%r499,4; .loc 1 1411 0 and.b32 %r807,%r320,64; setp.eq.u32 %r808,%r807,0; @ %r808 bra $L117; cvt.u16.u32 %r809,%r488; cvt.u64.u16 %r324,%r809; .loc 1 1412 0 mov.u32 %r325,%r805; bra $L115; $L117: .loc 1 1411 0 cvt.u64.u32 %r324,%r488; .loc 1 1412 0 mov.u32 %r325,%r807; bra $L115; $L46: .loc 1 1426 0 add.u64 %r433,%r499,7; and.b64 %r206,%r433,-8; add.u64 %r499,%r206,8; ld.u64 %r324,[%r206]; .loc 1 1429 0 or.b32 %r320,%r320,2; .loc 1 1430 0 mov.u32 %r810,48; st.u8 [%frame+216],%r810; .loc 1 1431 0 mov.u32 %r811,120; st.u8 [%frame+217],%r811; .loc 1 1428 0 cvta.const.u64 %r117,$LC5; .loc 1 1427 0 mov.u32 %r325,2; .loc 1 1431 0 mov.u32 %r316,120; .loc 1 1432 0 bra $L115; $L50: .loc 1 1437 0 add.u64 %r431,%r499,7; and.b64 %r405,%r431,-8; add.u64 %r499,%r405,8; ld.u64 %r319,[%r405]; .loc 1 1441 0 mov.u32 %r812,0; st.u8 [%frame+218],%r812; .loc 1 1447 0 setp.ne.u64 %r813,%r319,0; @ %r813 bra $L118; .loc 1 1449 0 min.u32 %r326,%r322,6; mov.u32 %r327,%r326; mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1448 0 cvta.const.u64 %r319,$LC6; setp.eq.u32 %r1353,1,1; bra $L140; $L118: .loc 1 1516 0 setp.eq.u32 %r814,%r322,-1; @ %r814 bra $L119; .loc 1 1522 0 cvt.s64.s32 %r818,%r322; mov.u32 %r816,0; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r319; .param .u32 %out_arg2; st.param.u32 [%out_arg2],%r816; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r818; call (%value_in),memchr,(%out_arg1,%out_arg2,%out_arg3); ld.param.u64 %r819,[%value_in]; } .loc 1 1524 0 setp.ne.u64 %r820,%r819,0; @ %r820 bra $L120; ld.s8 %r458,[%frame+218]; mov.u32 %r326,%r322; mov.u32 %r327,%r322; .loc 1 943 0 cvt.u32.u64 %r322,%r819; .loc 1 948 0 mov.u32 %r156,%r322; bra $L63; $L120: .loc 1 1525 0 sub.u64 %r821,%r819,%r319; cvt.u32.u64 %r822,%r821; min.s32 %r327,%r322,%r822; ld.s8 %r458,[%frame+218]; max.s32 %r326,%r327,0; .loc 1 943 0 mov.u32 %r322,%r816; .loc 1 948 0 mov.u32 %r156,%r322; bra $L63; $L119: .loc 1 1531 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r319; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r824,[%value_in]; } cvt.u32.u64 %r327,%r824; ld.s8 %r458,[%frame+218]; max.s32 %r326,%r327,0; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; bra $L63; $L19: .loc 1 1535 0 or.b32 %r320,%r320,16; $L48: .loc 1 1538 0 and.b32 %r825,%r320,32; setp.eq.u32 %r826,%r825,0; @ %r826 bra $L121; add.u64 %r426,%r499,7; and.b64 %r410,%r426,-8; add.u64 %r499,%r410,8; ld.u64 %r324,[%r410]; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L121: .loc 1 1538 0 and.b32 %r827,%r320,16; setp.eq.u32 %r828,%r827,0; @ %r828 bra $L122; add.u64 %r428,%r499,7; and.b64 %r416,%r428,-8; add.u64 %r499,%r416,8; ld.u64 %r324,[%r416]; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L122: ld.u32 %r487,[%r499]; add.u64 %r499,%r499,4; .loc 1 1538 0 and.b32 %r829,%r320,64; setp.eq.u32 %r830,%r829,0; @ %r830 bra $L123; cvt.u16.u32 %r831,%r487; cvt.u64.u16 %r324,%r831; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L123: .loc 1 1538 0 cvt.u64.u32 %r324,%r487; .loc 1 1539 0 mov.u32 %r325,1; bra $L115; $L49: setp.eq.u32 %r832,%r397,0; @ %r832 bra $L124; cvt.u32.u32 %r833,%r329; st.u8 [%frame+218],%r833; $L124: .loc 1 1545 0 cvta.const.u64 %r117,$LC5; $L53: .loc 1 1546 0 and.b32 %r834,%r320,32; setp.eq.u32 %r835,%r834,0; @ %r835 bra $L125; add.u64 %r415,%r499,7; and.b64 %r429,%r415,-8; add.u64 %r499,%r429,8; ld.u64 %r324,[%r429]; bra $L126; $L125: and.b32 %r836,%r320,16; setp.eq.u32 %r837,%r836,0; @ %r837 bra $L127; add.u64 %r425,%r499,7; and.b64 %r337,%r425,-8; add.u64 %r499,%r337,8; ld.u64 %r324,[%r337]; bra $L126; $L127: ld.u32 %r486,[%r499]; add.u64 %r499,%r499,4; and.b32 %r838,%r320,64; setp.eq.u32 %r839,%r838,0; @ %r839 bra $L128; cvt.u16.u32 %r840,%r486; cvt.u64.u16 %r324,%r840; bra $L126; $L128: cvt.u64.u32 %r324,%r486; $L126: .loc 1 1549 0 and.b32 %r841,%r320,1; setp.eq.u32 %r842,%r841,0; @ %r842 bra $L253; setp.eq.u64 %r843,%r324,0; @ %r843 bra $L254; .loc 1 1550 0 mov.u32 %r844,48; st.u8 [%frame+216],%r844; .loc 1 1551 0 st.u8 [%frame+217],%r316; .loc 1 1552 0 or.b32 %r320,%r320,2; .loc 1 1547 0 mov.u32 %r325,2; bra $L115; $L253: mov.u32 %r325,2; bra $L115; $L254: mov.u32 %r325,2; $L115: .loc 1 1559 0 mov.u32 %r845,0; st.u8 [%frame+218],%r845; .loc 1 1565 0 setp.eq.u32 %r847,%r322,-1; @ %r847 bra $L255; .loc 1 1566 0 and.b32 %r357,%r320,-129; .loc 1 1574 0 set.u32.ne.u64 %r849,%r324,0; neg.s32 %r850,%r849; set.u32.ne.u32 %r852,%r322,0; neg.s32 %r853,%r852; cvt.u16.u32 %r855,%r850; cvt.u16.u32 %r856,%r853; or.b16 %r854,%r855,%r856; cvt.u32.u16 %r857,%r854; cvt.u16.u8 %r858,%r857; setp.eq.u16 %r859,%r858,0; @ %r859 bra $L130; bra $L238; $L262: mov.u32 %r325,1; $L238: ld.s8 %r458,[%frame+218]; mov.u32 %r320,%r357; bra $L129; $L255: mov.u32 %r458,0; $L129: .loc 1 1580 0 cvt.u16.u32 %r860,%r325; setp.eq.u16 %r861,%r860,1; @ %r861 bra $L132; setp.eq.u16 %r863,%r860,2; @ %r863 bra $L256; .loc 1 1573 0 mov.u64 %r318,%r1379; bra $L131; $L258: .loc 1 1581 0 mov.u64 %r318,%r319; $L131: .loc 1 1583 0 add.u64 %r319,%r318,-1; cvt.u16.u64 %r866,%r324; and.b16 %r865,%r866,7; add.u16 %r868,%r865,48; cvt.u32.u16 %r870,%r868; cvt.s32.s8 %r195,%r870; st.u8 [%r319],%r870; .loc 1 1584 0 shr.u64 %r324,%r324,3; .loc 1 1585 0 setp.ne.u64 %r872,%r324,0; @ %r872 bra $L258; .loc 1 1587 0 cvt.u16.u32 %r874,%r195; set.u32.ne.u16 %r875,%r874,48; neg.s32 %r876,%r875; cvt.u16.u32 %r879,%r320; and.b16 %r878,%r879,1; cvt.u16.u32 %r882,%r876; and.b16 %r881,%r882,%r878; cvt.u32.u16 %r884,%r881; cvt.u16.u8 %r885,%r884; setp.ne.u16 %r886,%r885,0; @ %r886 bra $L134; sub.u64 %r887,%r1379,%r319; cvt.u32.u64 %r327,%r887; bra $L135; $L134: .loc 1 1588 0 add.u64 %r359,%r318,-2; mov.u32 %r888,48; st.u8 [%r319+-1],%r888; sub.u64 %r889,%r1379,%r359; cvt.u32.u64 %r327,%r889; mov.u64 %r319,%r359; bra $L135; $L132: .loc 1 1593 0 setp.gt.u64 %r890,%r324,9; @ %r890 bra $L259; .loc 1 1594 0 cvt.u16.u64 %r893,%r324; add.u16 %r892,%r893,48; cvt.u32.u16 %r894,%r892; st.u8 [%frame+167],%r894; .loc 1 1595 0 mov.u32 %r327,1; .loc 1 1594 0 add.u64 %r319,%frame,167; .loc 1 1595 0 bra $L135; $L259: .loc 1 1573 0 mov.u64 %r319,%r1379; $L136: .loc 1 1601 0 add.u64 %r319,%r319,-1; rem.u64 %r896,%r324,10; cvt.u16.u64 %r899,%r896; add.u16 %r898,%r899,48; cvt.u32.u16 %r900,%r898; st.u8 [%r319],%r900; .loc 1 1622 0 div.u64 %r324,%r324,10; .loc 1 1623 0 setp.ne.u64 %r903,%r324,0; @ %r903 bra $L136; sub.u64 %r904,%r1379,%r319; cvt.u32.u64 %r327,%r904; bra $L135; $L256: .loc 1 1573 0 mov.u64 %r319,%r1379; $L133: .loc 1 1628 0 add.u64 %r319,%r319,-1; and.b64 %r905,%r324,15; add.u64 %r906,%r117,%r905; ld.u8 %r907,[%r906]; st.u8 [%r319],%r907; .loc 1 1629 0 shr.u64 %r324,%r324,4; .loc 1 1630 0 setp.ne.u64 %r908,%r324,0; @ %r908 bra $L133; sub.u64 %r909,%r1379,%r319; cvt.u32.u64 %r327,%r909; bra $L135; $L130: .loc 1 1648 0 setp.eq.u32 %r910,%r325,0; @ %r910 bra $L137; $L239: ld.s8 %r458,[%frame+218]; .loc 1 1594 0 mov.u32 %r320,%r357; mov.u32 %r322,0; mov.u32 %r327,%r322; .loc 1 1573 0 mov.u64 %r319,%r1379; bra $L135; $L137: .loc 1 1648 0 and.b32 %r327,%r320,1; setp.ne.u32 %r911,%r327,0; @ %r911 bra $L138; mov.u32 %r322,%r325; mov.u32 %r458,%r322; .loc 1 1566 0 mov.u32 %r320,%r357; .loc 1 1573 0 mov.u64 %r319,%r1379; bra $L135; $L138: .loc 1 1649 0 mov.u32 %r912,48; st.u8 [%frame+167],%r912; mov.u32 %r458,%r325; .loc 1 1566 0 mov.u32 %r320,%r357; .loc 1 1649 0 mov.u32 %r322,%r458; add.u64 %r319,%frame,167; $L135: max.s32 %r326,%r322,%r327; .loc 1 948 0 mov.u32 %r156,0; bra $L63; $L18: setp.eq.u32 %r913,%r397,0; @ %r913 bra $L139; cvt.u32.u32 %r914,%r329; st.u8 [%frame+218],%r914; $L139: .loc 1 1655 0 setp.eq.u32 %r915,%r316,0; @ %r915 bra $L15; .loc 1 1659 0 st.u8 [%frame+128],%r316; .loc 1 1661 0 mov.u32 %r916,0; st.u8 [%frame+218],%r916; .loc 1 1662 0 mov.u32 %r326,1; .loc 1 1660 0 mov.u32 %r327,%r326; .loc 1 943 0 mov.u32 %r322,0; .loc 1 948 0 mov.u32 %r156,%r322; .loc 1 1658 0 add.u64 %r319,%frame,128; setp.eq.u32 %r1353,1,1; .loc 1 1662 0 bra $L140; $L63: .loc 1 1681 0 setp.eq.u32 %r1353,%r458,0; @ %r1353 bra $L140; $L365: .loc 1 1682 0 add.u32 %r326,%r326,1; $L140: .loc 1 1683 0 and.b32 %r208,%r320,2; setp.eq.u32 %r1348,%r208,0; @ %r1348 bra $L141; .loc 1 1684 0 add.u32 %r326,%r326,2; $L141: .loc 1 1687 0 and.b32 %r209,%r320,132; ld.u64 %r459,[%frame+184]; setp.ne.u32 %r919,%r209,0; @ %r919 bra $L142; .loc 1 1688 0 sub.u32 %r261,%r321,%r326; setp.le.s32 %r920,%r261,0; @ %r920 bra $L142; ld.u32 %r477,[%frame+176]; setp.le.s32 %r921,%r261,16; @ ! %r921 bra $L366; cvta.const.u64 %r1355,blanks$4117; bra $L143; $L366: cvta.const.u64 %r1355,blanks$4117; $L146: st.u64 [%r328],%r1355; mov.u64 %r923,16; st.u64 [%r328+8],%r923; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r477,%r477,1; st.u32 [%frame+176],%r477; setp.gt.s32 %r924,%r477,7; @ %r924 bra $L144; add.u64 %r328,%r328,16; bra $L145; $L144: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r929,[%value_in]; } setp.ne.u32 %r930,%r929,0; @ %r930 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r477,[%frame+176]; mov.u64 %r328,%frame; $L145: add.u32 %r261,%r261,-16; setp.gt.s32 %r931,%r261,16; @ %r931 bra $L146; $L143: st.u64 [%r328],%r1355; cvt.s64.s32 %r211,%r261; st.u64 [%r328+8],%r211; add.u64 %r459,%r459,%r211; st.u64 [%frame+184],%r459; add.u32 %r212,%r477,1; st.u32 [%frame+176],%r212; setp.gt.s32 %r933,%r212,7; @ %r933 bra $L147; add.u64 %r328,%r328,16; ld.s8 %r458,[%frame+218]; setp.eq.u32 %r1353,%r458,0; bra $L142; $L147: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r938,[%value_in]; } setp.ne.u32 %r939,%r938,0; @ %r939 bra $L14; ld.s8 %r458,[%frame+218]; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; setp.eq.u32 %r1353,%r458,0; $L142: .loc 1 1691 0 @ %r1353 bra $L148; .loc 1 1692 0 st.u64 [%r328],%r1382; mov.u64 %r942,1; st.u64 [%r328+8],%r942; add.u64 %r459,%r459,1; st.u64 [%frame+184],%r459; ld.u32 %r943,[%frame+176]; add.u32 %r215,%r943,1; st.u32 [%frame+176],%r215; setp.gt.s32 %r944,%r215,7; @ %r944 bra $L149; add.u64 %r328,%r328,16; bra $L148; $L149: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r949,[%value_in]; } setp.ne.u32 %r950,%r949,0; @ %r950 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L148: .loc 1 1693 0 @ %r1348 bra $L150; .loc 1 1694 0 st.u64 [%r328],%r1381; mov.u64 %r953,2; st.u64 [%r328+8],%r953; add.u64 %r459,%r459,2; st.u64 [%frame+184],%r459; ld.u32 %r954,[%frame+176]; add.u32 %r219,%r954,1; st.u32 [%frame+176],%r219; setp.gt.s32 %r955,%r219,7; @ %r955 bra $L151; add.u64 %r328,%r328,16; bra $L150; $L151: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r960,[%value_in]; } setp.ne.u32 %r961,%r960,0; @ %r961 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L150: .loc 1 1697 0 setp.ne.u32 %r962,%r209,128; @ %r962 bra $L152; .loc 1 1698 0 sub.u32 %r355,%r321,%r326; setp.le.s32 %r963,%r355,0; @ %r963 bra $L152; ld.u32 %r476,[%frame+176]; setp.le.s32 %r964,%r355,16; @ ! %r964 bra $L367; cvta.const.u64 %r1349,zeroes$4118; bra $L153; $L367: cvta.const.u64 %r1349,zeroes$4118; $L156: st.u64 [%r328],%r1349; mov.u64 %r966,16; st.u64 [%r328+8],%r966; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r476,%r476,1; st.u32 [%frame+176],%r476; setp.gt.s32 %r967,%r476,7; @ %r967 bra $L154; add.u64 %r328,%r328,16; bra $L155; $L154: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r972,[%value_in]; } setp.ne.u32 %r973,%r972,0; @ %r973 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r476,[%frame+176]; mov.u64 %r328,%frame; $L155: add.u32 %r355,%r355,-16; setp.gt.s32 %r974,%r355,16; @ %r974 bra $L156; $L153: st.u64 [%r328],%r1349; cvt.s64.s32 %r222,%r355; st.u64 [%r328+8],%r222; add.u64 %r459,%r459,%r222; st.u64 [%frame+184],%r459; add.u32 %r224,%r476,1; st.u32 [%frame+176],%r224; setp.gt.s32 %r976,%r224,7; @ %r976 bra $L157; add.u64 %r328,%r328,16; bra $L152; $L157: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r981,[%value_in]; } setp.ne.u32 %r982,%r981,0; @ %r982 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L152: .loc 1 1701 0 sub.u32 %r365,%r322,%r327; setp.le.s32 %r983,%r365,0; @ %r983 bra $L158; ld.u32 %r475,[%frame+176]; setp.le.s32 %r984,%r365,16; @ ! %r984 bra $L368; cvta.const.u64 %r1349,zeroes$4118; bra $L159; $L368: cvta.const.u64 %r1349,zeroes$4118; $L162: st.u64 [%r328],%r1349; mov.u64 %r986,16; st.u64 [%r328+8],%r986; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r475,%r475,1; st.u32 [%frame+176],%r475; setp.gt.s32 %r987,%r475,7; @ %r987 bra $L160; add.u64 %r328,%r328,16; bra $L161; $L160: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r992,[%value_in]; } setp.ne.u32 %r993,%r992,0; @ %r993 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r475,[%frame+176]; mov.u64 %r328,%frame; $L161: add.u32 %r365,%r365,-16; setp.gt.s32 %r994,%r365,16; @ %r994 bra $L162; $L159: st.u64 [%r328],%r1349; cvt.s64.s32 %r227,%r365; st.u64 [%r328+8],%r227; add.u64 %r459,%r459,%r227; st.u64 [%frame+184],%r459; add.u32 %r228,%r475,1; st.u32 [%frame+176],%r228; setp.gt.s32 %r996,%r228,7; @ %r996 bra $L163; add.u64 %r328,%r328,16; bra $L158; $L163: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1001,[%value_in]; } setp.ne.u32 %r1002,%r1001,0; @ %r1002 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L158: .loc 1 1705 0 and.b32 %r1003,%r320,256; setp.ne.u32 %r1004,%r1003,0; @ %r1004 bra $L164; .loc 1 1706 0 st.u64 [%r328],%r319; cvt.s64.s32 %r231,%r327; st.u64 [%r328+8],%r231; add.u64 %r459,%r459,%r231; st.u64 [%frame+184],%r459; ld.u32 %r1005,[%frame+176]; add.u32 %r233,%r1005,1; st.u32 [%frame+176],%r233; setp.gt.s32 %r1006,%r233,7; @ %r1006 bra $L165; add.u64 %r328,%r328,16; bra $L166; $L165: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1011,[%value_in]; } setp.ne.u32 %r1012,%r1011,0; @ %r1012 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L164: .loc 1 1708 0 setp.le.s32 %r1013,%r316,101; @ %r1013 bra $L167; .loc 1 1709 0 setp.neu.f64 %r1014,%r343,0d0000000000000000; @ %r1014 bra $L168; .loc 1 1711 0 cvta.const.u64 %r1015,$LC7; st.u64 [%r328],%r1015; mov.u64 %r1016,1; st.u64 [%r328+8],%r1016; add.u64 %r1017,%r459,1; st.u64 [%frame+184],%r1017; ld.u32 %r1018,[%frame+176]; add.u32 %r238,%r1018,1; st.u32 [%frame+176],%r238; setp.gt.s32 %r1019,%r238,7; @ %r1019 bra $L169; add.u64 %r328,%r328,16; bra $L170; $L169: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1024,[%value_in]; } setp.ne.u32 %r1025,%r1024,0; @ %r1025 bra $L14; mov.u64 %r328,%frame; $L170: .loc 1 1712 0 ld.u32 %r1026,[%frame+212]; setp.lt.s32 %r1027,%r1026,%r407; @ %r1027 bra $L171; and.b32 %r1028,%r320,1; setp.ne.u32 %r1029,%r1028,0; @ %r1029 bra $L171; ld.u64 %r459,[%frame+184]; bra $L166; $L171: .loc 1 1713 0 st.u64 [%r328],%r334; st.u64 [%r328+8],%r513; ld.u64 %r1030,[%frame+184]; add.u64 %r459,%r513,%r1030; st.u64 [%frame+184],%r459; ld.u32 %r1031,[%frame+176]; add.u32 %r244,%r1031,1; st.u32 [%frame+176],%r244; setp.gt.s32 %r1032,%r244,7; @ %r1032 bra $L172; add.u64 %r328,%r328,16; bra $L173; $L172: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1037,[%value_in]; } setp.ne.u32 %r1038,%r1037,0; @ %r1038 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L173: .loc 1 1714 0 add.u32 %r254,%r407,-1; setp.le.s32 %r1039,%r254,0; @ %r1039 bra $L166; ld.u32 %r474,[%frame+176]; setp.le.s32 %r1040,%r254,16; @ ! %r1040 bra $L369; cvta.const.u64 %r1349,zeroes$4118; bra $L174; $L369: cvta.const.u64 %r1349,zeroes$4118; $L177: st.u64 [%r328],%r1349; mov.u64 %r1042,16; st.u64 [%r328+8],%r1042; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r474,%r474,1; st.u32 [%frame+176],%r474; setp.gt.s32 %r1043,%r474,7; @ %r1043 bra $L175; add.u64 %r328,%r328,16; bra $L176; $L175: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1048,[%value_in]; } setp.ne.u32 %r1049,%r1048,0; @ %r1049 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r474,[%frame+176]; mov.u64 %r328,%frame; $L176: add.u32 %r254,%r254,-16; setp.gt.s32 %r1050,%r254,16; @ %r1050 bra $L177; $L174: st.u64 [%r328],%r1349; cvt.s64.s32 %r247,%r254; st.u64 [%r328+8],%r247; add.u64 %r459,%r459,%r247; st.u64 [%frame+184],%r459; add.u32 %r249,%r474,1; st.u32 [%frame+176],%r249; setp.gt.s32 %r1052,%r249,7; @ %r1052 bra $L178; add.u64 %r328,%r328,16; bra $L166; $L178: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1057,[%value_in]; } setp.ne.u32 %r1058,%r1057,0; @ %r1058 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L168: .loc 1 1716 0 ld.u32 %r251,[%frame+212]; setp.gt.s32 %r1059,%r251,0; @ %r1059 bra $L179; .loc 1 1717 0 cvta.const.u64 %r1060,$LC7; st.u64 [%r328],%r1060; mov.u64 %r1061,1; st.u64 [%r328+8],%r1061; add.u64 %r459,%r459,1; st.u64 [%frame+184],%r459; ld.u32 %r1062,[%frame+176]; add.u32 %r253,%r1062,1; st.u32 [%frame+176],%r253; setp.gt.s32 %r1063,%r253,7; @ %r1063 bra $L180; add.u64 %r328,%r328,16; bra $L181; $L180: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1068,[%value_in]; } setp.ne.u32 %r1069,%r1068,0; @ %r1069 bra $L14; ld.u32 %r251,[%frame+212]; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L181: .loc 1 1718 0 or.b32 %r1070,%r407,%r251; setp.ne.u32 %r1071,%r1070,0; @ %r1071 bra $L182; and.b32 %r1072,%r320,1; setp.eq.u32 %r1073,%r1072,0; @ %r1073 bra $L166; $L182: .loc 1 1719 0 st.u64 [%r328],%r334; st.u64 [%r328+8],%r513; add.u64 %r472,%r513,%r459; st.u64 [%frame+184],%r472; ld.u32 %r1074,[%frame+176]; add.u32 %r473,%r1074,1; st.u32 [%frame+176],%r473; setp.gt.s32 %r1075,%r473,7; @ %r1075 bra $L183; add.u64 %r330,%r328,16; bra $L184; $L183: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1080,[%value_in]; } setp.ne.u32 %r1081,%r1080,0; @ %r1081 bra $L14; ld.u32 %r251,[%frame+212]; ld.u64 %r472,[%frame+184]; ld.u32 %r473,[%frame+176]; mov.u64 %r330,%frame; $L184: .loc 1 1720 0 setp.ge.s32 %r1082,%r251,0; @ %r1082 bra $L185; neg.s32 %r159,%r251; setp.ge.s32 %r1083,%r251,-16; @ ! %r1083 bra $L370; cvta.const.u64 %r1349,zeroes$4118; bra $L186; $L370: cvta.const.u64 %r1349,zeroes$4118; $L189: st.u64 [%r330],%r1349; mov.u64 %r1085,16; st.u64 [%r330+8],%r1085; add.u64 %r472,%r472,16; st.u64 [%frame+184],%r472; add.u32 %r473,%r473,1; st.u32 [%frame+176],%r473; setp.gt.s32 %r1086,%r473,7; @ %r1086 bra $L187; add.u64 %r330,%r330,16; bra $L188; $L187: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1091,[%value_in]; } setp.ne.u32 %r1092,%r1091,0; @ %r1092 bra $L14; ld.u64 %r472,[%frame+184]; ld.u32 %r473,[%frame+176]; mov.u64 %r330,%frame; $L188: add.u32 %r159,%r159,-16; setp.gt.s32 %r1093,%r159,16; @ %r1093 bra $L189; $L186: st.u64 [%r330],%r1349; cvt.s64.s32 %r260,%r159; st.u64 [%r330+8],%r260; add.u64 %r472,%r472,%r260; st.u64 [%frame+184],%r472; add.u32 %r473,%r473,1; st.u32 [%frame+176],%r473; setp.gt.s32 %r1095,%r473,7; @ %r1095 bra $L190; add.u64 %r330,%r330,16; bra $L185; $L190: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1100,[%value_in]; } setp.ne.u32 %r1101,%r1100,0; @ %r1101 bra $L14; ld.u64 %r472,[%frame+184]; ld.u32 %r473,[%frame+176]; mov.u64 %r330,%frame; $L185: .loc 1 1721 0 st.u64 [%r330],%r319; cvt.s64.s32 %r263,%r407; st.u64 [%r330+8],%r263; add.u64 %r459,%r263,%r472; st.u64 [%frame+184],%r459; add.u32 %r264,%r473,1; st.u32 [%frame+176],%r264; setp.gt.s32 %r1102,%r264,7; @ %r1102 bra $L191; add.u64 %r328,%r330,16; bra $L166; $L191: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1107,[%value_in]; } setp.ne.u32 %r1108,%r1107,0; @ %r1108 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L179: min.s32 %r133,%r156,%r407; .loc 1 1725 0 setp.le.s32 %r1109,%r133,0; @ %r1109 bra $L192; st.u64 [%r328],%r319; cvt.s64.s32 %r266,%r133; st.u64 [%r328+8],%r266; add.u64 %r459,%r459,%r266; st.u64 [%frame+184],%r459; ld.u32 %r1110,[%frame+176]; add.u32 %r268,%r1110,1; st.u32 [%frame+176],%r268; setp.gt.s32 %r1111,%r268,7; @ %r1111 bra $L193; add.u64 %r328,%r328,16; bra $L192; $L193: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1116,[%value_in]; } setp.ne.u32 %r1117,%r1116,0; @ %r1117 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L192: max.s32 %r270,%r133,0; sub.u32 %r234,%r156,%r270; setp.le.s32 %r1118,%r234,0; @ %r1118 bra $L194; ld.u32 %r471,[%frame+176]; setp.le.s32 %r1119,%r234,16; @ ! %r1119 bra $L371; cvta.const.u64 %r1349,zeroes$4118; bra $L195; $L371: cvta.const.u64 %r1349,zeroes$4118; $L198: st.u64 [%r328],%r1349; mov.u64 %r1121,16; st.u64 [%r328+8],%r1121; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r471,%r471,1; st.u32 [%frame+176],%r471; setp.gt.s32 %r1122,%r471,7; @ %r1122 bra $L196; add.u64 %r328,%r328,16; bra $L197; $L196: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1127,[%value_in]; } setp.ne.u32 %r1128,%r1127,0; @ %r1128 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r471,[%frame+176]; mov.u64 %r328,%frame; $L197: add.u32 %r234,%r234,-16; setp.gt.s32 %r1129,%r234,16; @ %r1129 bra $L198; $L195: st.u64 [%r328],%r1349; cvt.s64.s32 %r272,%r234; st.u64 [%r328+8],%r272; add.u64 %r459,%r459,%r272; st.u64 [%frame+184],%r459; add.u32 %r273,%r471,1; st.u32 [%frame+176],%r273; setp.gt.s32 %r1131,%r273,7; @ %r1131 bra $L199; add.u64 %r328,%r328,16; bra $L194; $L199: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1136,[%value_in]; } setp.ne.u32 %r1137,%r1136,0; @ %r1137 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L194: .loc 1 1746 0 ld.u32 %r276,[%frame+212]; setp.lt.s32 %r1138,%r276,%r407; @ %r1138 bra $L200; and.b32 %r1139,%r320,1; setp.eq.u32 %r1140,%r1139,0; @ %r1140 bra $L201; $L200: .loc 1 1747 0 st.u64 [%r328],%r334; st.u64 [%r328+8],%r513; add.u64 %r459,%r459,%r513; st.u64 [%frame+184],%r459; ld.u32 %r1141,[%frame+176]; add.u32 %r279,%r1141,1; st.u32 [%frame+176],%r279; setp.gt.s32 %r1142,%r279,7; @ %r1142 bra $L202; add.u64 %r328,%r328,16; bra $L201; $L202: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1147,[%value_in]; } setp.ne.u32 %r1148,%r1147,0; @ %r1148 bra $L14; ld.u32 %r276,[%frame+212]; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L201: .loc 1 1748 0 sub.u32 %r368,%r407,%r156; sub.u32 %r281,%r407,%r276; min.s32 %r348,%r281,%r368; setp.le.s32 %r1149,%r348,0; @ %r1149 bra $L203; .loc 1 1727 0 cvt.s64.s32 %r1150,%r156; add.u64 %r1151,%r319,%r1150; .loc 1 1748 0 st.u64 [%r328],%r1151; cvt.s64.s32 %r284,%r348; st.u64 [%r328+8],%r284; add.u64 %r459,%r459,%r284; st.u64 [%frame+184],%r459; ld.u32 %r1152,[%frame+176]; add.u32 %r286,%r1152,1; st.u32 [%frame+176],%r286; setp.gt.s32 %r1153,%r286,7; @ %r1153 bra $L204; add.u64 %r328,%r328,16; bra $L203; $L204: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1158,[%value_in]; } setp.ne.u32 %r1159,%r1158,0; @ %r1159 bra $L14; ld.u32 %r1160,[%frame+212]; sub.u32 %r281,%r407,%r1160; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L203: max.s32 %r288,%r348,0; sub.u32 %r363,%r281,%r288; setp.le.s32 %r1161,%r363,0; @ %r1161 bra $L166; ld.u32 %r470,[%frame+176]; setp.le.s32 %r1162,%r363,16; @ ! %r1162 bra $L372; cvta.const.u64 %r1349,zeroes$4118; bra $L205; $L372: cvta.const.u64 %r1349,zeroes$4118; $L208: st.u64 [%r328],%r1349; mov.u64 %r1164,16; st.u64 [%r328+8],%r1164; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r470,%r470,1; st.u32 [%frame+176],%r470; setp.gt.s32 %r1165,%r470,7; @ %r1165 bra $L206; add.u64 %r328,%r328,16; bra $L207; $L206: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1170,[%value_in]; } setp.ne.u32 %r1171,%r1170,0; @ %r1171 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r470,[%frame+176]; mov.u64 %r328,%frame; $L207: add.u32 %r363,%r363,-16; setp.gt.s32 %r1172,%r363,16; @ %r1172 bra $L208; $L205: st.u64 [%r328],%r1349; cvt.s64.s32 %r290,%r363; st.u64 [%r328+8],%r290; add.u64 %r459,%r459,%r290; st.u64 [%frame+184],%r459; add.u32 %r291,%r470,1; st.u32 [%frame+176],%r291; setp.gt.s32 %r1174,%r291,7; @ %r1174 bra $L209; add.u64 %r328,%r328,16; bra $L166; $L209: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1179,[%value_in]; } setp.ne.u32 %r1180,%r1179,0; @ %r1180 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; bra $L166; $L167: add.u64 %r466,%r459,1; ld.u32 %r491,[%frame+176]; add.u32 %r464,%r491,1; add.u64 %r298,%r328,16; .loc 1 1752 0 setp.gt.s32 %r1181,%r407,1; @ %r1181 bra $L210; and.b32 %r1182,%r320,1; setp.eq.u32 %r1183,%r1182,0; @ %r1183 bra $L211; $L210: .loc 1 1753 0 st.u64 [%r328],%r319; mov.u64 %r1184,1; st.u64 [%r328+8],%r1184; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r464; setp.le.s32 %r1185,%r464,7; @ %r1185 bra $L212; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1190,[%value_in]; } setp.ne.u32 %r1191,%r1190,0; @ %r1191 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r464,[%frame+176]; mov.u64 %r298,%frame; $L212: .loc 1 1755 0 st.u64 [%r298],%r334; st.u64 [%r298+8],%r513; add.u64 %r466,%r466,%r513; st.u64 [%frame+184],%r466; add.u32 %r467,%r464,1; st.u32 [%frame+176],%r467; setp.gt.s32 %r1192,%r467,7; @ %r1192 bra $L213; add.u64 %r298,%r298,16; bra $L214; $L213: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1197,[%value_in]; } setp.ne.u32 %r1198,%r1197,0; @ %r1198 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r298,%frame; $L214: add.u32 %r465,%r467,1; mov.u32 %r1352,%r465; add.u32 %r282,%r407,-1; add.u64 %r328,%r298,16; .loc 1 1756 0 setp.eq.f64 %r1199,%r343,0d0000000000000000; @ %r1199 bra $L215; .loc 1 1754 0 add.u64 %r1200,%r319,1; .loc 1 1757 0 st.u64 [%r298],%r1200; cvt.s64.s32 %r296,%r282; st.u64 [%r298+8],%r296; add.u64 %r466,%r466,%r296; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r465; setp.gt.s32 %r1201,%r465,7; @ %r1201 bra $L216; add.u32 %r465,%r467,2; add.u64 %r492,%r298,32; mov.u64 %r298,%r328; mov.u64 %r328,%r492; bra $L217; $L216: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1206,[%value_in]; } setp.ne.u32 %r1207,%r1206,0; @ %r1207 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r1208,[%frame+176]; add.u32 %r465,%r1208,1; add.u64 %r328,%frame,16; mov.u64 %r298,%frame; bra $L217; $L215: .loc 1 1760 0 setp.le.s32 %r1209,%r282,0; @ %r1209 bra $L217; setp.le.s32 %r1210,%r282,16; @ %r1210 bra $L260; cvta.const.u64 %r1349,zeroes$4118; $L221: st.u64 [%r298],%r1349; mov.u64 %r1212,16; st.u64 [%r298+8],%r1212; add.u64 %r466,%r466,16; st.u64 [%frame+184],%r466; mov.u32 %r467,%r1352; st.u32 [%frame+176],%r467; setp.gt.s32 %r1213,%r467,7; @ %r1213 bra $L219; add.u64 %r298,%r298,16; bra $L220; $L219: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1218,[%value_in]; } setp.ne.u32 %r1219,%r1218,0; @ %r1219 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r467,[%frame+176]; mov.u64 %r298,%frame; $L220: add.u32 %r282,%r282,-16; setp.gt.s32 %r1220,%r282,16; @ ! %r1220 bra $L373; add.u32 %r1352,%r467,1; bra $L221; $L373: add.u32 %r465,%r467,1; add.u64 %r468,%r298,16; bra $L218; $L260: mov.u64 %r468,%r328; cvta.const.u64 %r1349,zeroes$4118; $L218: st.u64 [%r298],%r1349; cvt.s64.s32 %r301,%r282; st.u64 [%r298+8],%r301; add.u64 %r466,%r466,%r301; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r465; setp.gt.s32 %r1222,%r465,7; @ %r1222 bra $L222; add.u32 %r465,%r465,1; add.u64 %r328,%r468,16; mov.u64 %r298,%r468; bra $L217; $L222: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1227,[%value_in]; } setp.ne.u32 %r1228,%r1227,0; @ %r1228 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r1229,[%frame+176]; add.u32 %r465,%r1229,1; add.u64 %r328,%frame,16; mov.u64 %r298,%frame; bra $L217; $L211: .loc 1 1762 0 st.u64 [%r328],%r319; mov.u64 %r1230,1; st.u64 [%r328+8],%r1230; st.u64 [%frame+184],%r466; st.u32 [%frame+176],%r464; setp.gt.s32 %r1231,%r464,7; @ %r1231 bra $L223; add.u32 %r465,%r491,2; add.u64 %r328,%r328,32; bra $L217; $L223: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1236,[%value_in]; } setp.ne.u32 %r1237,%r1236,0; @ %r1237 bra $L14; ld.u64 %r466,[%frame+184]; ld.u32 %r1238,[%frame+176]; add.u32 %r465,%r1238,1; add.u64 %r328,%frame,16; mov.u64 %r298,%frame; $L217: .loc 1 1763 0 st.u64 [%r298],%r1380; cvt.s64.s32 %r305,%r323; st.u64 [%r298+8],%r305; add.u64 %r459,%r305,%r466; st.u64 [%frame+184],%r459; st.u32 [%frame+176],%r465; setp.le.s32 %r1240,%r465,7; @ %r1240 bra $L166; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1245,[%value_in]; } setp.ne.u32 %r1246,%r1245,0; @ %r1246 bra $L14; ld.u64 %r459,[%frame+184]; mov.u64 %r328,%frame; $L166: .loc 1 1770 0 and.b32 %r1247,%r320,4; setp.eq.u32 %r1248,%r1247,0; @ %r1248 bra $L224; .loc 1 1771 0 sub.u32 %r158,%r321,%r326; setp.le.s32 %r1249,%r158,0; @ %r1249 bra $L224; ld.u32 %r460,[%frame+176]; setp.le.s32 %r1250,%r158,16; @ ! %r1250 bra $L374; cvta.const.u64 %r1355,blanks$4117; bra $L225; $L374: cvta.const.u64 %r1355,blanks$4117; $L228: st.u64 [%r328],%r1355; mov.u64 %r1252,16; st.u64 [%r328+8],%r1252; add.u64 %r459,%r459,16; st.u64 [%frame+184],%r459; add.u32 %r460,%r460,1; st.u32 [%frame+176],%r460; setp.gt.s32 %r1253,%r460,7; @ %r1253 bra $L226; add.u64 %r328,%r328,16; bra $L227; $L226: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1258,[%value_in]; } setp.ne.u32 %r1259,%r1258,0; @ %r1259 bra $L14; ld.u64 %r459,[%frame+184]; ld.u32 %r460,[%frame+176]; mov.u64 %r328,%frame; $L227: add.u32 %r158,%r158,-16; setp.gt.s32 %r1260,%r158,16; @ %r1260 bra $L228; $L225: st.u64 [%r328],%r1355; cvt.s64.s32 %r309,%r158; st.u64 [%r328+8],%r309; add.u64 %r459,%r459,%r309; st.u64 [%frame+184],%r459; add.u32 %r310,%r460,1; st.u32 [%frame+176],%r310; setp.le.s32 %r1262,%r310,7; @ %r1262 bra $L224; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1267,[%value_in]; } setp.ne.u32 %r1268,%r1267,0; @ %r1268 bra $L14; ld.u64 %r459,[%frame+184]; $L224: .loc 1 1774 0 max.s32 %r1269,%r321,%r326; add.u32 %r495,%r495,%r1269; .loc 1 1776 0 setp.ne.u64 %r1270,%r459,0; @ %r1270 bra $L229; $L230: mov.u32 %r1271,0; st.u32 [%frame+176],%r1271; mov.u64 %r328,%frame; bra $L9; $L229: { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1379; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1276,[%value_in]; } setp.ne.u32 %r1277,%r1276,0; @ ! %r1277 bra $L230; .loc 1 1785 0 bra $L14; $L15: .loc 1 1784 0 ld.u64 %r1278,[%frame+184]; setp.eq.u64 %r1279,%r1278,0; @ %r1279 bra $L14; add.u64 %r1283,%frame,168; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r497; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r1283; call (%value_in),__sprint_r,(%out_arg1,%out_arg2,%out_arg3); ld.param.u32 %r1284,[%value_in]; } $L14: .loc 1 1791 0 ld.u16 %r1286,[%r497+16]; and.b16 %r1285,%r1286,64; setp.eq.u16 %r1287,%r1285,0; @ %r1287 bra $L1; $L6: mov.u32 %r495,-1; bra $L1; $L261: .loc 1 1882 0 mov.u32 %r378,%r322; $L83: .loc 1 1883 0 cvt.s64.s32 %r1289,%r378; add.u64 %r382,%r319,%r1289; bra $L231; $L82: .loc 1 1880 0 mov.u32 %r1292,2; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r375; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1292; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r322; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1385; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1384; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1383; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1300,[%value_in]; } mov.u64 %r319,%r1300; .loc 1 1882 0 setp.ne.u32 %r1354,%r454,71; @ ! %r1354 bra $L375; bra $L261; $L81: .loc 1 1880 0 mov.u32 %r1304,3; { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r496; .param .f64 %out_arg2; st.param.f64 [%out_arg2],%r375; .param .u32 %out_arg3; st.param.u32 [%out_arg3],%r1304; .param .u32 %out_arg4; st.param.u32 [%out_arg4],%r322; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r1385; .param .u64 %out_arg6; st.param.u64 [%out_arg6],%r1384; .param .u64 %out_arg7; st.param.u64 [%out_arg7],%r1383; call (%value_in),_dtoa_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5,%out_arg6,%out_arg7); ld.param.u64 %r1312,[%value_in]; } mov.u64 %r319,%r1312; .loc 1 1883 0 cvt.s64.s32 %r360,%r322; .loc 1 1885 0 ld.s8 %r1315,[%r1312]; cvt.u16.u32 %r1314,%r1315; set.u32.eq.u16 %r1316,%r1314,48; neg.s32 %r1317,%r1316; set.u32.neu.f64 %r1319,%r375,0d0000000000000000; neg.s32 %r1320,%r1319; cvt.u16.u32 %r1322,%r1317; cvt.u16.u32 %r1323,%r1320; and.b16 %r1321,%r1322,%r1323; cvt.u32.u16 %r1324,%r1321; cvt.u16.u8 %r1325,%r1324; setp.ne.u16 %r1326,%r1325,0; @ ! %r1326 bra $L376; bra $L233; $L69: .loc 1 1565 0 setp.ne.u32 %r1328,%r322,-1; @ %r1328 bra $L235; ld.s8 %r458,[%frame+218]; bra $L132; $L236: .loc 1 1883 0 cvt.s64.s32 %r1329,%r322; add.u64 %r382,%r319,%r1329; bra $L231; $L375: .loc 1 1882 0 and.b32 %r1330,%r320,1; setp.ne.u32 %r1331,%r1330,0; @ %r1331 bra $L236; bra $L377; $L235: .loc 1 1566 0 and.b32 %r357,%r320,-129; .loc 1 1574 0 set.u32.ne.u32 %r1333,%r322,0; neg.s32 %r1334,%r1333; set.u32.ne.u64 %r1336,%r324,0; neg.s32 %r1337,%r1336; cvt.u16.u32 %r1339,%r1334; cvt.u16.u32 %r1340,%r1337; or.b16 %r1338,%r1339,%r1340; cvt.u32.u16 %r1341,%r1338; cvt.u16.u8 %r1342,%r1341; setp.ne.u16 %r1343,%r1342,0; @ ! %r1343 bra $L239; bra $L262; $L1: .loc 1 1793 0 mov.u32 %value,%r495; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vfprintf .visible .func (.param .u32 %value_out) vfprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u32 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 657 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; call (%value_in),_vfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r32,[%value_in]; } .loc 1 659 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } // BEGIN FUNCTION DEF: __sbprintf .func (.param .u32 %value_out) __sbprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,1200; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r33; .reg .u64 %r34; .reg .u64 %r35; .reg .u64 %r36; .reg .u64 %r37; .reg .u16 %r38; .reg .u16 %r39; .reg .u32 %r40; .reg .u16 %r41; .reg .u64 %r42; .reg .u64 %r43; .reg .u32 %r44; .reg .u32 %r46; .reg .u64 %r51; .reg .u32 %r52; .reg .pred %r53; .reg .u32 %r57; .reg .pred %r58; .reg .u16 %r59; .reg .u16 %r60; .reg .pred %r61; .reg .u16 %r62; .reg .u16 %r63; mov.u64 %r34,%ar0; mov.u64 %r35,%ar1; mov.u64 %r36,%ar2; mov.u64 %r37,%ar3; .loc 1 470 0 ld.u16 %r39,[%r35+16]; and.b16 %r38,%r39,-3; st.u16 [%frame+1040],%r38; .loc 1 471 0 ld.u32 %r40,[%r35+172]; st.u32 [%frame+1196],%r40; .loc 1 472 0 ld.u16 %r41,[%r35+18]; st.u16 [%frame+1042],%r41; .loc 1 473 0 ld.u64 %r42,[%r35+48]; st.u64 [%frame+1072],%r42; .loc 1 474 0 ld.u64 %r43,[%r35+64]; st.u64 [%frame+1088],%r43; .loc 1 477 0 st.u64 [%frame+1024],%frame; st.u64 [%frame+1048],%frame; .loc 1 478 0 mov.u32 %r44,1024; st.u32 [%frame+1036],%r44; st.u32 [%frame+1056],%r44; .loc 1 479 0 mov.u32 %r46,0; st.u32 [%frame+1064],%r46; .loc 1 485 0 add.u64 %r51,%frame,1024; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r34; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r51; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r36; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r37; call (%value_in),_vfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r52,[%value_in]; } mov.u32 %r33,%r52; .loc 1 486 0 setp.lt.s32 %r53,%r33,0; @ %r53 bra $L380; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r34; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r51; call (%value_in),_fflush_r,(%out_arg1,%out_arg2); ld.param.u32 %r57,[%value_in]; } setp.eq.u32 %r58,%r57,0; .loc 1 487 0 selp.u32 %r33,%r33,-1,%r58; $L380: .loc 1 488 0 ld.u16 %r60,[%frame+1040]; and.b16 %r59,%r60,64; setp.eq.u16 %r61,%r59,0; @ %r61 bra $L379; .loc 1 489 0 ld.u16 %r63,[%r35+16]; or.b16 %r62,%r63,64; st.u16 [%r35+16],%r62; $L379: .loc 1 495 0 mov.u32 %value,%r33; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } /921 0 0 0 644 5036 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _vsnprintf_r .visible .func (.param .u32 %value_out) _vsnprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4); .file 1 "../../../../../../newlib/libc/stdio/vsnprintf.c" // BEGIN GLOBAL FUNCTION DECL: vsnprintf .visible .func (.param .u32 %value_out) vsnprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: _vsnprintf_r .visible .func (.param .u32 %value_out) _vsnprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3, .param .u64 %in_ar4) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %ar4; ld.param.u64 %ar4,[%in_ar4]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r24; .reg .u32 %r25; .reg .u32 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u64 %r29; .reg .u64 %r30; .reg .u64 %r31; .reg .pred %r32; .reg .u32 %r33; .reg .u16 %r34; .reg .pred %r35; .reg .u32 %r36; .reg .u16 %r37; .reg .u32 %r42; .reg .pred %r43; .reg .u32 %r44; .reg .u32 %r46; .reg .u16 %r48; .reg .u32 %r53; .reg .pred %r54; .reg .u32 %r55; .reg .u32 %r56; mov.u64 %r27,%ar0; mov.u64 %r28,%ar1; mov.u64 %r29,%ar2; mov.u64 %r30,%ar3; mov.u64 %r31,%ar4; .loc 1 63 0 setp.le.u64 %r32,%r29,2147483647; @ %r32 bra $L2; .loc 1 65 0 mov.u32 %r33,139; st.u32 [%r27],%r33; .loc 1 66 0 mov.u32 %r26,-1; bra $L1; $L2: .loc 1 68 0 mov.u16 %r34,520; st.u16 [%frame+16],%r34; .loc 1 69 0 st.u64 [%frame],%r28; st.u64 [%frame+24],%r28; .loc 1 70 0 setp.eq.u64 %r35,%r29,0; @ %r35 bra $L4; cvt.u32.u64 %r36,%r29; add.u32 %r25,%r36,-1; st.u32 [%frame+12],%r25; st.u32 [%frame+32],%r25; .loc 1 71 0 mov.u16 %r37,-1; st.u16 [%frame+18],%r37; .loc 1 72 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r31; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r42,[%value_in]; } mov.u32 %r26,%r42; .loc 1 73 0 setp.lt.s32 %r43,%r26,-1; @ %r43 bra $L5; $L7: .loc 1 76 0 ld.u64 %r24,[%frame]; mov.u32 %r44,0; st.u8 [%r24],%r44; bra $L1; $L4: .loc 1 70 0 cvt.u32.u64 %r46,%r29; st.u32 [%frame+12],%r46; st.u32 [%frame+32],%r46; .loc 1 71 0 mov.u16 %r48,-1; st.u16 [%frame+18],%r48; .loc 1 72 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r27; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r30; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r31; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r53,[%value_in]; } mov.u32 %r26,%r53; .loc 1 73 0 setp.lt.s32 %r54,%r26,-1; @ ! %r54 bra $L1; bra $L6; $L5: .loc 1 74 0 mov.u32 %r55,139; st.u32 [%r27],%r55; bra $L7; $L6: mov.u32 %r56,139; st.u32 [%r27],%r56; $L1: .loc 1 78 0 mov.u32 %value,%r26; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vsnprintf .visible .func (.param .u32 %value_out) vsnprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r33; .reg .u32 %r34; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 41 0 ld.global.u64 %r33,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r33; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; .param .u64 %out_arg5; st.param.u64 [%out_arg5],%r27; call (%value_in),_vsnprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4,%out_arg5); ld.param.u32 %r34,[%value_in]; } .loc 1 42 0 mov.u32 %value,%r34; st.param.u32 [%value_out],%value; ret; } /940 0 0 0 644 3439 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _vsprintf_r .visible .func (.param .u32 %value_out) _vsprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdio/vsprintf.c" // BEGIN GLOBAL FUNCTION DECL: vsprintf .visible .func (.param .u32 %value_out) vsprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: _svfprintf_r .extern .func (.param .u32 %value_out) _svfprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: _vsprintf_r .visible .func (.param .u32 %value_out) _vsprintf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r22; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u32 %r28; .reg .u32 %r30; .reg .u32 %r35; .reg .u32 %r36; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; mov.u64 %r27,%ar3; .loc 1 61 0 st.u64 [%frame],%r25; st.u64 [%frame+24],%r25; .loc 1 62 0 mov.u32 %r28,2147483647; st.u32 [%frame+32],%r28; st.u32 [%frame+12],%r28; mov.u32 %r30,-65016; st.u32 [%frame+16],%r30; .loc 1 64 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r24; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r26; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r27; call (%value_in),_svfprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r35,[%value_in]; } .loc 1 65 0 ld.u64 %r22,[%frame]; mov.u32 %r36,0; st.u8 [%r22],%r36; .loc 1 67 0 mov.u32 %value,%r35; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vsprintf .visible .func (.param .u32 %value_out) vsprintf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u32 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 39 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; call (%value_in),_vsprintf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r32,[%value_in]; } .loc 1 40 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-vsscanf.o/0 0 0 644 4042 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: _vsscanf_r .visible .func (.param .u32 %value_out) _vsscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); .file 1 "../../../../../../newlib/libc/stdio/vsscanf.c" // BEGIN GLOBAL FUNCTION DECL: vsscanf .visible .func (.param .u32 %value_out) vsscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); // BEGIN GLOBAL VAR DECL: _impure_ptr .extern .global .align 8 .u64 _impure_ptr[1]; // BEGIN GLOBAL FUNCTION DECL: strlen .extern .func (.param .u64 %value_out) strlen (.param .u64 %in_ar0); // BEGIN GLOBAL FUNCTION DECL: __seofread .extern .func (.param .u32 %value_out) __seofread (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u32 %in_ar3); // BEGIN GLOBAL FUNCTION DECL: __ssvfscanf_r .extern .func (.param .u32 %value_out) __ssvfscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // BEGIN GLOBAL FUNCTION DEF: _vsscanf_r .visible .func (.param .u32 %value_out) _vsscanf_r (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2, .param .u64 %in_ar3) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %ar3; ld.param.u64 %ar3,[%in_ar3]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,176; sub.u64 %stack,%frame,0; st.shared.u64 [%sspslot],%stack; } .reg .u32 %r23; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r27; .reg .u64 %r28; .reg .u16 %r29; .reg .u64 %r31; .reg .u64 %r32; .reg .u64 %r33; .reg .u16 %r35; .reg .u32 %r40; mov.u64 %r25,%ar0; mov.u64 %r26,%ar1; mov.u64 %r27,%ar2; mov.u64 %r28,%ar3; .loc 1 63 0 mov.u16 %r29,516; st.u16 [%frame+16],%r29; .loc 1 64 0 st.u64 [%frame],%r26; st.u64 [%frame+24],%r26; .loc 1 65 0 { .param .u64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r26; call (%value_in),strlen,(%out_arg1); ld.param.u64 %r31,[%value_in]; } cvt.u32.u64 %r23,%r31; st.u32 [%frame+8],%r23; st.u32 [%frame+32],%r23; .loc 1 66 0 mov.u64 %r32,__seofread; st.u64 [%frame+56],%r32; .loc 1 67 0 mov.u64 %r33,0; st.u64 [%frame+88],%r33; .loc 1 68 0 st.u64 [%frame+120],%r33; .loc 1 69 0 mov.u16 %r35,-1; st.u16 [%frame+18],%r35; .loc 1 70 0 { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r25; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%frame; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r27; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r28; call (%value_in),__ssvfscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r40,[%value_in]; } .loc 1 71 0 mov.u32 %value,%r40; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } // BEGIN GLOBAL FUNCTION DEF: vsscanf .visible .func (.param .u32 %value_out) vsscanf (.param .u64 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %r24; .reg .u64 %r25; .reg .u64 %r26; .reg .u64 %r31; .reg .u32 %r32; mov.u64 %r24,%ar0; mov.u64 %r25,%ar1; mov.u64 %r26,%ar2; .loc 1 43 0 ld.global.u64 %r31,[_impure_ptr]; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r31; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; .param .u64 %out_arg3; st.param.u64 [%out_arg3],%r25; .param .u64 %out_arg4; st.param.u64 [%out_arg4],%r26; call (%value_in),_vsscanf_r,(%out_arg1,%out_arg2,%out_arg3,%out_arg4); ld.param.u32 %r32,[%value_in]; } .loc 1 44 0 mov.u32 %value,%r32; st.param.u32 [%value_out],%value; ret; } lib_a-wcstold.o/0 0 0 644 1018 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // END PREAMBLE // BEGIN GLOBAL FUNCTION DECL: wcstold .visible .func (.param .f64 %value_out) wcstold (.param .u64 %in_ar0, .param .u64 %in_ar1); .file 1 "../../../../../../newlib/libc/stdlib/wcstold.c" // BEGIN GLOBAL FUNCTION DECL: wcstod .extern .func (.param .f64 %value_out) wcstod (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL FUNCTION DEF: wcstold .visible .func (.param .f64 %value_out) wcstold (.param .u64 %in_ar0, .param .u64 %in_ar1) { .reg .f64 %value; .reg .u64 %ar0; ld.param.u64 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %r23; .reg .u64 %r24; .reg .f64 %r27; mov.u64 %r23,%ar0; mov.u64 %r24,%ar1; .loc 1 39 0 { .param .f64 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r23; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%r24; call (%value_in),wcstod,(%out_arg1,%out_arg2); ld.param.f64 %r27,[%value_in]; } .loc 1 40 0 mov.f64 %value,%r27; st.param.f64 [%value_out],%value; ret; } lib_a-write.o/ 0 0 0 644 2523 ` // BEGIN PREAMBLE .version 3.1 .target sm_30 .address_size 64 // BEGIN GLOBAL FUNCTION DECL: write .visible .func (.param .u32 %value_out) write (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2); .file 1 "../../../../../../../newlib/libc/machine/nvptx/write.c" // BEGIN GLOBAL FUNCTION DECL: __errno .extern .func (.param .u64 %value_out) __errno; // BEGIN GLOBAL FUNCTION DECL: printf .extern .func (.param .u32 %value_out) printf (.param .u64 %in_ar0, .param .u64 %in_ar1); // BEGIN GLOBAL VAR DECL: __nvptx_stacks .extern .shared .u64 __nvptx_stacks[32]; // END PREAMBLE // BEGIN VAR DEF: $LC0 .const .align 1 .u8 $LC0[3] = {37,99,0 }; // BEGIN GLOBAL FUNCTION DEF: write .visible .func (.param .u32 %value_out) write (.param .u32 %in_ar0, .param .u64 %in_ar1, .param .u64 %in_ar2) { .reg .u32 %value; .reg .u32 %ar0; ld.param.u32 %ar0,[%in_ar0]; .reg .u64 %ar1; ld.param.u64 %ar1,[%in_ar1]; .reg .u64 %ar2; ld.param.u64 %ar2,[%in_ar2]; .reg .u64 %stack; .reg .u64 %frame; .reg .u64 %sspslot; .reg .u64 %sspprev; { .reg .u32 %fstmp0; .reg .u64 %fstmp1; .reg .u64 %fstmp2; mov.u32 %fstmp0,%tid.y; mul.wide.u32 %fstmp1,%fstmp0,8; mov.u64 %fstmp2,__nvptx_stacks; add.u64 %sspslot,%fstmp2,%fstmp1; ld.shared.u64 %sspprev,[%sspslot]; sub.u64 %frame,%sspprev,0; sub.u64 %stack,%frame,8; st.shared.u64 [%sspslot],%stack; } .reg .u64 %r54; .reg .u64 %r56; .reg .u32 %r57; .reg .u32 %r58; .reg .u64 %r59; .reg .u64 %r60; .reg .u32 %r61; .reg .pred %r62; .reg .pred %r63; .reg .u64 %r64; .reg .u32 %r65; .reg .u32 %r67; .reg .u32 %r68; .reg .pred %r70; .reg .u64 %r72; mov.u32 %r58,%ar0; mov.u64 %r59,%ar1; mov.u64 %r60,%ar2; .loc 1 25 0 add.u32 %r61,%r58,-1; setp.gt.u32 %r62,%r61,1; @ %r62 bra $L2; .loc 1 30 0 setp.ne.u64 %r63,%r60,0; @ %r63 bra $L3; bra $L4; $L2: .loc 1 27 0 { .param .u64 %value_in; call (%value_in),__errno; ld.param.u64 %r64,[%value_in]; } mov.u32 %r65,9; st.u32 [%r64],%r65; .loc 1 28 0 mov.u32 %r57,-1; bra $L1; $L3: mov.u64 %r56,%r59; add.u64 %r54,%r56,%r60; cvta.const.u64 %r72,$LC0; $L6: .loc 1 31 0 ld.s8 %r67,[%r56]; st.u32 [%stack],%r67; { .param .u32 %value_in; .param .u64 %out_arg1; st.param.u64 [%out_arg1],%r72; .param .u64 %out_arg2; st.param.u64 [%out_arg2],%stack; call (%value_in),printf,(%out_arg1,%out_arg2); ld.param.u32 %r68,[%value_in]; } add.u64 %r56,%r56,1; .loc 1 30 0 setp.ne.u64 %r70,%r54,%r56; @ %r70 bra $L6; $L4: .loc 1 32 0 cvt.u32.u64 %r57,%r60; $L1: .loc 1 33 0 mov.u32 %value,%r57; st.shared.u64 [%sspslot],%sspprev; st.param.u32 [%value_out],%value; ret; } 07070100000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000b00000000TRAILER!!!